35class X86CodeGenPassBuilder
37 using Base = CodeGenPassBuilder<X86CodeGenPassBuilder, X86TargetMachine>;
40 explicit X86CodeGenPassBuilder(X86TargetMachine &TM,
41 const CGPassBuilderOption &Opts,
42 PassInstrumentationCallbacks *
PIC)
43 : CodeGenPassBuilder(TM, Opts,
PIC) {}
45 void addIRPasses(PassManagerWrapper &PMW)
const;
46 void addPreISel(PassManagerWrapper &PMW)
const;
47 Error addInstSelector(PassManagerWrapper &PMW)
const;
48 void addILPOpts(PassManagerWrapper &PMW)
const;
49 void addPreRegBankSelect(PassManagerWrapper &PMW)
const;
50 void addMachineSSAOptimization(PassManagerWrapper &PMW)
const;
51 void addPreRegAlloc(PassManagerWrapper &PMW)
const;
54 void addPostRegAlloc(PassManagerWrapper &PMW)
const;
55 void addPreSched2(PassManagerWrapper &PMW)
const;
56 void addPreEmitPass(PassManagerWrapper &PMW)
const;
57 void addPreEmitPass2(PassManagerWrapper &PMW)
const;
60 void addAsmPrinterBegin(PassManagerWrapper &PMW)
const;
61 void addAsmPrinter(PassManagerWrapper &PMW)
const;
62 void addAsmPrinterEnd(PassManagerWrapper &PMW)
const;
66 addFunctionPass(AtomicExpandPass(TM), PMW);
70 addFunctionPass(X86LowerAMXIntrinsicsPass(&TM), PMW);
71 addFunctionPass(X86LowerAMXTypePass(&TM), PMW);
73 Base::addIRPasses(PMW);
75 if (getOptLevel() != CodeGenOptLevel::None) {
76 addFunctionPass(InterleavedAccessPass(TM), PMW);
77 addFunctionPass(X86PartialReductionPass(&TM), PMW);
83 addFunctionPass(IndirectBrExpandPass(TM), PMW);
86 const Triple &
TT = TM.getTargetTriple();
88 addFunctionPass(CFGuardPass(
TT.isX86_64() ? CFGuardPass::Mechanism::Dispatch
89 : CFGuardPass::Mechanism::Check),
92 if (TM.Options.JMCInstrument) {
94 addModulePass(JMCInstrumenterPass(), PMW);
98void X86CodeGenPassBuilder::addPreISel(PassManagerWrapper &PMW)
const {
100 const Triple &
TT = TM.getTargetTriple();
101 if (
TT.isOSWindows() &&
TT.isX86_32()) {
103 addModulePass(X86WinEHStatePass(), PMW);
107Error X86CodeGenPassBuilder::addInstSelector(PassManagerWrapper &PMW)
const {
108 addMachineFunctionPass(X86ISelDAGToDAGPass(TM), PMW);
111 if (TM.getTargetTriple().isOSBinFormatELF() &&
112 getOptLevel() != CodeGenOptLevel::None) {
113 addMachineFunctionPass(X86CleanupLocalDynamicTLSPass(), PMW);
116 addMachineFunctionPass(X86GlobalBaseRegPass(), PMW);
117 addMachineFunctionPass(X86ArgumentStackSlotPass(), PMW);
121void X86CodeGenPassBuilder::addILPOpts(PassManagerWrapper &PMW)
const {
122 addMachineFunctionPass(EarlyIfConverterPass(), PMW);
127 addMachineFunctionPass(X86CmovConversionPass(), PMW);
130void X86CodeGenPassBuilder::addPreRegBankSelect(PassManagerWrapper &PMW)
const {
131 addMachineFunctionPass(X86PostLegalizerCombinerPass(), PMW);
134void X86CodeGenPassBuilder::addMachineSSAOptimization(
135 PassManagerWrapper &PMW)
const {
136 addMachineFunctionPass(X86DomainReassignmentPass(), PMW);
137 Base::addMachineSSAOptimization(PMW);
140void X86CodeGenPassBuilder::addPreRegAlloc(PassManagerWrapper &PMW)
const {
141 if (getOptLevel() != CodeGenOptLevel::None) {
142 addMachineFunctionPass(LiveRangeShrinkPass(), PMW);
143 addMachineFunctionPass(X86FixupSetCCPass(), PMW);
144 addMachineFunctionPass(X86CallFrameOptimizationPass(), PMW);
145 addMachineFunctionPass(X86AvoidStoreForwardingBlocksPass(), PMW);
148 addMachineFunctionPass(X86SuppressAPXForRelocationPass(), PMW);
149 addMachineFunctionPass(X86SpeculativeLoadHardeningPass(), PMW);
150 addMachineFunctionPass(X86FlagsCopyLoweringPass(), PMW);
151 addMachineFunctionPass(X86DynAllocaExpanderPass(), PMW);
153 if (getOptLevel() != CodeGenOptLevel::None)
154 addMachineFunctionPass(X86PreTileConfigPass(), PMW);
156 addMachineFunctionPass(X86FastPreTileConfigPass(), PMW);
159void X86CodeGenPassBuilder::addPostRegAlloc(PassManagerWrapper &PMW)
const {
160 addMachineFunctionPass(X86LowerTileCopyPass(), PMW);
161 addMachineFunctionPass(X86FPStackifierPass(), PMW);
166 if (getOptLevel() != CodeGenOptLevel::None) {
167 addMachineFunctionPass(X86LoadValueInjectionLoadHardeningPass(), PMW);
171void X86CodeGenPassBuilder::addPreSched2(PassManagerWrapper &PMW)
const {
172 addMachineFunctionPass(X86ExpandPseudoPass(), PMW);
176void X86CodeGenPassBuilder::addPreEmitPass(PassManagerWrapper &PMW)
const {
177 if (getOptLevel() != CodeGenOptLevel::None) {
180 addMachineFunctionPass(BreakFalseDepsPass(), PMW);
183 addMachineFunctionPass(X86IndirectBranchTrackingPass(), PMW);
187 if (getOptLevel() != CodeGenOptLevel::None) {
188 addMachineFunctionPass(X86FixupBWInstsPass(), PMW);
191 addMachineFunctionPass(X86FixupLEAsPass(), PMW);
192 addMachineFunctionPass(X86FixupInstTuningPass(), PMW);
193 addMachineFunctionPass(X86FixupVectorConstantsPass(), PMW);
195 addMachineFunctionPass(X86CompressEVEXPass(), PMW);
196 addMachineFunctionPass(X86InsertX87WaitPass(), PMW);
199void X86CodeGenPassBuilder::addPreEmitPass2(PassManagerWrapper &PMW)
const {
200 const Triple &
TT = TM.getTargetTriple();
201 const MCAsmInfo *MAI = TM.getMCAsmInfo();
212 addMachineFunctionPass(X86SpeculativeExecutionSideEffectSuppressionPass(),
216 addMachineFunctionPass(X86ReturnThunksPass(), PMW);
220 if (
TT.isOSWindows() &&
TT.isX86_64())
221 addMachineFunctionPass(X86AvoidTrailingCallPass(), PMW);
226 if (!
TT.isOSDarwin() &&
227 (!
TT.isOSWindows() ||
233 if (
TT.isOSWindows()) {
242 addMachineFunctionPass(X86LoadValueInjectionRetHardeningPass(), PMW);
255 if (
TT.isOSWindows() &&
TT.isX86_64()) {
256 addMachineFunctionPass(X86WinEHUnwindV2Pass(), PMW);
260void X86CodeGenPassBuilder::addAsmPrinterBegin(PassManagerWrapper &PMW)
const {
261 addModulePass(X86AsmPrinterBeginPass(), PMW,
true);
264void X86CodeGenPassBuilder::addAsmPrinter(PassManagerWrapper &PMW)
const {
265 addMachineFunctionPass(X86AsmPrinterPass(), PMW);
268void X86CodeGenPassBuilder::addAsmPrinterEnd(PassManagerWrapper &PMW)
const {
269 addModulePass(X86AsmPrinterEndPass(), PMW,
true);
275#define GET_PASS_REGISTRY "X86PassRegistry.def"
281 "x86-asm-printer-begin");
284 "x86-asm-printer-end");
293 auto CGPB = X86CodeGenPassBuilder(*
this, Opt,
PIC);
294 return CGPB.buildPipeline(MPM,
MAM, Out, DwoOut, FileType, Ctx);
Interfaces for producing common pass manager configurations.
This file contains the declaration of the InterleavedAccessPass class, its corresponding pass name is...
ModuleAnalysisManager MAM
PassInstrumentationCallbacks PIC
PassBuilder PB(Machine, PassOpts->PTO, std::nullopt, &PIC)
cl::opt< bool > X86EnableMachineCombinerPass
This class provides access to building LLVM's passes.
Lightweight error class with error context and mandatory checking.
static ErrorSuccess success()
Create a success value.
ExceptionHandling getExceptionHandlingType() const
Context object for machine code objects.
This class provides access to building LLVM's passes.
This class manages callbacks registration, as well as provides a way for PassInstrumentation to pass ...
void registerPassBuilderCallbacks(PassBuilder &PB) override
Allow the target to modify the pass pipeline.
Error buildCodeGenPipeline(ModulePassManager &MPM, ModuleAnalysisManager &MAM, raw_pwrite_stream &Out, raw_pwrite_stream *DwoOut, CodeGenFileType FileType, const CGPassBuilderOption &Opt, MCContext &Ctx, PassInstrumentationCallbacks *PIC) override
An abstract base class for streams implementations that also support a pwrite operation.
Interfaces for registering analysis passes, producing common pass manager configurations,...
This is an optimization pass for GlobalISel generic memory operations.
CodeGenFileType
These enums are meant to be passed into addPassesToEmitFile to indicate what type of file to emit,...
PassManager< Module > ModulePassManager
Convenience typedef for a pass manager over modules.
AnalysisManager< Module > ModuleAnalysisManager
Convenience typedef for the Module analysis manager.