LLVM 22.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
151
153 const Triple &TT) {
154 std::string FullFS = std::string(FS);
155
156 // Make sure 64-bit features are available when CPUname is generic
157 if (TT.getArch() == Triple::ppc64 || TT.getArch() == Triple::ppc64le) {
158 if (!FullFS.empty())
159 FullFS = "+64bit," + FullFS;
160 else
161 FullFS = "+64bit";
162 }
163
164 if (OL >= CodeGenOptLevel::Default) {
165 if (!FullFS.empty())
166 FullFS = "+crbits," + FullFS;
167 else
168 FullFS = "+crbits";
169 }
170
171 if (OL != CodeGenOptLevel::None) {
172 if (!FullFS.empty())
173 FullFS = "+invariant-function-descriptors," + FullFS;
174 else
175 FullFS = "+invariant-function-descriptors";
176 }
177
178 if (TT.isOSAIX()) {
179 if (!FullFS.empty())
180 FullFS = "+aix," + FullFS;
181 else
182 FullFS = "+aix";
183 }
184
185 return FullFS;
186}
187
188static std::unique_ptr<TargetLoweringObjectFile> createTLOF(const Triple &TT) {
189 if (TT.isOSAIX())
190 return std::make_unique<TargetLoweringObjectFileXCOFF>();
191
192 return std::make_unique<PPC64LinuxTargetObjectFile>();
193}
194
196 const TargetOptions &Options) {
197 if (Options.MCOptions.getABIName().starts_with("elfv1"))
199 else if (Options.MCOptions.getABIName().starts_with("elfv2"))
201
202 assert(Options.MCOptions.getABIName().empty() &&
203 "Unknown target-abi option!");
204
205 switch (TT.getArch()) {
206 case Triple::ppc64le:
208 case Triple::ppc64:
209 if (TT.isPPC64ELFv2ABI())
211 else
213 default:
215 }
216}
217
219 std::optional<Reloc::Model> RM) {
220 if (TT.isOSAIX() && RM && *RM != Reloc::PIC_)
221 report_fatal_error("invalid relocation model, AIX only supports PIC",
222 false);
223
224 if (RM)
225 return *RM;
226
227 // Big Endian PPC and AIX default to PIC.
228 if (TT.getArch() == Triple::ppc64 || TT.isOSAIX())
229 return Reloc::PIC_;
230
231 // Rest are static by default.
232 return Reloc::Static;
233}
234
235static CodeModel::Model
236getEffectivePPCCodeModel(const Triple &TT, std::optional<CodeModel::Model> CM,
237 bool JIT) {
238 if (CM) {
239 if (*CM == CodeModel::Tiny)
240 report_fatal_error("Target does not support the tiny CodeModel", false);
241 if (*CM == CodeModel::Kernel)
242 report_fatal_error("Target does not support the kernel CodeModel", false);
243 return *CM;
244 }
245
246 if (JIT)
247 return CodeModel::Small;
248 if (TT.isOSAIX())
249 return CodeModel::Small;
250
251 assert(TT.isOSBinFormatELF() && "All remaining PPC OSes are ELF based.");
252
253 if (TT.isArch32Bit())
254 return CodeModel::Small;
255
256 assert(TT.isArch64Bit() && "Unsupported PPC architecture.");
257 return CodeModel::Medium;
258}
259
260
262 const PPCSubtarget &ST = C->MF->getSubtarget<PPCSubtarget>();
263 ScheduleDAGMILive *DAG = ST.usePPCPreRASchedStrategy()
266 // add DAG Mutations here.
267 if (ST.hasStoreFusion())
268 DAG->addMutation(createStoreClusterDAGMutation(DAG->TII, DAG->TRI));
269 if (ST.hasFusion())
270 DAG->addMutation(createPowerPCMacroFusionDAGMutation());
271
272 return DAG;
273}
274
275static ScheduleDAGInstrs *
277 const PPCSubtarget &ST = C->MF->getSubtarget<PPCSubtarget>();
278 ScheduleDAGMI *DAG = ST.usePPCPostRASchedStrategy()
281 // add DAG Mutations here.
282 if (ST.hasStoreFusion())
283 DAG->addMutation(createStoreClusterDAGMutation(DAG->TII, DAG->TRI));
284 if (ST.hasFusion())
285 DAG->addMutation(createPowerPCMacroFusionDAGMutation());
286 return DAG;
287}
288
289// The FeatureString here is a little subtle. We are modifying the feature
290// string with what are (currently) non-function specific overrides as it goes
291// into the CodeGenTargetMachineImpl constructor and then using the stored value
292// in the Subtarget constructor below it.
294 StringRef CPU, StringRef FS,
295 const TargetOptions &Options,
296 std::optional<Reloc::Model> RM,
297 std::optional<CodeModel::Model> CM,
298 CodeGenOptLevel OL, bool JIT)
299 : CodeGenTargetMachineImpl(T, TT.computeDataLayout(), TT, CPU,
300 computeFSAdditions(FS, OL, TT), Options,
302 getEffectivePPCCodeModel(TT, CM, JIT), OL),
304 TargetABI(computeTargetABI(TT, Options)),
305 Endianness(TT.isLittleEndian() ? Endian::LITTLE : Endian::BIG) {
306 initAsmInfo();
307}
308
310
311const PPCSubtarget *
313 Attribute CPUAttr = F.getFnAttribute("target-cpu");
314 Attribute TuneAttr = F.getFnAttribute("tune-cpu");
315 Attribute FSAttr = F.getFnAttribute("target-features");
316
317 std::string CPU =
318 CPUAttr.isValid() ? CPUAttr.getValueAsString().str() : TargetCPU;
319 std::string TuneCPU =
320 TuneAttr.isValid() ? TuneAttr.getValueAsString().str() : CPU;
321 std::string FS =
322 FSAttr.isValid() ? FSAttr.getValueAsString().str() : TargetFS;
323
324 // FIXME: This is related to the code below to reset the target options,
325 // we need to know whether or not the soft float flag is set on the
326 // function before we can generate a subtarget. We also need to use
327 // it as a key for the subtarget since that can be the only difference
328 // between two functions.
329 bool SoftFloat = F.getFnAttribute("use-soft-float").getValueAsBool();
330 // If the soft float attribute is set on the function turn on the soft float
331 // subtarget feature.
332 if (SoftFloat)
333 FS += FS.empty() ? "-hard-float" : ",-hard-float";
334
335 auto &I = SubtargetMap[CPU + TuneCPU + FS];
336 if (!I) {
337 // This needs to be done before we create a new subtarget since any
338 // creation will depend on the TM and the code generation flags on the
339 // function that reside in TargetOptions.
341 I = std::make_unique<PPCSubtarget>(
342 TargetTriple, CPU, TuneCPU,
343 // FIXME: It would be good to have the subtarget additions here
344 // not necessary. Anything that turns them on/off (overrides) ends
345 // up being put at the end of the feature string, but the defaults
346 // shouldn't require adding them. Fixing this means pulling Feature64Bit
347 // out of most of the target cpus in the .td file and making it set only
348 // as part of initialization via the TargetTriple.
350 }
351 return I.get();
352}
353
358
363
364//===----------------------------------------------------------------------===//
365// Pass Pipeline Configuration
366//===----------------------------------------------------------------------===//
367
368namespace {
369
370/// PPC Code Generator Pass Configuration Options.
371class PPCPassConfig : public TargetPassConfig {
372public:
373 PPCPassConfig(PPCTargetMachine &TM, PassManagerBase &PM)
374 : TargetPassConfig(TM, PM) {
375 // At any optimization level above -O0 we use the Machine Scheduler and not
376 // the default Post RA List Scheduler.
377 if (TM.getOptLevel() != CodeGenOptLevel::None)
378 substitutePass(&PostRASchedulerID, &PostMachineSchedulerID);
379 }
380
381 PPCTargetMachine &getPPCTargetMachine() const {
383 }
384
385 void addIRPasses() override;
386 bool addPreISel() override;
387 bool addILPOpts() override;
388 bool addInstSelector() override;
389 void addMachineSSAOptimization() override;
390 void addPreRegAlloc() override;
391 void addPreSched2() override;
392 void addPreEmitPass() override;
393 void addPreEmitPass2() override;
394 // GlobalISEL
395 bool addIRTranslator() override;
396 bool addLegalizeMachineIR() override;
397 bool addRegBankSelect() override;
398 bool addGlobalInstructionSelect() override;
399};
400
401} // end anonymous namespace
402
404 return new PPCPassConfig(*this, PM);
405}
406
407void PPCPassConfig::addIRPasses() {
408 if (TM->getOptLevel() != CodeGenOptLevel::None)
409 addPass(createPPCBoolRetToIntPass());
411
412 // Lower generic MASSV routines to PowerPC subtarget-specific entries.
414
415 // Generate PowerPC target-specific entries for scalar math functions
416 // that are available in IBM MASS (scalar) library.
417 if (TM->getOptLevel() == CodeGenOptLevel::Aggressive &&
419 TM->Options.PPCGenScalarMASSEntries = EnablePPCGenScalarMASSEntries;
421 }
422
423 // If explicitly requested, add explicit data prefetch intrinsics.
424 if (EnablePrefetch.getNumOccurrences() > 0)
426
427 if (TM->getOptLevel() >= CodeGenOptLevel::Default && EnableGEPOpt) {
428 // Call SeparateConstOffsetFromGEP pass to extract constants within indices
429 // and lower a GEP with multiple indices to either arithmetic operations or
430 // multiple GEPs with single index.
432 // Call EarlyCSE pass to find and remove subexpressions in the lowered
433 // result.
434 addPass(createEarlyCSEPass());
435 // Do loop invariant code motion in case part of the lowered result is
436 // invariant.
437 addPass(createLICMPass());
438 }
439
441}
442
443bool PPCPassConfig::addPreISel() {
444 // The GlobalMerge pass is intended to be on by default on AIX.
445 // Specifying the command line option overrides the AIX default.
448 : getOptLevel() != CodeGenOptLevel::None)
449 addPass(createGlobalMergePass(TM, GlobalMergeMaxOffset, false, false, true,
450 true));
451
452 if (!DisableInstrFormPrep && getOptLevel() != CodeGenOptLevel::None)
453 addPass(createPPCLoopInstrFormPrepPass(getPPCTargetMachine()));
454
455 if (!DisableCTRLoops && getOptLevel() != CodeGenOptLevel::None)
457
458 return false;
459}
460
461bool PPCPassConfig::addILPOpts() {
462 addPass(&EarlyIfConverterLegacyID);
463
465 addPass(&MachineCombinerID);
466
467 return true;
468}
469
470bool PPCPassConfig::addInstSelector() {
471 // Install an instruction selector.
472 addPass(createPPCISelDag(getPPCTargetMachine(), getOptLevel()));
473
474#ifndef NDEBUG
475 if (!DisableCTRLoops && getOptLevel() != CodeGenOptLevel::None)
476 addPass(createPPCCTRLoopsVerify());
477#endif
478
479 addPass(createPPCVSXWACCCopyPass());
480 return false;
481}
482
483void PPCPassConfig::addMachineSSAOptimization() {
484 // Run CTR loops pass before any cfg modification pass to prevent the
485 // canonical form of hardware loop from being destroied.
486 if (!DisableCTRLoops && getOptLevel() != CodeGenOptLevel::None)
487 addPass(createPPCCTRLoopsPass());
488
489 // PPCBranchCoalescingPass need to be done before machine sinking
490 // since it merges empty blocks.
491 if (EnableBranchCoalescing && getOptLevel() != CodeGenOptLevel::None)
494 // For little endian, remove where possible the vector swap instructions
495 // introduced at code generation to normalize vector element order.
496 if (TM->getTargetTriple().getArch() == Triple::ppc64le &&
499 // Reduce the number of cr-logical ops.
500 if (ReduceCRLogical && getOptLevel() != CodeGenOptLevel::None)
502 // Target-specific peephole cleanups performed after instruction
503 // selection.
504 if (!DisableMIPeephole) {
505 addPass(createPPCMIPeepholePass());
507 }
508}
509
510void PPCPassConfig::addPreRegAlloc() {
511 if (getOptLevel() != CodeGenOptLevel::None) {
515 }
516
517 // FIXME: We probably don't need to run these for -fPIE.
518 if (getPPCTargetMachine().isPositionIndependent()) {
519 // FIXME: LiveVariables should not be necessary here!
520 // PPCTLSDynamicCallPass uses LiveIntervals which previously dependent on
521 // LiveVariables. This (unnecessary) dependency has been removed now,
522 // however a stage-2 clang build fails without LiveVariables computed here.
523 addPass(&LiveVariablesID);
525 }
527 addPass(createPPCTOCRegDepsPass());
528
529 if (getOptLevel() != CodeGenOptLevel::None)
530 addPass(&MachinePipelinerID);
531}
532
533void PPCPassConfig::addPreSched2() {
534 if (getOptLevel() != CodeGenOptLevel::None)
535 addPass(&IfConverterID);
536}
537
538void PPCPassConfig::addPreEmitPass() {
540
541 if (getOptLevel() != CodeGenOptLevel::None)
542 addPass(createPPCEarlyReturnPass());
543}
544
545void PPCPassConfig::addPreEmitPass2() {
546 // Schedule the expansion of AMOs at the last possible moment, avoiding the
547 // possibility for other passes to break the requirements for forward
548 // progress in the LL/SC block.
550 // Must run branch selection immediately preceding the asm printer.
552}
553
556 return TargetTransformInfo(std::make_unique<PPCTTIImpl>(this, F));
557}
558
560 assert(Endianness != Endian::NOT_DETECTED &&
561 "Unable to determine endianness");
562 return Endianness == Endian::LITTLE;
563}
564
570
573 "Run PowerPC PreRA specific scheduler",
575
578 "Run PowerPC PostRA specific scheduler",
580
581// Global ISEL
582bool PPCPassConfig::addIRTranslator() {
583 addPass(new IRTranslator());
584 return false;
585}
586
587bool PPCPassConfig::addLegalizeMachineIR() {
588 addPass(new Legalizer());
589 return false;
590}
591
592bool PPCPassConfig::addRegBankSelect() {
593 addPass(new RegBankSelect());
594 return false;
595}
596
597bool PPCPassConfig::addGlobalInstructionSelect() {
598 addPass(new InstructionSelect(getOptLevel()));
599 return false;
600}
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)
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:55
#define I(x, y, z)
Definition MD5.cpp:58
#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:69
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:223
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:233
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.
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:384
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)
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:167
void initializePPCDAGToDAGISelLegacyPass(PassRegistry &)
ModulePass * createPPCGenScalarMASSEntriesPass()
BumpPtrAllocatorImpl BumpPtrAllocator
The standard BumpPtrAllocator which just uses the default template parameters.
Definition Allocator.h:383
void initializePPCEarlyReturnPass(PassRegistry &)
CodeGenOptLevel
Code generation optimization level.
Definition CodeGen.h:82
@ Default
-O2, -Os
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,...
LLVM_ABI FunctionPass * createEarlyCSEPass(bool UseMemorySSA=false)
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,...