• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1//===- MachinePassRegistry.def - Registry of passes -------------*- C++ -*-===//
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// This file is used as the registry of passes that are for target-independent
10// code generator.
11//
12//===----------------------------------------------------------------------===//
13
14// NOTE: NO INCLUDE GUARD DESIRED!
15
16#ifndef MODULE_ANALYSIS
17#define MODULE_ANALYSIS(NAME, CREATE_PASS)
18#endif
19MODULE_ANALYSIS("collector-metadata", CollectorMetadataAnalysis())
20MODULE_ANALYSIS("machine-module-info", MachineModuleAnalysis())
21MODULE_ANALYSIS("pass-instrumentation", PassInstrumentationAnalysis(PIC))
22#undef MODULE_ANALYSIS
23
24#ifndef MODULE_PASS
25#define MODULE_PASS(NAME, CREATE_PASS)
26#endif
27MODULE_PASS("global-merge", GlobalMergePass(TM, GlobalMergeOptions()))
28MODULE_PASS("jmc-instrumenter", JMCInstrumenterPass())
29MODULE_PASS("lower-emutls", LowerEmuTLSPass())
30MODULE_PASS("pre-isel-intrinsic-lowering", PreISelIntrinsicLoweringPass())
31MODULE_PASS("shadow-stack-gc-lowering", ShadowStackGCLoweringPass())
32#undef MODULE_PASS
33
34#ifndef FUNCTION_ANALYSIS
35#define FUNCTION_ANALYSIS(NAME, CREATE_PASS)
36#endif
37FUNCTION_ANALYSIS("gc-function", GCFunctionAnalysis())
38FUNCTION_ANALYSIS("pass-instrumentation", PassInstrumentationAnalysis(PIC))
39FUNCTION_ANALYSIS("ssp-layout", SSPLayoutAnalysis())
40FUNCTION_ANALYSIS("target-ir", TargetIRAnalysis(std::move(TM.getTargetIRAnalysis())))
41#undef FUNCTION_ANALYSIS
42
43#ifndef FUNCTION_PASS
44#define FUNCTION_PASS(NAME, CREATE_PASS)
45#endif
46FUNCTION_PASS("callbr-prepare", CallBrPreparePass())
47FUNCTION_PASS("cfguard", CFGuardPass())
48FUNCTION_PASS("codegenprepare", CodeGenPreparePass(TM))
49FUNCTION_PASS("consthoist", ConstantHoistingPass())
50FUNCTION_PASS("dwarf-eh-prepare", DwarfEHPreparePass(TM))
51FUNCTION_PASS("ee-instrument", EntryExitInstrumenterPass(false))
52FUNCTION_PASS("expand-large-div-rem", ExpandLargeDivRemPass(TM))
53FUNCTION_PASS("expand-large-fp-convert", ExpandLargeFpConvertPass(TM))
54FUNCTION_PASS("expand-memcmp", ExpandMemCmpPass(TM))
55FUNCTION_PASS("expand-reductions", ExpandReductionsPass())
56FUNCTION_PASS("gc-lowering", GCLoweringPass())
57FUNCTION_PASS("indirectbr-expand", IndirectBrExpandPass(TM))
58FUNCTION_PASS("interleaved-access", InterleavedAccessPass(TM))
59FUNCTION_PASS("interleaved-load-combine", InterleavedLoadCombinePass(TM))
60FUNCTION_PASS("lower-constant-intrinsics", LowerConstantIntrinsicsPass())
61FUNCTION_PASS("lower-invoke", LowerInvokePass())
62FUNCTION_PASS("mergeicmps", MergeICmpsPass())
63FUNCTION_PASS("partially-inline-libcalls", PartiallyInlineLibCallsPass())
64FUNCTION_PASS("post-inline-ee-instrument", EntryExitInstrumenterPass(true))
65FUNCTION_PASS("replace-with-veclib", ReplaceWithVeclib())
66FUNCTION_PASS("safe-stack", SafeStackPass(TM))
67FUNCTION_PASS("scalarize-masked-mem-intrin", ScalarizeMaskedMemIntrinPass())
68FUNCTION_PASS("select-optimize", SelectOptimizePass(TM))
69FUNCTION_PASS("sjlj-eh-prepare", SjLjEHPreparePass(TM))
70FUNCTION_PASS("stack-protector", StackProtectorPass(TM))
71FUNCTION_PASS("tlshoist", TLSVariableHoistPass())
72FUNCTION_PASS("unreachableblockelim", UnreachableBlockElimPass())
73FUNCTION_PASS("verify", VerifierPass())
74FUNCTION_PASS("wasm-eh-prepare", WasmEHPreparePass())
75FUNCTION_PASS("win-eh-prepare", WinEHPreparePass())
76#undef FUNCTION_PASS
77
78#ifndef LOOP_PASS
79#define LOOP_PASS(NAME, CREATE_PASS)
80#endif
81LOOP_PASS("loop-reduce", LoopStrengthReducePass())
82LOOP_PASS("loop-term-fold", LoopTermFoldPass())
83#undef LOOP_PASS
84
85#ifndef MACHINE_MODULE_PASS
86#define MACHINE_MODULE_PASS(NAME, CREATE_PASS)
87#endif
88#undef MACHINE_MODULE_PASS
89
90#ifndef MACHINE_FUNCTION_ANALYSIS
91#define MACHINE_FUNCTION_ANALYSIS(NAME, CREATE_PASS)
92#endif
93// LiveVariables currently requires pure SSA form.
94// FIXME: Once TwoAddressInstruction pass no longer uses kill flags,
95// LiveVariables can be removed completely, and LiveIntervals can be directly
96// computed. (We still either need to regenerate kill flags after regalloc, or
97// preferably fix the scavenger to not depend on them).
98MACHINE_FUNCTION_ANALYSIS("live-intervals", LiveIntervalsAnalysis())
99MACHINE_FUNCTION_ANALYSIS("live-vars", LiveVariablesAnalysis())
100MACHINE_FUNCTION_ANALYSIS("machine-block-freq", MachineBlockFrequencyAnalysis())
101MACHINE_FUNCTION_ANALYSIS("machine-branch-prob",
102                          MachineBranchProbabilityAnalysis())
103MACHINE_FUNCTION_ANALYSIS("machine-dom-tree", MachineDominatorTreeAnalysis())
104MACHINE_FUNCTION_ANALYSIS("machine-loops", MachineLoopAnalysis())
105MACHINE_FUNCTION_ANALYSIS("machine-opt-remark-emitter",
106                          MachineOptimizationRemarkEmitterAnalysis())
107MACHINE_FUNCTION_ANALYSIS("machine-post-dom-tree",
108                          MachinePostDominatorTreeAnalysis())
109MACHINE_FUNCTION_ANALYSIS("pass-instrumentation", PassInstrumentationAnalysis(PIC))
110MACHINE_FUNCTION_ANALYSIS("slot-indexes", SlotIndexesAnalysis())
111// MACHINE_FUNCTION_ANALYSIS("live-stacks", LiveStacksPass())
112// MACHINE_FUNCTION_ANALYSIS("edge-bundles", EdgeBundlesAnalysis())
113// MACHINE_FUNCTION_ANALYSIS("lazy-machine-bfi",
114// LazyMachineBlockFrequencyInfoAnalysis())
115// MACHINE_FUNCTION_ANALYSIS("machine-loops", MachineLoopInfoAnalysis())
116// MACHINE_FUNCTION_ANALYSIS("machine-dom-frontier",
117// MachineDominanceFrontierAnalysis())
118// MACHINE_FUNCTION_ANALYSIS("machine-post-dom-tree",
119// MachinePostDominatorTreeAnalysis())
120// MACHINE_FUNCTION_ANALYSIS("machine-region-info",
121// MachineRegionInfoPassAnalysis())
122// MACHINE_FUNCTION_ANALYSIS("machine-trace-metrics",
123// MachineTraceMetricsAnalysis()) MACHINE_FUNCTION_ANALYSIS("reaching-def",
124// ReachingDefAnalysisAnalysis()) MACHINE_FUNCTION_ANALYSIS("live-reg-matrix",
125// LiveRegMatrixAnalysis()) MACHINE_FUNCTION_ANALYSIS("gc-analysis",
126// GCMachineCodeAnalysisPass())
127#undef MACHINE_FUNCTION_ANALYSIS
128
129#ifndef MACHINE_FUNCTION_PASS
130#define MACHINE_FUNCTION_PASS(NAME, CREATE_PASS)
131#endif
132MACHINE_FUNCTION_PASS("dead-mi-elimination", DeadMachineInstructionElimPass())
133MACHINE_FUNCTION_PASS("finalize-isel", FinalizeISelPass())
134MACHINE_FUNCTION_PASS("localstackalloc", LocalStackSlotAllocationPass())
135MACHINE_FUNCTION_PASS("no-op-machine-function", NoOpMachineFunctionPass())
136MACHINE_FUNCTION_PASS("phi-node-elimination", PHIEliminationPass())
137MACHINE_FUNCTION_PASS("print", PrintMIRPass())
138MACHINE_FUNCTION_PASS("print<live-intervals>", LiveIntervalsPrinterPass(dbgs()))
139MACHINE_FUNCTION_PASS("print<live-vars>", LiveVariablesPrinterPass(dbgs()))
140MACHINE_FUNCTION_PASS("print<machine-block-freq>",
141                      MachineBlockFrequencyPrinterPass(dbgs()))
142MACHINE_FUNCTION_PASS("print<machine-branch-prob>",
143                      MachineBranchProbabilityPrinterPass(dbgs()))
144MACHINE_FUNCTION_PASS("print<machine-dom-tree>",
145                      MachineDominatorTreePrinterPass(dbgs()))
146MACHINE_FUNCTION_PASS("print<machine-loops>", MachineLoopPrinterPass(dbgs()))
147MACHINE_FUNCTION_PASS("print<machine-post-dom-tree>",
148                      MachinePostDominatorTreePrinterPass(dbgs()))
149MACHINE_FUNCTION_PASS("print<slot-indexes>", SlotIndexesPrinterPass(dbgs()))
150MACHINE_FUNCTION_PASS("require-all-machine-function-properties",
151                      RequireAllMachineFunctionPropertiesPass())
152MACHINE_FUNCTION_PASS("trigger-verifier-error", TriggerVerifierErrorPass())
153MACHINE_FUNCTION_PASS("two-address-instruction", TwoAddressInstructionPass())
154MACHINE_FUNCTION_PASS("verify", MachineVerifierPass())
155#undef MACHINE_FUNCTION_PASS
156
157#ifndef MACHINE_FUNCTION_PASS_WITH_PARAMS
158#define MACHINE_FUNCTION_PASS_WITH_PARAMS(NAME, CLASS, CREATE_PASS, PARSER,    \
159                                          PARAMS)
160#endif
161MACHINE_FUNCTION_PASS_WITH_PARAMS(
162    "regallocfast", "RegAllocFast",
163    [](RegAllocFastPassOptions Opts) { return RegAllocFastPass(Opts); },
164    [PB = this](StringRef Params) {
165      return parseRegAllocFastPassOptions(*PB, Params);
166    },
167    "filter=reg-filter;no-clear-vregs")
168#undef MACHINE_FUNCTION_PASS_WITH_PARAMS
169
170// After a pass is converted to new pass manager, its entry should be moved from
171// dummy table to the normal one. For example, for a machine function pass,
172// DUMMY_MACHINE_FUNCTION_PASS to MACHINE_FUNCTION_PASS.
173
174#ifndef DUMMY_FUNCTION_PASS
175#define DUMMY_FUNCTION_PASS(NAME, PASS_NAME)
176#endif
177DUMMY_FUNCTION_PASS("atomic-expand", AtomicExpandPass)
178#undef DUMMY_FUNCTION_PASS
179
180#ifndef DUMMY_MACHINE_MODULE_PASS
181#define DUMMY_MACHINE_MODULE_PASS(NAME, PASS_NAME)
182#endif
183DUMMY_MACHINE_MODULE_PASS("machine-outliner", MachineOutlinerPass)
184DUMMY_MACHINE_MODULE_PASS("pseudo-probe-inserter", PseudoProbeInserterPass)
185DUMMY_MACHINE_MODULE_PASS("mir-debugify", DebugifyMachineModule)
186DUMMY_MACHINE_MODULE_PASS("mir-check-debugify", CheckDebugMachineModulePass)
187DUMMY_MACHINE_MODULE_PASS("mir-strip-debug", StripDebugMachineModulePass)
188#undef DUMMY_MACHINE_MODULE_PASS
189
190#ifndef DUMMY_MACHINE_FUNCTION_PASS
191#define DUMMY_MACHINE_FUNCTION_PASS(NAME, PASS_NAME)
192#endif
193DUMMY_MACHINE_FUNCTION_PASS("bbsections-prepare", BasicBlockSectionsPass)
194DUMMY_MACHINE_FUNCTION_PASS("bbsections-profile-reader", BasicBlockSectionsProfileReaderPass)
195DUMMY_MACHINE_FUNCTION_PASS("block-placement", MachineBlockPlacementPass)
196DUMMY_MACHINE_FUNCTION_PASS("block-placement-stats", MachineBlockPlacementStatsPass)
197DUMMY_MACHINE_FUNCTION_PASS("branch-folder", BranchFolderPass)
198DUMMY_MACHINE_FUNCTION_PASS("break-false-deps", BreakFalseDepsPass)
199DUMMY_MACHINE_FUNCTION_PASS("cfguard-longjmp", CFGuardLongjmpPass)
200DUMMY_MACHINE_FUNCTION_PASS("cfi-fixup", CFIFixupPass)
201DUMMY_MACHINE_FUNCTION_PASS("cfi-instr-inserter", CFIInstrInserterPass)
202DUMMY_MACHINE_FUNCTION_PASS("detect-dead-lanes", DetectDeadLanesPass)
203DUMMY_MACHINE_FUNCTION_PASS("dot-machine-cfg", MachineCFGPrinter)
204DUMMY_MACHINE_FUNCTION_PASS("early-ifcvt", EarlyIfConverterPass)
205DUMMY_MACHINE_FUNCTION_PASS("early-machinelicm", EarlyMachineLICMPass)
206DUMMY_MACHINE_FUNCTION_PASS("early-tailduplication", EarlyTailDuplicatePass)
207DUMMY_MACHINE_FUNCTION_PASS("fentry-insert", FEntryInserterPass)
208DUMMY_MACHINE_FUNCTION_PASS("fixup-statepoint-caller-saved", FixupStatepointCallerSavedPass)
209DUMMY_MACHINE_FUNCTION_PASS("fs-profile-loader", MIRProfileLoaderNewPass)
210DUMMY_MACHINE_FUNCTION_PASS("funclet-layout", FuncletLayoutPass)
211DUMMY_MACHINE_FUNCTION_PASS("gc-empty-basic-blocks", GCEmptyBasicBlocksPass)
212DUMMY_MACHINE_FUNCTION_PASS("implicit-null-checks", ImplicitNullChecksPass)
213DUMMY_MACHINE_FUNCTION_PASS("init-undef-pass", InitUndefPass)
214DUMMY_MACHINE_FUNCTION_PASS("instruction-select", InstructionSelectPass)
215DUMMY_MACHINE_FUNCTION_PASS("irtranslator", IRTranslatorPass)
216DUMMY_MACHINE_FUNCTION_PASS("kcfi", MachineKCFIPass)
217DUMMY_MACHINE_FUNCTION_PASS("legalizer", LegalizerPass)
218DUMMY_MACHINE_FUNCTION_PASS("livedebugvalues", LiveDebugValuesPass)
219DUMMY_MACHINE_FUNCTION_PASS("lrshrink", LiveRangeShrinkPass)
220DUMMY_MACHINE_FUNCTION_PASS("machine-combiner", MachineCombinerPass)
221DUMMY_MACHINE_FUNCTION_PASS("machine-cp", MachineCopyPropagationPass)
222DUMMY_MACHINE_FUNCTION_PASS("machine-cse", MachineCSEPass)
223DUMMY_MACHINE_FUNCTION_PASS("machine-function-splitter", MachineFunctionSplitterPass)
224DUMMY_MACHINE_FUNCTION_PASS("machine-latecleanup", MachineLateInstrsCleanupPass)
225DUMMY_MACHINE_FUNCTION_PASS("machine-sanmd", MachineSanitizerBinaryMetadata)
226DUMMY_MACHINE_FUNCTION_PASS("machine-scheduler", MachineSchedulerPass)
227DUMMY_MACHINE_FUNCTION_PASS("machine-sink", MachineSinkingPass)
228DUMMY_MACHINE_FUNCTION_PASS("machine-uniformity", MachineUniformityInfoWrapperPass)
229DUMMY_MACHINE_FUNCTION_PASS("machineinstr-printer", MachineFunctionPrinterPass)
230DUMMY_MACHINE_FUNCTION_PASS("machinelicm", MachineLICMPass)
231DUMMY_MACHINE_FUNCTION_PASS("machineverifier", MachineVerifierPass)
232DUMMY_MACHINE_FUNCTION_PASS("mirfs-discriminators", MIRAddFSDiscriminatorsPass)
233DUMMY_MACHINE_FUNCTION_PASS("opt-phis", OptimizePHIsPass)
234DUMMY_MACHINE_FUNCTION_PASS("patchable-function", PatchableFunctionPass)
235DUMMY_MACHINE_FUNCTION_PASS("peephole-opt", PeepholeOptimizerPass)
236DUMMY_MACHINE_FUNCTION_PASS("post-RA-sched", PostRASchedulerPass)
237DUMMY_MACHINE_FUNCTION_PASS("postmisched", PostMachineSchedulerPass)
238DUMMY_MACHINE_FUNCTION_PASS("postra-machine-sink", PostRAMachineSinkingPass)
239DUMMY_MACHINE_FUNCTION_PASS("postrapseudos", ExpandPostRAPseudosPass)
240DUMMY_MACHINE_FUNCTION_PASS("print-machine-cycles", MachineCycleInfoPrinterPass)
241DUMMY_MACHINE_FUNCTION_PASS("print-machine-uniformity", MachineUniformityInfoPrinterPass)
242DUMMY_MACHINE_FUNCTION_PASS("processimpdefs", ProcessImplicitDefsPass)
243DUMMY_MACHINE_FUNCTION_PASS("prologepilog", PrologEpilogInserterPass)
244DUMMY_MACHINE_FUNCTION_PASS("prologepilog-code", PrologEpilogCodeInserterPass)
245DUMMY_MACHINE_FUNCTION_PASS("ra-basic", RABasicPass)
246DUMMY_MACHINE_FUNCTION_PASS("ra-greedy", RAGreedyPass)
247DUMMY_MACHINE_FUNCTION_PASS("ra-pbqp", RAPBQPPass)
248DUMMY_MACHINE_FUNCTION_PASS("reg-usage-collector", RegUsageInfoCollectorPass)
249DUMMY_MACHINE_FUNCTION_PASS("reg-usage-propagation", RegUsageInfoPropagationPass)
250DUMMY_MACHINE_FUNCTION_PASS("regalloc", RegAllocPass)
251DUMMY_MACHINE_FUNCTION_PASS("regallocscoringpass", RegAllocScoringPass)
252DUMMY_MACHINE_FUNCTION_PASS("regbankselect", RegBankSelectPass)
253DUMMY_MACHINE_FUNCTION_PASS("removeredundantdebugvalues", RemoveRedundantDebugValuesPass)
254DUMMY_MACHINE_FUNCTION_PASS("rename-independent-subregs", RenameIndependentSubregsPass)
255DUMMY_MACHINE_FUNCTION_PASS("reset-machine-function", ResetMachineFunctionPass)
256DUMMY_MACHINE_FUNCTION_PASS("shrink-wrap", ShrinkWrapPass)
257DUMMY_MACHINE_FUNCTION_PASS("simple-register-coalescing", RegisterCoalescerPass)
258DUMMY_MACHINE_FUNCTION_PASS("stack-coloring", StackColoringPass)
259DUMMY_MACHINE_FUNCTION_PASS("stack-frame-layout", StackFrameLayoutAnalysisPass)
260DUMMY_MACHINE_FUNCTION_PASS("stack-slot-coloring", StackSlotColoringPass)
261DUMMY_MACHINE_FUNCTION_PASS("stackmap-liveness", StackMapLivenessPass)
262DUMMY_MACHINE_FUNCTION_PASS("tailduplication", TailDuplicatePass)
263DUMMY_MACHINE_FUNCTION_PASS("unpack-mi-bundles", UnpackMachineBundlesPass)
264DUMMY_MACHINE_FUNCTION_PASS("virtregrewriter", VirtRegRewriterPass)
265DUMMY_MACHINE_FUNCTION_PASS("xray-instrumentation", XRayInstrumentationPass)
266#undef DUMMY_MACHINE_FUNCTION_PASS
267