LLVM 23.0.0git
PPCTargetMachine.cpp
Go to the documentation of this file.
1//===-- PPCTargetMachine.cpp - Define TargetMachine for PowerPC -----------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// Top-level implementation for the PowerPC target.
10//
11//===----------------------------------------------------------------------===//
12
13#include "PPCTargetMachine.h"
15#include "PPC.h"
17#include "PPCMachineScheduler.h"
18#include "PPCMacroFusion.h"
19#include "PPCSubtarget.h"
20#include "PPCTargetObjectFile.h"
23#include "llvm/ADT/StringRef.h"
31#include "llvm/CodeGen/Passes.h"
33#include "llvm/IR/Attributes.h"
34#include "llvm/IR/DataLayout.h"
35#include "llvm/IR/Function.h"
38#include "llvm/Pass.h"
46#include <cassert>
47#include <memory>
48#include <optional>
49#include <string>
50
51using namespace llvm;
52
53
54static cl::opt<bool>
55 EnableBranchCoalescing("enable-ppc-branch-coalesce", cl::Hidden,
56 cl::desc("enable coalescing of duplicate branches for PPC"));
57static cl::
58opt<bool> DisableCTRLoops("disable-ppc-ctrloops", cl::Hidden,
59 cl::desc("Disable CTR loops for PPC"));
60
61static cl::
62opt<bool> DisableInstrFormPrep("disable-ppc-instr-form-prep", cl::Hidden,
63 cl::desc("Disable PPC loop instr form prep"));
64
65static cl::opt<bool>
66VSXFMAMutateEarly("schedule-ppc-vsx-fma-mutation-early",
67 cl::Hidden, cl::desc("Schedule VSX FMA instruction mutation early"));
68
69static cl::
70opt<bool> DisableVSXSwapRemoval("disable-ppc-vsx-swap-removal", cl::Hidden,
71 cl::desc("Disable VSX Swap Removal for PPC"));
72
73static cl::
74opt<bool> DisableMIPeephole("disable-ppc-peephole", cl::Hidden,
75 cl::desc("Disable machine peepholes for PPC"));
76
77static cl::opt<bool>
78EnableGEPOpt("ppc-gep-opt", cl::Hidden,
79 cl::desc("Enable optimizations on complex GEPs"),
80 cl::init(true));
81
82static cl::opt<bool>
83EnablePrefetch("enable-ppc-prefetching",
84 cl::desc("enable software prefetching on PPC"),
85 cl::init(false), cl::Hidden);
86
87static cl::opt<bool>
88EnableExtraTOCRegDeps("enable-ppc-extra-toc-reg-deps",
89 cl::desc("Add extra TOC register dependencies"),
90 cl::init(true), cl::Hidden);
91
92static cl::opt<bool>
93EnableMachineCombinerPass("ppc-machine-combiner",
94 cl::desc("Enable the machine combiner pass"),
95 cl::init(true), cl::Hidden);
96
97static cl::opt<bool>
98 ReduceCRLogical("ppc-reduce-cr-logicals",
99 cl::desc("Expand eligible cr-logical binary ops to branches"),
100 cl::init(true), cl::Hidden);
101
103 "enable-ppc-gen-scalar-mass", cl::init(false),
104 cl::desc("Enable lowering math functions to their corresponding MASS "
105 "(scalar) entries"),
106 cl::Hidden);
107
108static cl::opt<bool>
109 EnableGlobalMerge("ppc-global-merge", cl::Hidden, cl::init(false),
110 cl::desc("Enable the global merge pass"));
111
113 GlobalMergeMaxOffset("ppc-global-merge-max-offset", cl::Hidden,
114 cl::init(0x7fff),
115 cl::desc("Maximum global merge offset"));
116
152
154 const Triple &TT) {
155 std::string FullFS = std::string(FS);
156
157 // Make sure 64-bit features are available when CPUname is generic
158 if (TT.getArch() == Triple::ppc64 || TT.getArch() == Triple::ppc64le) {
159 if (!FullFS.empty())
160 FullFS = "+64bit," + FullFS;
161 else
162 FullFS = "+64bit";
163 }
164
165 if (OL >= CodeGenOptLevel::Default) {
166 if (!FullFS.empty())
167 FullFS = "+crbits," + FullFS;
168 else
169 FullFS = "+crbits";
170 }
171
172 if (OL != CodeGenOptLevel::None) {
173 if (!FullFS.empty())
174 FullFS = "+invariant-function-descriptors," + FullFS;
175 else
176 FullFS = "+invariant-function-descriptors";
177 }
178
179 if (TT.isOSAIX()) {
180 if (!FullFS.empty())
181 FullFS = "+aix," + FullFS;
182 else
183 FullFS = "+aix";
184 }
185
186 return FullFS;
187}
188
189static std::unique_ptr<TargetLoweringObjectFile> createTLOF(const Triple &TT) {
190 if (TT.isOSAIX())
191 return std::make_unique<TargetLoweringObjectFileXCOFF>();
192
193 return std::make_unique<PPC64LinuxTargetObjectFile>();
194}
195
197 const TargetOptions &Options) {
198 if (Options.MCOptions.getABIName().starts_with("elfv1"))
200 else if (Options.MCOptions.getABIName().starts_with("elfv2"))
202
203 assert(Options.MCOptions.getABIName().empty() &&
204 "Unknown target-abi option!");
205
206 switch (TT.getArch()) {
207 case Triple::ppc64le:
209 case Triple::ppc64:
210 if (TT.isPPC64ELFv2ABI())
212 else
214 default:
216 }
217}
218
220 std::optional<Reloc::Model> RM) {
221 if (TT.isOSAIX() && RM && *RM != Reloc::PIC_)
222 report_fatal_error("invalid relocation model, AIX only supports PIC",
223 false);
224
225 if (RM)
226 return *RM;
227
228 // Big Endian PPC and AIX default to PIC.
229 if (TT.getArch() == Triple::ppc64 || TT.isOSAIX())
230 return Reloc::PIC_;
231
232 // Rest are static by default.
233 return Reloc::Static;
234}
235
236static CodeModel::Model
237getEffectivePPCCodeModel(const Triple &TT, std::optional<CodeModel::Model> CM,
238 bool JIT) {
239 if (CM) {
240 if (*CM == CodeModel::Tiny)
241 report_fatal_error("Target does not support the tiny CodeModel", false);
242 if (*CM == CodeModel::Kernel)
243 report_fatal_error("Target does not support the kernel CodeModel", false);
244 return *CM;
245 }
246
247 if (JIT)
248 return CodeModel::Small;
249 if (TT.isOSAIX())
250 return CodeModel::Small;
251
252 assert(TT.isOSBinFormatELF() && "All remaining PPC OSes are ELF based.");
253
254 if (TT.isArch32Bit())
255 return CodeModel::Small;
256
257 assert(TT.isArch64Bit() && "Unsupported PPC architecture.");
258 return CodeModel::Medium;
259}
260
261
263 const PPCSubtarget &ST = C->MF->getSubtarget<PPCSubtarget>();
264 ScheduleDAGMILive *DAG = ST.usePPCPreRASchedStrategy()
267 // add DAG Mutations here.
268 if (ST.hasStoreFusion())
269 DAG->addMutation(createStoreClusterDAGMutation(DAG->TII, DAG->TRI));
270 if (ST.hasFusion())
271 DAG->addMutation(createPowerPCMacroFusionDAGMutation());
272
273 return DAG;
274}
275
276static ScheduleDAGInstrs *
278 const PPCSubtarget &ST = C->MF->getSubtarget<PPCSubtarget>();
279 ScheduleDAGMI *DAG = ST.usePPCPostRASchedStrategy()
282 // add DAG Mutations here.
283 if (ST.hasStoreFusion())
284 DAG->addMutation(createStoreClusterDAGMutation(DAG->TII, DAG->TRI));
285 if (ST.hasFusion())
286 DAG->addMutation(createPowerPCMacroFusionDAGMutation());
287 return DAG;
288}
289
290// The FeatureString here is a little subtle. We are modifying the feature
291// string with what are (currently) non-function specific overrides as it goes
292// into the CodeGenTargetMachineImpl constructor and then using the stored value
293// in the Subtarget constructor below it.
295 StringRef CPU, StringRef FS,
296 const TargetOptions &Options,
297 std::optional<Reloc::Model> RM,
298 std::optional<CodeModel::Model> CM,
299 CodeGenOptLevel OL, bool JIT)
301 TT.computeDataLayout(Options.MCOptions.ABIName),
302 TT, CPU, computeFSAdditions(FS, OL, TT), Options,
304 getEffectivePPCCodeModel(TT, CM, JIT), OL),
306 TargetABI(computeTargetABI(TT, Options)),
307 Endianness(TT.isLittleEndian() ? Endian::LITTLE : Endian::BIG) {
308 initAsmInfo();
309}
310
312
313const PPCSubtarget *
315 Attribute CPUAttr = F.getFnAttribute("target-cpu");
316 Attribute TuneAttr = F.getFnAttribute("tune-cpu");
317 Attribute FSAttr = F.getFnAttribute("target-features");
318
319 std::string CPU =
320 CPUAttr.isValid() ? CPUAttr.getValueAsString().str() : TargetCPU;
321 std::string TuneCPU =
322 TuneAttr.isValid() ? TuneAttr.getValueAsString().str() : CPU;
323 std::string FS =
324 FSAttr.isValid() ? FSAttr.getValueAsString().str() : TargetFS;
325
326 // FIXME: This is related to the code below to reset the target options,
327 // we need to know whether or not the soft float flag is set on the
328 // function before we can generate a subtarget. We also need to use
329 // it as a key for the subtarget since that can be the only difference
330 // between two functions.
331 bool SoftFloat = F.getFnAttribute("use-soft-float").getValueAsBool();
332 // If the soft float attribute is set on the function turn on the soft float
333 // subtarget feature.
334 if (SoftFloat)
335 FS += FS.empty() ? "-hard-float" : ",-hard-float";
336
337 auto &I = SubtargetMap[CPU + TuneCPU + FS];
338 if (!I) {
339 // This needs to be done before we create a new subtarget since any
340 // creation will depend on the TM and the code generation flags on the
341 // function that reside in TargetOptions.
343 I = std::make_unique<PPCSubtarget>(
344 TargetTriple, CPU, TuneCPU,
345 // FIXME: It would be good to have the subtarget additions here
346 // not necessary. Anything that turns them on/off (overrides) ends
347 // up being put at the end of the feature string, but the defaults
348 // shouldn't require adding them. Fixing this means pulling Feature64Bit
349 // out of most of the target cpus in the .td file and making it set only
350 // as part of initialization via the TargetTriple.
352 }
353 return I.get();
354}
355
360
365
366//===----------------------------------------------------------------------===//
367// Pass Pipeline Configuration
368//===----------------------------------------------------------------------===//
369
370namespace {
371
372/// PPC Code Generator Pass Configuration Options.
373class PPCPassConfig : public TargetPassConfig {
374public:
375 PPCPassConfig(PPCTargetMachine &TM, PassManagerBase &PM)
376 : TargetPassConfig(TM, PM) {
377 // At any optimization level above -O0 we use the Machine Scheduler and not
378 // the default Post RA List Scheduler.
380 substitutePass(&PostRASchedulerID, &PostMachineSchedulerID);
381 }
382
383 PPCTargetMachine &getPPCTargetMachine() const {
385 }
386
387 void addIRPasses() override;
388 bool addPreISel() override;
389 bool addILPOpts() override;
390 bool addInstSelector() override;
391 void addMachineSSAOptimization() override;
392 void addPreRegAlloc() override;
393 void addPreSched2() override;
394 void addPreEmitPass() override;
395 void addPreEmitPass2() override;
396 // GlobalISEL
397 bool addIRTranslator() override;
398 bool addLegalizeMachineIR() override;
399 bool addRegBankSelect() override;
400 bool addGlobalInstructionSelect() override;
401};
402
403} // end anonymous namespace
404
406 return new PPCPassConfig(*this, PM);
407}
408
409void PPCPassConfig::addIRPasses() {
410 if (TM->getOptLevel() != CodeGenOptLevel::None)
411 addPass(createPPCBoolRetToIntPass());
413
414 // Lower generic MASSV routines to PowerPC subtarget-specific entries.
416
417 // Generate PowerPC target-specific entries for scalar math functions
418 // that are available in IBM MASS (scalar) library.
419 if (TM->getOptLevel() == CodeGenOptLevel::Aggressive &&
421 TM->Options.PPCGenScalarMASSEntries = EnablePPCGenScalarMASSEntries;
423 }
424
425 // If explicitly requested, add explicit data prefetch intrinsics.
426 if (EnablePrefetch.getNumOccurrences() > 0)
428
429 if (TM->getOptLevel() >= CodeGenOptLevel::Default && EnableGEPOpt) {
430 // Call SeparateConstOffsetFromGEP pass to extract constants within indices
431 // and lower a GEP with multiple indices to either arithmetic operations or
432 // multiple GEPs with single index.
434 // Call EarlyCSE pass to find and remove subexpressions in the lowered
435 // result.
436 addPass(createEarlyCSEPass());
437 // Do loop invariant code motion in case part of the lowered result is
438 // invariant.
439 addPass(createLICMPass());
440 }
441
442 if (TM->getTargetTriple().isOSAIX())
444
446}
447
448bool PPCPassConfig::addPreISel() {
449 // The GlobalMerge pass is intended to be on by default on AIX.
450 // Specifying the command line option overrides the AIX default.
453 : getOptLevel() != CodeGenOptLevel::None)
454 addPass(createGlobalMergePass(TM, GlobalMergeMaxOffset, false, false, true,
455 true));
456
457 if (!DisableInstrFormPrep && getOptLevel() != CodeGenOptLevel::None)
458 addPass(createPPCLoopInstrFormPrepPass(getPPCTargetMachine()));
459
460 if (!DisableCTRLoops && getOptLevel() != CodeGenOptLevel::None)
462
463 return false;
464}
465
466bool PPCPassConfig::addILPOpts() {
467 addPass(&EarlyIfConverterLegacyID);
468
470 addPass(&MachineCombinerID);
471
472 return true;
473}
474
475bool PPCPassConfig::addInstSelector() {
476 // Install an instruction selector.
477 addPass(createPPCISelDag(getPPCTargetMachine(), getOptLevel()));
478
479#ifndef NDEBUG
480 if (!DisableCTRLoops && getOptLevel() != CodeGenOptLevel::None)
481 addPass(createPPCCTRLoopsVerify());
482#endif
483
484 addPass(createPPCVSXWACCCopyPass());
485 return false;
486}
487
488void PPCPassConfig::addMachineSSAOptimization() {
489 // Run CTR loops pass before any cfg modification pass to prevent the
490 // canonical form of hardware loop from being destroied.
491 if (!DisableCTRLoops && getOptLevel() != CodeGenOptLevel::None)
492 addPass(createPPCCTRLoopsPass());
493
494 // PPCBranchCoalescingPass need to be done before machine sinking
495 // since it merges empty blocks.
496 if (EnableBranchCoalescing && getOptLevel() != CodeGenOptLevel::None)
499 // For little endian, remove where possible the vector swap instructions
500 // introduced at code generation to normalize vector element order.
501 if (TM->getTargetTriple().getArch() == Triple::ppc64le &&
504 // Reduce the number of cr-logical ops.
505 if (ReduceCRLogical && getOptLevel() != CodeGenOptLevel::None)
507 // Target-specific peephole cleanups performed after instruction
508 // selection.
509 if (!DisableMIPeephole) {
510 addPass(createPPCMIPeepholePass());
512 }
513}
514
515void PPCPassConfig::addPreRegAlloc() {
516 if (getOptLevel() != CodeGenOptLevel::None) {
520 }
521
522 // FIXME: We probably don't need to run these for -fPIE.
523 if (getPPCTargetMachine().isPositionIndependent()) {
524 // FIXME: LiveVariables should not be necessary here!
525 // PPCTLSDynamicCallPass uses LiveIntervals which previously dependent on
526 // LiveVariables. This (unnecessary) dependency has been removed now,
527 // however a stage-2 clang build fails without LiveVariables computed here.
528 addPass(&LiveVariablesID);
530 }
532 addPass(createPPCTOCRegDepsPass());
533
534 if (getOptLevel() != CodeGenOptLevel::None)
535 addPass(&MachinePipelinerID);
536}
537
538void PPCPassConfig::addPreSched2() {
539 if (getOptLevel() != CodeGenOptLevel::None)
540 addPass(&IfConverterID);
541}
542
543void PPCPassConfig::addPreEmitPass() {
545
546 if (getOptLevel() != CodeGenOptLevel::None)
547 addPass(createPPCEarlyReturnPass());
548}
549
550void PPCPassConfig::addPreEmitPass2() {
551 // Schedule the expansion of AMOs at the last possible moment, avoiding the
552 // possibility for other passes to break the requirements for forward
553 // progress in the LL/SC block.
555 // Must run branch selection immediately preceding the asm printer.
557}
558
561 return TargetTransformInfo(std::make_unique<PPCTTIImpl>(this, F));
562}
563
565 assert(Endianness != Endian::NOT_DETECTED &&
566 "Unable to determine endianness");
567 return Endianness == Endian::LITTLE;
568}
569
575
578 "Run PowerPC PreRA specific scheduler",
580
583 "Run PowerPC PostRA specific scheduler",
585
586// Global ISEL
587bool PPCPassConfig::addIRTranslator() {
588 addPass(new IRTranslator());
589 return false;
590}
591
592bool PPCPassConfig::addLegalizeMachineIR() {
593 addPass(new Legalizer());
594 return false;
595}
596
597bool PPCPassConfig::addRegBankSelect() {
598 addPass(new RegBankSelect());
599 return false;
600}
601
602bool PPCPassConfig::addGlobalInstructionSelect() {
603 addPass(new InstructionSelect(getOptLevel()));
604 return false;
605}
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static cl::opt< bool > EnableGEPOpt("aarch64-enable-gep-opt", cl::Hidden, cl::desc("Enable optimizations on complex GEPs"), cl::init(false))
static std::unique_ptr< TargetLoweringObjectFile > createTLOF(const Triple &TT)
static Reloc::Model getEffectiveRelocModel()
This file contains the simple types necessary to represent the attributes associated with functions a...
static cl::opt< bool > DisableMIPeephole("disable-bpf-peephole", cl::Hidden, cl::desc("Disable machine peepholes for BPF"))
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
#define LLVM_ABI
Definition Compiler.h:213
#define LLVM_EXTERNAL_VISIBILITY
Definition Compiler.h:132
DXIL Legalizer
static cl::opt< unsigned > GlobalMergeMaxOffset("global-merge-max-offset", cl::Hidden, cl::desc("Set maximum offset for global merge pass"), cl::init(0))
static cl::opt< bool > EnableGlobalMerge("enable-global-merge", cl::Hidden, cl::desc("Enable the global merge pass"), cl::init(true))
This file declares the IRTranslator pass.
static LVOptions Options
Definition LVOptions.cpp:25
#define F(x, y, z)
Definition MD5.cpp:54
#define I(x, y, z)
Definition MD5.cpp:57
#define T
static cl::opt< bool > VSXFMAMutateEarly("schedule-ppc-vsx-fma-mutation-early", cl::Hidden, cl::desc("Schedule VSX FMA instruction mutation early"))
static cl::opt< bool > EnableMachineCombinerPass("ppc-machine-combiner", cl::desc("Enable the machine combiner pass"), cl::init(true), cl::Hidden)
static MachineSchedRegistry PPCPostRASchedRegistry("ppc-postra", "Run PowerPC PostRA specific scheduler", createPPCPostMachineScheduler)
static cl::opt< bool > DisableCTRLoops("disable-ppc-ctrloops", cl::Hidden, cl::desc("Disable CTR loops for PPC"))
static cl::opt< bool > DisableMIPeephole("disable-ppc-peephole", cl::Hidden, cl::desc("Disable machine peepholes for PPC"))
static cl::opt< bool > EnableExtraTOCRegDeps("enable-ppc-extra-toc-reg-deps", cl::desc("Add extra TOC register dependencies"), cl::init(true), cl::Hidden)
LLVM_ABI LLVM_EXTERNAL_VISIBILITY void LLVMInitializePowerPCTarget()
static PPCTargetMachine::PPCABI computeTargetABI(const Triple &TT, const TargetOptions &Options)
static cl::opt< bool > EnablePrefetch("enable-ppc-prefetching", cl::desc("enable software prefetching on PPC"), cl::init(false), cl::Hidden)
static cl::opt< bool > EnablePPCGenScalarMASSEntries("enable-ppc-gen-scalar-mass", cl::init(false), cl::desc("Enable lowering math functions to their corresponding MASS " "(scalar) entries"), cl::Hidden)
static cl::opt< bool > ReduceCRLogical("ppc-reduce-cr-logicals", cl::desc("Expand eligible cr-logical binary ops to branches"), cl::init(true), cl::Hidden)
static cl::opt< bool > EnableGEPOpt("ppc-gep-opt", cl::Hidden, cl::desc("Enable optimizations on complex GEPs"), cl::init(true))
static ScheduleDAGInstrs * createPPCPostMachineScheduler(MachineSchedContext *C)
static CodeModel::Model getEffectivePPCCodeModel(const Triple &TT, std::optional< CodeModel::Model > CM, bool JIT)
static cl::opt< bool > DisableInstrFormPrep("disable-ppc-instr-form-prep", cl::Hidden, cl::desc("Disable PPC loop instr form prep"))
static std::string computeFSAdditions(StringRef FS, CodeGenOptLevel OL, const Triple &TT)
static MachineSchedRegistry PPCPreRASchedRegistry("ppc-prera", "Run PowerPC PreRA specific scheduler", createPPCMachineScheduler)
static cl::opt< unsigned > GlobalMergeMaxOffset("ppc-global-merge-max-offset", cl::Hidden, cl::init(0x7fff), cl::desc("Maximum global merge offset"))
static cl::opt< bool > DisableVSXSwapRemoval("disable-ppc-vsx-swap-removal", cl::Hidden, cl::desc("Disable VSX Swap Removal for PPC"))
static cl::opt< bool > EnableBranchCoalescing("enable-ppc-branch-coalesce", cl::Hidden, cl::desc("enable coalescing of duplicate branches for PPC"))
static ScheduleDAGInstrs * createPPCMachineScheduler(MachineSchedContext *C)
static cl::opt< bool > EnableGlobalMerge("ppc-global-merge", cl::Hidden, cl::init(false), cl::desc("Enable the global merge pass"))
This file a TargetTransformInfoImplBase conforming object specific to the PPC target machine.
This file describes the interface of the MachineFunctionPass responsible for assigning the generic vi...
const GCNTargetMachine & getTM(const GCNSubtarget *STI)
Target-Independent Code Generator Pass Configuration Options pass.
This pass exposes codegen information to IR-level passes.
static std::unique_ptr< TargetLoweringObjectFile > createTLOF()
Functions, function parameters, and return types can have attributes to indicate how they should be t...
Definition Attributes.h:105
LLVM_ABI StringRef getValueAsString() const
Return the attribute's value as a string.
bool isValid() const
Return true if the attribute is any kind of attribute.
Definition Attributes.h:261
CodeGenTargetMachineImpl(const Target &T, StringRef DataLayoutString, const Triple &TT, StringRef CPU, StringRef FS, const TargetOptions &Options, Reloc::Model RM, CodeModel::Model CM, CodeGenOptLevel OL)
This pass is responsible for selecting generic machine instructions to target-specific instructions.
MachineSchedRegistry provides a selection of available machine instruction schedulers.
Common code between 32-bit and 64-bit PowerPC targets.
ScheduleDAGInstrs * createPostMachineScheduler(MachineSchedContext *C) const override
Similar to createMachineScheduler but used when postRA machine scheduling is enabled.
const PPCSubtarget * getSubtargetImpl() const =delete
~PPCTargetMachine() override
PPCTargetMachine(const Target &T, const Triple &TT, StringRef CPU, StringRef FS, const TargetOptions &Options, std::optional< Reloc::Model > RM, std::optional< CodeModel::Model > CM, CodeGenOptLevel OL, bool JIT)
TargetTransformInfo getTargetTransformInfo(const Function &F) const override
Get a TargetTransformInfo implementation for the target.
ScheduleDAGInstrs * createMachineScheduler(MachineSchedContext *C) const override
Create an instance of ScheduleDAGInstrs to be run within the standard MachineScheduler pass for this ...
TargetPassConfig * createPassConfig(PassManagerBase &PM) override
Create a pass configuration object to be used by addPassToEmitX methods for generating a pipeline of ...
MachineFunctionInfo * createMachineFunctionInfo(BumpPtrAllocator &Allocator, const Function &F, const TargetSubtargetInfo *STI) const override
Create the target's instance of MachineFunctionInfo.
PassRegistry - This class manages the registration and intitialization of the pass subsystem as appli...
static LLVM_ABI PassRegistry * getPassRegistry()
getPassRegistry - Access the global registry object, which is automatically initialized at applicatio...
This pass implements the reg bank selector pass used in the GlobalISel pipeline.
A ScheduleDAG for scheduling lists of MachineInstr.
ScheduleDAGMILive is an implementation of ScheduleDAGInstrs that schedules machine instructions while...
ScheduleDAGMI is an implementation of ScheduleDAGInstrs that simply schedules machine instructions ac...
StringRef - Represent a constant reference to a string, i.e.
Definition StringRef.h:55
std::string str() const
str - Get the contents as an std::string.
Definition StringRef.h:222
CodeGenOptLevel getOptLevel() const
Returns the optimization level: None, Less, Default, or Aggressive.
Triple TargetTriple
Triple string, CPU name, and target feature strings the TargetMachine instance is created with.
const Triple & getTargetTriple() const
std::unique_ptr< const MCSubtargetInfo > STI
TargetOptions Options
void resetTargetOptions(const Function &F) const
Reset the target options based on the function's attributes.
Target-Independent Code Generator Pass Configuration Options.
virtual void addIRPasses()
Add common target configurable passes that perform LLVM IR to IR transforms following machine indepen...
virtual void addMachineSSAOptimization()
addMachineSSAOptimization - Add standard passes that optimize machine instructions in SSA form.
TargetSubtargetInfo - Generic base class for all target subtargets.
This pass provides access to the codegen interfaces that are needed for IR-level transformations.
Target - Wrapper for Target specific information.
Triple - Helper class for working with autoconf configuration names.
Definition Triple.h:47
int getNumOccurrences() const
PassManagerBase - An abstract interface to allow code to add passes to a pass manager without having ...
@ C
The default llvm calling convention, compatible with C.
Definition CallingConv.h:34
template class LLVM_TEMPLATE_ABI opt< bool >
initializer< Ty > init(const Ty &Val)
This is an optimization pass for GlobalISel generic memory operations.
Definition Types.h:26
ScheduleDAGMILive * createSchedLive(MachineSchedContext *C)
Create the standard converging machine scheduler.
FunctionPass * createPPCPreEmitPeepholePass()
Target & getThePPC64LETarget()
void initializePPCTLSDynamicCallPass(PassRegistry &)
FunctionPass * createPPCLoopInstrFormPrepPass(PPCTargetMachine &TM)
void initializePPCVSXFMAMutatePass(PassRegistry &)
void initializePPCLowerMASSVEntriesPass(PassRegistry &)
LLVM_ABI Pass * createGlobalMergePass(const TargetMachine *TM, unsigned MaximalOffset, bool OnlyOptimizeForSize=false, bool MergeExternalByDefault=false, bool MergeConstantByDefault=false, bool MergeConstAggressiveByDefault=false)
GlobalMerge - This pass merges internal (by default) globals into structs to enable reuse of a base p...
LLVM_ABI char & PostRASchedulerID
PostRAScheduler - This pass performs post register allocation scheduling.
Target & getThePPC32Target()
FunctionPass * createPPCCTRLoopsPass()
LLVM_ABI char & MachineSchedulerID
MachineScheduler - This pass schedules machine instructions.
FunctionPass * createPPCTLSDynamicCallPass()
LLVM_ABI char & PostMachineSchedulerID
PostMachineScheduler - This pass schedules machine instructions postRA.
LLVM_ABI Pass * createLICMPass()
Definition LICM.cpp:386
FunctionPass * createPPCEarlyReturnPass()
void initializePPCPreEmitPeepholePass(PassRegistry &)
LLVM_ABI char & EarlyIfConverterLegacyID
EarlyIfConverter - This pass performs if-conversion on SSA form by inserting cmov instructions.
FunctionPass * createPPCExpandAtomicPseudoPass()
void initializePPCTOCRegDepsPass(PassRegistry &)
void initializePPCReduceCRLogicalsPass(PassRegistry &)
LLVM_ABI char & MachineCombinerID
This pass performs instruction combining using trace metrics to estimate critical-path and resource d...
static Reloc::Model getEffectiveRelocModel(std::optional< Reloc::Model > RM)
ModulePass * createPPCPrepareIFuncsOnAIXPass()
ScheduleDAGMI * createSchedPostRA(MachineSchedContext *C)
Create a generic scheduler with no vreg liveness or DAG mutation passes.
void initializePPCCTRLoopsVerifyPass(PassRegistry &)
FunctionPass * createPPCVSXSwapRemovalPass()
void initializePPCAIXAsmPrinterPass(PassRegistry &)
void initializePPCCTRLoopsPass(PassRegistry &)
ModulePass * createPPCLowerMASSVEntriesPass()
LLVM_ABI std::unique_ptr< ScheduleDAGMutation > createStoreClusterDAGMutation(const TargetInstrInfo *TII, const TargetRegisterInfo *TRI, bool ReorderWhileClustering=false)
If ReorderWhileClustering is set to true, no attempt will be made to reduce reordering due to store c...
LLVM_ABI FunctionPass * createLoopDataPrefetchPass()
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
Definition Error.cpp:163
void initializePPCDAGToDAGISelLegacyPass(PassRegistry &)
ModulePass * createPPCGenScalarMASSEntriesPass()
void initializePPCEarlyReturnPass(PassRegistry &)
CodeGenOptLevel
Code generation optimization level.
Definition CodeGen.h:82
@ Default
-O2, -Os, -Oz
Definition CodeGen.h:85
void initializePPCGenScalarMASSEntriesPass(PassRegistry &)
FunctionPass * createPPCReduceCRLogicalsPass()
FunctionPass * createPPCISelDag(PPCTargetMachine &TM, CodeGenOptLevel OL)
createPPCISelDag - This pass converts a legalized DAG into a PowerPC-specific DAG,...
void initializePPCExpandAtomicPseudoPass(PassRegistry &)
LLVM_ABI FunctionPass * createSeparateConstOffsetFromGEPPass(bool LowerGEP=false)
FunctionPass * createPPCBranchCoalescingPass()
createPPCBranchCoalescingPass - returns an instance of the Branch Coalescing Pass
Target & getThePPC64Target()
void initializePPCVSXWACCCopyPass(PassRegistry &)
void initializePPCLinuxAsmPrinterPass(PassRegistry &)
LLVM_ABI void initializeGlobalISel(PassRegistry &)
Initialize all passes linked into the GlobalISel library.
void initializePPCBSelPass(PassRegistry &)
LLVM_ABI char & MachinePipelinerID
This pass performs software pipelining on machine instructions.
FunctionPass * createPPCTOCRegDepsPass()
FunctionPass * createPPCCTRLoopsVerify()
void initializePPCBranchCoalescingPass(PassRegistry &)
void initializePPCBoolRetToIntPass(PassRegistry &)
void initializePPCMIPeepholePass(PassRegistry &)
std::unique_ptr< ScheduleDAGMutation > createPowerPCMacroFusionDAGMutation()
Note that you have to add: DAG.addMutation(createPowerPCMacroFusionDAGMutation()); to PPCTargetMachin...
void initializePPCVSXSwapRemovalPass(PassRegistry &)
LLVM_ABI char & LiveVariablesID
LiveVariables pass - This pass computes the set of blocks in which each variable is life and sets mac...
Target & getThePPC32LETarget()
char & PPCVSXFMAMutateID
LLVM_ABI char & IfConverterID
IfConverter - This pass performs machine code if conversion.
void initializePPCLoopInstrFormPrepPass(PassRegistry &)
FunctionPass * createPPCVSXWACCCopyPass()
LLVM_ABI char & TwoAddressInstructionPassID
TwoAddressInstruction - This pass reduces two-address instructions to use two operands.
LLVM_ABI FunctionPass * createAtomicExpandLegacyPass()
AtomicExpandPass - At IR level this pass replace atomic instructions with __atomic_* library calls,...
BumpPtrAllocatorImpl<> BumpPtrAllocator
The standard BumpPtrAllocator which just uses the default template parameters.
Definition Allocator.h:383
LLVM_ABI FunctionPass * createEarlyCSEPass(bool UseMemorySSA=false)
void initializePPCPrepareIFuncsOnAIXPass(PassRegistry &)
FunctionPass * createPPCBranchSelectionPass()
FunctionPass * createPPCBoolRetToIntPass()
LLVM_ABI char & DeadMachineInstructionElimID
DeadMachineInstructionElim - This pass removes dead machine instructions.
LLVM_ABI FunctionPass * createHardwareLoopsLegacyPass()
Create Hardware Loop pass.
FunctionPass * createPPCMIPeepholePass()
MachineFunctionInfo - This class can be derived from and used by targets to hold private target-speci...
static FuncInfoTy * create(BumpPtrAllocator &Allocator, const Function &F, const SubtargetTy *STI)
Factory function: default behavior is to call new using the supplied allocator.
MachineSchedContext provides enough context from the MachineScheduler pass for the target to instanti...
RegisterTargetMachine - Helper template for registering a target machine implementation,...