1//===- AMDGPUPassRegistry.def - Registry of AMDGPU 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 part of the
10// AMDGPU backend.
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("amdgpu-argument-usage", AMDGPUArgumentUsageAnalysis())
20#undef MODULE_ANALYSIS
21
22#ifndef MODULE_PASS
23#define MODULE_PASS(NAME, CREATE_PASS)
24#endif
25MODULE_PASS("amdgpu-always-inline", AMDGPUAlwaysInlinePass())
26MODULE_PASS("amdgpu-export-kernel-runtime-handles", AMDGPUExportKernelRuntimeHandlesPass())
27MODULE_PASS("amdgpu-lower-buffer-fat-pointers",
28 AMDGPULowerBufferFatPointersPass(*this))
29MODULE_PASS("amdgpu-lower-intrinsics", AMDGPULowerIntrinsicsPass(*this))
30MODULE_PASS("amdgpu-lower-ctor-dtor", AMDGPUCtorDtorLoweringPass())
31MODULE_PASS("amdgpu-lower-module-lds", AMDGPULowerModuleLDSPass(*this))
32MODULE_PASS("amdgpu-perf-hint",
33 AMDGPUPerfHintAnalysisPass(
34 *static_cast<const GCNTargetMachine *>(this)))
35MODULE_PASS("amdgpu-preload-kernel-arguments", AMDGPUPreloadKernelArgumentsPass(*this))
36MODULE_PASS("amdgpu-printf-runtime-binding", AMDGPUPrintfRuntimeBindingPass())
37MODULE_PASS("amdgpu-remove-incompatible-functions", AMDGPURemoveIncompatibleFunctionsPass(*this))
38MODULE_PASS("amdgpu-lower-exec-sync", AMDGPULowerExecSyncPass())
39MODULE_PASS("amdgpu-sw-lower-lds", AMDGPUSwLowerLDSPass(*this))
40#undef MODULE_PASS
41
42#ifndef MODULE_PASS_WITH_PARAMS
43#define MODULE_PASS_WITH_PARAMS(NAME, CLASS, CREATE_PASS, PARSER, PARAMS)
44#endif
45MODULE_PASS_WITH_PARAMS(
46 "amdgpu-attributor", "AMDGPUAttributorPass",
47 [=](AMDGPUAttributorOptions Options) {
48 return AMDGPUAttributorPass(*this, Options);
49 },
50 parseAMDGPUAttributorPassOptions, "closed-world")
51#undef MODULE_PASS_WITH_PARAMS
52
53#ifndef FUNCTION_PASS
54#define FUNCTION_PASS(NAME, CREATE_PASS)
55#endif
56FUNCTION_PASS("amdgpu-annotate-uniform", AMDGPUAnnotateUniformValuesPass())
57FUNCTION_PASS("amdgpu-codegenprepare", AMDGPUCodeGenPreparePass(*this))
58FUNCTION_PASS("amdgpu-image-intrinsic-opt",
59 AMDGPUImageIntrinsicOptimizerPass(*this))
60FUNCTION_PASS("amdgpu-late-codegenprepare",
61 AMDGPULateCodeGenPreparePass(
62 *static_cast<const GCNTargetMachine *>(this)))
63FUNCTION_PASS("amdgpu-lower-kernel-arguments",
64 AMDGPULowerKernelArgumentsPass(*this))
65FUNCTION_PASS("amdgpu-lower-kernel-attributes",
66 AMDGPULowerKernelAttributesPass())
67FUNCTION_PASS("amdgpu-promote-alloca", AMDGPUPromoteAllocaPass(*this))
68FUNCTION_PASS("amdgpu-promote-alloca-to-vector",
69 AMDGPUPromoteAllocaToVectorPass(*this))
70FUNCTION_PASS("amdgpu-promote-kernel-arguments",
71 AMDGPUPromoteKernelArgumentsPass())
72FUNCTION_PASS("amdgpu-rewrite-undef-for-phi", AMDGPURewriteUndefForPHIPass())
73FUNCTION_PASS("amdgpu-simplifylib", AMDGPUSimplifyLibCallsPass())
74FUNCTION_PASS("amdgpu-unify-divergent-exit-nodes",
75 AMDGPUUnifyDivergentExitNodesPass())
76FUNCTION_PASS("amdgpu-usenative", AMDGPUUseNativeCallsPass())
77FUNCTION_PASS("si-annotate-control-flow", SIAnnotateControlFlowPass(*static_cast<const GCNTargetMachine *>(this)))
78FUNCTION_PASS("amdgpu-uniform-intrinsic-combine", AMDGPUUniformIntrinsicCombinePass())
79#undef FUNCTION_PASS
80
81#ifndef FUNCTION_ANALYSIS
82#define FUNCTION_ANALYSIS(NAME, CREATE_PASS)
83#endif
84
85#ifndef FUNCTION_ALIAS_ANALYSIS
86#define FUNCTION_ALIAS_ANALYSIS(NAME, CREATE_PASS) \
87 FUNCTION_ANALYSIS(NAME, CREATE_PASS)
88#endif
89FUNCTION_ALIAS_ANALYSIS("amdgpu-aa", AMDGPUAA())
90#undef FUNCTION_ALIAS_ANALYSIS
91#undef FUNCTION_ANALYSIS
92
93#ifndef FUNCTION_PASS_WITH_PARAMS
94#define FUNCTION_PASS_WITH_PARAMS(NAME, CLASS, CREATE_PASS, PARSER, PARAMS)
95#endif
96FUNCTION_PASS_WITH_PARAMS(
97 "amdgpu-atomic-optimizer",
98 "AMDGPUAtomicOptimizerPass",
99 [=](ScanOptions Strategy) {
100 return AMDGPUAtomicOptimizerPass(*this, Strategy);
101 },
102 parseAMDGPUAtomicOptimizerStrategy, "strategy=dpp|iterative|none")
103#undef FUNCTION_PASS_WITH_PARAMS
104
105#ifndef MACHINE_FUNCTION_ANALYSIS
106#define MACHINE_FUNCTION_ANALYSIS(NAME, CREATE_PASS)
107#endif
108
109MACHINE_FUNCTION_ANALYSIS("amdgpu-resource-usage", AMDGPUResourceUsageAnalysis(*static_cast<const GCNTargetMachine *>(this)))
110#undef MACHINE_FUNCTION_ANALYSIS
111
112#ifndef MACHINE_FUNCTION_PASS
113#define MACHINE_FUNCTION_PASS(NAME, CREATE_PASS)
114#endif
115MACHINE_FUNCTION_PASS("amdgpu-insert-delay-alu", AMDGPUInsertDelayAluPass())
116MACHINE_FUNCTION_PASS("amdgpu-isel", AMDGPUISelDAGToDAGPass(*this))
117MACHINE_FUNCTION_PASS("amdgpu-lower-vgpr-encoding", AMDGPULowerVGPREncodingPass())
118MACHINE_FUNCTION_PASS("amdgpu-mark-last-scratch-load", AMDGPUMarkLastScratchLoadPass())
119MACHINE_FUNCTION_PASS("amdgpu-pre-ra-long-branch-reg", GCNPreRALongBranchRegPass())
120MACHINE_FUNCTION_PASS("amdgpu-reserve-wwm-regs", AMDGPUReserveWWMRegsPass())
121MACHINE_FUNCTION_PASS("amdgpu-rewrite-agpr-copy-mfma", AMDGPURewriteAGPRCopyMFMAPass())
122MACHINE_FUNCTION_PASS("amdgpu-rewrite-partial-reg-uses", GCNRewritePartialRegUsesPass())
123MACHINE_FUNCTION_PASS("amdgpu-set-wave-priority", AMDGPUSetWavePriorityPass())
124MACHINE_FUNCTION_PASS("amdgpu-pre-ra-optimizations", GCNPreRAOptimizationsPass())
125MACHINE_FUNCTION_PASS("amdgpu-preload-kern-arg-prolog", AMDGPUPreloadKernArgPrologPass())
126MACHINE_FUNCTION_PASS("amdgpu-prepare-agpr-alloc", AMDGPUPrepareAGPRAllocPass())
127MACHINE_FUNCTION_PASS("amdgpu-nsa-reassign", GCNNSAReassignPass())
128MACHINE_FUNCTION_PASS("amdgpu-wait-sgpr-hazards", AMDGPUWaitSGPRHazardsPass())
129MACHINE_FUNCTION_PASS("gcn-create-vopd", GCNCreateVOPDPass())
130MACHINE_FUNCTION_PASS("gcn-dpp-combine", GCNDPPCombinePass())
131MACHINE_FUNCTION_PASS("si-fix-sgpr-copies", SIFixSGPRCopiesPass())
132MACHINE_FUNCTION_PASS("si-fix-vgpr-copies", SIFixVGPRCopiesPass())
133MACHINE_FUNCTION_PASS("si-fold-operands", SIFoldOperandsPass());
134MACHINE_FUNCTION_PASS("si-form-memory-clauses", SIFormMemoryClausesPass())
135MACHINE_FUNCTION_PASS("si-i1-copies", SILowerI1CopiesPass())
136MACHINE_FUNCTION_PASS("si-insert-hard-clauses", SIInsertHardClausesPass())
137MACHINE_FUNCTION_PASS("si-insert-waitcnts", SIInsertWaitcntsPass())
138MACHINE_FUNCTION_PASS("si-late-branch-lowering", SILateBranchLoweringPass())
139MACHINE_FUNCTION_PASS("si-load-store-opt", SILoadStoreOptimizerPass())
140MACHINE_FUNCTION_PASS("si-lower-control-flow", SILowerControlFlowPass())
141MACHINE_FUNCTION_PASS("si-lower-sgpr-spills", SILowerSGPRSpillsPass())
142MACHINE_FUNCTION_PASS("si-lower-wwm-copies", SILowerWWMCopiesPass())
143MACHINE_FUNCTION_PASS("si-memory-legalizer", SIMemoryLegalizerPass())
144MACHINE_FUNCTION_PASS("si-mode-register", SIModeRegisterPass())
145MACHINE_FUNCTION_PASS("si-opt-vgpr-liverange", SIOptimizeVGPRLiveRangePass())
146MACHINE_FUNCTION_PASS("si-optimize-exec-masking", SIOptimizeExecMaskingPass())
147MACHINE_FUNCTION_PASS("si-optimize-exec-masking-pre-ra", SIOptimizeExecMaskingPreRAPass())
148MACHINE_FUNCTION_PASS("si-peephole-sdwa", SIPeepholeSDWAPass())
149MACHINE_FUNCTION_PASS("si-post-ra-bundler", SIPostRABundlerPass())
150MACHINE_FUNCTION_PASS("si-pre-allocate-wwm-regs", SIPreAllocateWWMRegsPass())
151MACHINE_FUNCTION_PASS("si-pre-emit-peephole", SIPreEmitPeepholePass())
152MACHINE_FUNCTION_PASS("si-shrink-instructions", SIShrinkInstructionsPass())
153MACHINE_FUNCTION_PASS("si-wqm", SIWholeQuadModePass())
154#undef MACHINE_FUNCTION_PASS
155
156#define DUMMY_MACHINE_FUNCTION_PASS(NAME, CREATE_PASS)
157// Global ISel passes
158DUMMY_MACHINE_FUNCTION_PASS("amdgpu-prelegalizer-combiner", AMDGPUPreLegalizerCombinerPass())
159DUMMY_MACHINE_FUNCTION_PASS("amdgpu-postlegalizer-combiner", AMDGPUPostLegalizerCombinerPass())
160DUMMY_MACHINE_FUNCTION_PASS("amdgpu-global-isel-divergence-lowering", AMDGPUGlobalISelDivergenceLoweringPass())
161DUMMY_MACHINE_FUNCTION_PASS("amdgpu-regbankselect", AMDGPURegBankSelectPass())
162DUMMY_MACHINE_FUNCTION_PASS("amdgpu-regbanklegalize", AMDGPURegBankLegalizePass())
163DUMMY_MACHINE_FUNCTION_PASS("amdgpu-regbank-combiner", AMDGPURegBankCombinerPass())
164
165#undef DUMMY_MACHINE_FUNCTION_PASS
166