LLVM 23.0.0git
AMDGPU.h
Go to the documentation of this file.
1//===-- AMDGPU.h - MachineFunction passes hw codegen --------------*- 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/// \file
8//===----------------------------------------------------------------------===//
9
10#ifndef LLVM_LIB_TARGET_AMDGPU_AMDGPU_H
11#define LLVM_LIB_TARGET_AMDGPU_AMDGPU_H
12
15#include "llvm/IR/PassManager.h"
16#include "llvm/Pass.h"
19
20namespace llvm {
21
23class LazyCallGraph;
25class TargetMachine;
26
27// GlobalISel passes
37
38// SI Passes
58
74
80
82 : OptionalPassInfoMixin<AMDGPUImageIntrinsicOptimizerPass> {
85
86private:
87 TargetMachine &TM;
88};
89
94
95class SILowerI1CopiesPass : public OptionalPassInfoMixin<SILowerI1CopiesPass> {
96public:
100};
101
103
105
107
108// DPP/Iterative option enables the atomic optimizer with given strategy
109// whereas None disables the atomic optimizer.
110enum class ScanOptions { DPP, Iterative, None };
111FunctionPass *createAMDGPUAtomicOptimizerPass(ScanOptions ScanStrategy);
113extern char &AMDGPUAtomicOptimizerID;
114
118
122
126
128 : OptionalPassInfoMixin<AMDGPUPromoteKernelArgumentsPass> {
130};
131
135
137 : OptionalPassInfoMixin<AMDGPULowerKernelAttributesPass> {
139};
140
143
151
154
156 : OptionalPassInfoMixin<AMDGPULowerBufferFatPointersPass> {
159
160private:
161 const TargetMachine &TM;
162};
163
165
167 : OptionalPassInfoMixin<AMDGPULowerIntrinsicsPass> {
170
171private:
172 const AMDGPUTargetMachine &TM;
173};
174
177
180
182extern char &AMDGPURewriteOutArgumentsID;
183
185extern char &GCNDPPCombineLegacyID;
186
188extern char &SIFoldOperandsLegacyID;
189
191extern char &SIPeepholeSDWALegacyID;
192
195
197extern char &SIFixSGPRCopiesLegacyID;
198
200extern char &SIFixVGPRCopiesID;
201
204
207
209extern char &SILowerWWMCopiesLegacyID;
210
212extern char &SILowerI1CopiesLegacyID;
213
216
218extern char &AMDGPURegBankSelectID;
219
221extern char &AMDGPURegBankLegalizeID;
222
224extern char &AMDGPUMarkLastScratchLoadID;
225
227extern char &SILowerSGPRSpillsLegacyID;
228
231
233extern char &SIWholeQuadModeID;
234
236extern char &SILowerControlFlowLegacyID;
237
239extern char &SIPreEmitPeepholeID;
240
242extern char &SILateBranchLoweringPassID;
243
246
249
252
255
257extern char &GCNRegPressurePrinterID;
258
261
264
265// Passes common to R600 and SI
268extern char &AMDGPUPromoteAllocaID;
269
271 : OptionalPassInfoMixin<AMDGPUPromoteAllocaPass> {
274
275private:
276 TargetMachine &TM;
277};
278
280 : OptionalPassInfoMixin<AMDGPUPromoteAllocaToVectorPass> {
283
284private:
285 TargetMachine &TM;
286};
287
289 : OptionalPassInfoMixin<AMDGPUAtomicOptimizerPass> {
291 : TM(TM), ScanImpl(ScanImpl) {}
293
294private:
295 TargetMachine &TM;
296 ScanOptions ScanImpl;
297};
298
300 : public OptionalPassInfoMixin<AMDGPUInsertDelayAluPass> {
303};
304
307ModulePass *createAMDGPUAlwaysInlinePass(bool GlobalOpt = true);
308
309struct AMDGPUAlwaysInlinePass : OptionalPassInfoMixin<AMDGPUAlwaysInlinePass> {
310 AMDGPUAlwaysInlinePass(bool GlobalOpt = true) : GlobalOpt(GlobalOpt) {}
312
313private:
314 bool GlobalOpt;
315};
316
320
326
331
337
339 : public OptionalPassInfoMixin<AMDGPUCodeGenPreparePass> {
340private:
341 TargetMachine &TM;
342
343public:
346};
347
349 : public OptionalPassInfoMixin<AMDGPULateCodeGenPreparePass> {
350private:
351 const GCNTargetMachine &TM;
352
353public:
356};
357
359 : public OptionalPassInfoMixin<AMDGPULowerKernelArgumentsPass> {
360private:
361 TargetMachine &TM;
362
363public:
366};
367
369 bool IsClosedWorld = false;
370};
371
373 : public OptionalPassInfoMixin<AMDGPUAttributorPass> {
374private:
375 TargetMachine &TM;
376
378
379 const ThinOrFullLTOPhase LTOPhase;
380
381public:
384 : TM(TM), Options(Options), LTOPhase(LTOPhase) {};
386};
387
389 : public OptionalPassInfoMixin<AMDGPUAttributorCGSCCPass> {
390private:
392
393public:
397};
398
400 : public OptionalPassInfoMixin<AMDGPUPreloadKernelArgumentsPass> {
401 const TargetMachine &TM;
402
403public:
404 explicit AMDGPUPreloadKernelArgumentsPass(const TargetMachine &TM) : TM(TM) {}
405
407};
408
410 : public OptionalPassInfoMixin<AMDGPUAnnotateUniformValuesPass> {
411public:
414};
415
421
423 : public RequiredPassInfoMixin<SIMemoryLegalizerPass> {
424public:
427};
428
429class GCNCreateVOPDPass : public OptionalPassInfoMixin<GCNCreateVOPDPass> {
430public:
433};
434
436 : public OptionalPassInfoMixin<AMDGPUMarkLastScratchLoadPass> {
437public:
440};
441
443 : public RequiredPassInfoMixin<SIInsertWaitcntsPass> {
444public:
447};
448
450 : public OptionalPassInfoMixin<SIInsertHardClausesPass> {
451public:
454};
455
457 : public RequiredPassInfoMixin<SILateBranchLoweringPass> {
458public:
461};
462
464 : public RequiredPassInfoMixin<SIPreEmitPeepholePass> {
465public:
468};
469
471 : public OptionalPassInfoMixin<AMDGPUSetWavePriorityPass> {
472public:
475};
476
478
482
485
487 : OptionalPassInfoMixin<AMDGPUPrintfRuntimeBindingPass> {
489};
490
493
496
499
501extern char &AMDGPUCodeGenPrepareID;
502
505
508
512
514 : public OptionalPassInfoMixin<AMDGPURewriteUndefForPHIPass> {
515public:
518};
519
521 : public OptionalPassInfoMixin<SIAnnotateControlFlowPass> {
522private:
523 const AMDGPUTargetMachine &TM;
524
525public:
528};
529
532
534extern char &SIMemoryLegalizerID;
535
537extern char &SIModeRegisterID;
538
540extern char &AMDGPUInsertDelayAluID;
541
544
546extern char &SIInsertHardClausesID;
547
549extern char &SIInsertWaitcntsID;
550
552extern char &SIFormMemoryClausesID;
553
555extern char &SIPostRABundlerLegacyID;
556
558extern char &GCNCreateVOPDID;
559
562
567
571
573extern char &GCNNSAReassignID;
574
576extern char &GCNPreRALongBranchRegID;
577
579extern char &GCNPreRAOptimizationsID;
580
583
585extern char &GCNRewritePartialRegUsesID;
586
589
591 : public OptionalPassInfoMixin<AMDGPURewriteAGPRCopyMFMAPass> {
592public:
596};
597
600
604
606 : public OptionalPassInfoMixin<AMDGPUUniformIntrinsicCombinePass> {
608};
609
610namespace AMDGPU {
618
619static inline bool addrspacesMayAlias(unsigned AS1, unsigned AS2) {
621 return true;
622
623 // clang-format off
624 static const bool ASAliasRules[][AMDGPUAS::MAX_AMDGPU_ADDRESS + 1] = {
625 /* Flat Global Region Local Constant Private Const32 BufFatPtr BufRsrc BufStrdPtr */
626 /* Flat */ {true, true, false, true, true, true, true, true, true, true},
627 /* Global */ {true, true, false, false, true, false, true, true, true, true},
628 /* Region */ {false, false, true, false, false, false, false, false, false, false},
629 /* Local */ {true, false, false, true, false, false, false, false, false, false},
630 /* Constant */ {true, true, false, false, false, false, true, true, true, true},
631 /* Private */ {true, false, false, false, false, true, false, false, false, false},
632 /* Constant 32-bit */ {true, true, false, false, true, false, false, true, true, true},
633 /* Buffer Fat Ptr */ {true, true, false, false, true, false, true, true, true, true},
634 /* Buffer Resource */ {true, true, false, false, true, false, true, true, true, true},
635 /* Buffer Strided Ptr */ {true, true, false, false, true, false, true, true, true, true},
636 };
637 // clang-format on
638 static_assert(std::size(ASAliasRules) == AMDGPUAS::MAX_AMDGPU_ADDRESS + 1);
639
640 return ASAliasRules[AS1][AS2];
641}
642
643}
644
645} // End namespace llvm
646
647#endif
AMDGPU address space definition.
This header provides classes for managing passes over SCCs of the call graph.
This header defines various interfaces for pass management in LLVM.
#define F(x, y, z)
Definition MD5.cpp:54
ModuleAnalysisManager MAM
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
AMDGPUAttributorCGSCCPass(GCNTargetMachine &TM)
Definition AMDGPU.h:394
PreservedAnalyses run(LazyCallGraph::SCC &C, CGSCCAnalysisManager &AM, LazyCallGraph &CG, CGSCCUpdateResult &UR)
PreservedAnalyses run(Module &M, ModuleAnalysisManager &AM)
AMDGPUAttributorPass(TargetMachine &TM, AMDGPUAttributorOptions Options, ThinOrFullLTOPhase LTOPhase=ThinOrFullLTOPhase::None)
Definition AMDGPU.h:382
PreservedAnalyses run(Function &, FunctionAnalysisManager &)
AMDGPUCodeGenPreparePass(TargetMachine &TM)
Definition AMDGPU.h:344
AMDGPULateCodeGenPreparePass(const GCNTargetMachine &TM)
Definition AMDGPU.h:354
PreservedAnalyses run(Function &, FunctionAnalysisManager &)
AMDGPULowerKernelArgumentsPass(TargetMachine &TM)
Definition AMDGPU.h:364
PreservedAnalyses run(Function &, FunctionAnalysisManager &)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &AM)
AMDGPUPreloadKernelArgumentsPass(const TargetMachine &TM)
Definition AMDGPU.h:404
PreservedAnalyses run(Module &M, ModuleAnalysisManager &AM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
FunctionPass class - This class is used to implement most global optimizations.
Definition Pass.h:314
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &AM)
ImmutablePass class - This class is used to provide information that does not need to be run.
Definition Pass.h:285
An SCC of the call graph.
A lazily constructed view of the call graph of a module.
ModulePass class - This class is used to implement unstructured interprocedural optimizations and ana...
Definition Pass.h:255
A Module instance is used to store all the information related to an LLVM module.
Definition Module.h:67
PassRegistry - This class manages the registration and intitialization of the pass subsystem as appli...
Pass interface - Implemented by all 'passes'.
Definition Pass.h:99
A set of analyses that are preserved following a run of a transformation pass.
Definition Analysis.h:112
SIAnnotateControlFlowPass(const AMDGPUTargetMachine &TM)
Definition AMDGPU.h:526
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &F, MachineFunctionAnalysisManager &AM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Primary interface to the complete machine description for the target machine.
static bool addrspacesMayAlias(unsigned AS1, unsigned AS2)
Definition AMDGPU.h:619
@ TI_SCRATCH_RSRC_DWORD1
Definition AMDGPU.h:614
@ TI_SCRATCH_RSRC_DWORD3
Definition AMDGPU.h:616
@ TI_SCRATCH_RSRC_DWORD0
Definition AMDGPU.h:613
@ TI_SCRATCH_RSRC_DWORD2
Definition AMDGPU.h:615
@ TI_CONSTDATA_START
Definition AMDGPU.h:612
@ C
The default llvm calling convention, compatible with C.
Definition CallingConv.h:34
This is an optimization pass for GlobalISel generic memory operations.
ScanOptions
Definition AMDGPU.h:110
ImmutablePass * createAMDGPUAAWrapperPass()
char & SIAnnotateControlFlowLegacyPassID
FunctionPass * createAMDGPUSetWavePriorityPass()
char & AMDGPUCtorDtorLoweringLegacyPassID
void initializeAMDGPUMarkLastScratchLoadLegacyPass(PassRegistry &)
void initializeAMDGPUInsertDelayAluLegacyPass(PassRegistry &)
char & AMDGPUPreloadKernArgPrologLegacyID
char & AMDGPUExportKernelRuntimeHandlesLegacyID
void initializeSIOptimizeExecMaskingPreRALegacyPass(PassRegistry &)
char & GCNPreRAOptimizationsID
void initializeSIInsertHardClausesLegacyPass(PassRegistry &)
char & SIMemoryLegalizerID
FunctionPass * createSIFormMemoryClausesLegacyPass()
FunctionPass * createSIAnnotateControlFlowLegacyPass()
Create the annotation pass.
FunctionPass * createSIModeRegisterPass()
void initializeGCNPreRAOptimizationsLegacyPass(PassRegistry &)
void initializeSILowerWWMCopiesLegacyPass(PassRegistry &)
void initializeAMDGPUAAWrapperPassPass(PassRegistry &)
void initializeSIShrinkInstructionsLegacyPass(PassRegistry &)
ModulePass * createAMDGPULowerBufferFatPointersPass()
char & SIShrinkInstructionsLegacyID
ModulePass * createAMDGPUCtorDtorLoweringLegacyPass()
char & AMDGPUImageIntrinsicOptimizerID
ModulePass * createAMDGPUSwLowerLDSLegacyPass(const AMDGPUTargetMachine *TM=nullptr)
void initializeGCNRewritePartialRegUsesLegacyPass(llvm::PassRegistry &)
void initializeAMDGPURewriteUndefForPHILegacyPass(PassRegistry &)
char & AMDGPULowerExecSyncLegacyPassID
char & AMDGPUPromoteKernelArgumentsID
char & GCNRewritePartialRegUsesID
void initializeAMDGPUSetWavePriorityLegacyPass(PassRegistry &)
void initializeAMDGPUSwLowerLDSLegacyPass(PassRegistry &)
void initializeAMDGPULowerVGPREncodingLegacyPass(PassRegistry &)
FunctionPass * createAMDGPURewriteOutArgumentsPass()
char & AMDGPUWaitSGPRHazardsLegacyID
void initializeSILowerSGPRSpillsLegacyPass(PassRegistry &)
char & AMDGPUResourceUsageAnalysisID
void initializeAMDGPUDAGToDAGISelLegacyPass(PassRegistry &)
FunctionPass * createAMDGPURegBankCombiner(bool IsOptNone)
char & AMDGPUReserveWWMRegsLegacyID
void initializeAMDGPUWaitSGPRHazardsLegacyPass(PassRegistry &)
char & SIOptimizeExecMaskingLegacyID
FunctionPass * createSILoadStoreOptimizerLegacyPass()
ModulePass * createAMDGPULowerKernelAttributesPass()
void initializeAMDGPUNextUseAnalysisLegacyPassPass(PassRegistry &)
ModulePass * createAMDGPUExportKernelRuntimeHandlesLegacyPass()
ModulePass * createAMDGPUAlwaysInlinePass(bool GlobalOpt=true)
AnalysisManager< MachineFunction > MachineFunctionAnalysisManager
void initializeAMDGPUAsmPrinterPass(PassRegistry &)
void initializeSIFoldOperandsLegacyPass(PassRegistry &)
FunctionPass * createAMDGPUNextUseAnalysisLegacyPass()
char & SILoadStoreOptimizerLegacyID
void initializeAMDGPUGlobalISelDivergenceLoweringPass(PassRegistry &)
FunctionPass * createSIPeepholeSDWALegacyPass()
char & SIFormMemoryClausesID
char & AMDGPURemoveIncompatibleFunctionsID
void initializeSILoadStoreOptimizerLegacyPass(PassRegistry &)
void initializeAMDGPULowerModuleLDSLegacyPass(PassRegistry &)
AnalysisManager< LazyCallGraph::SCC, LazyCallGraph & > CGSCCAnalysisManager
The CGSCC analysis manager.
void initializeAMDGPUCtorDtorLoweringLegacyPass(PassRegistry &)
FunctionPass * createAMDGPUUniformIntrinsicCombineLegacyPass()
void initializeAMDGPURegBankCombinerPass(PassRegistry &)
FunctionPass * createSIFoldOperandsLegacyPass()
ThinOrFullLTOPhase
This enumerates the LLVM full LTO or ThinLTO optimization phases.
Definition Pass.h:77
@ None
No LTO/ThinLTO behavior needed.
Definition Pass.h:79
char & AMDGPUUnifyDivergentExitNodesID
void initializeAMDGPUPrepareAGPRAllocLegacyPass(PassRegistry &)
char & SIInsertWaitcntsID
FunctionPass * createAMDGPUAtomicOptimizerPass(ScanOptions ScanStrategy)
FunctionPass * createAMDGPUPreloadKernArgPrologLegacyPass()
char & AMDGPUPrintfRuntimeBindingID
char & SIOptimizeVGPRLiveRangeLegacyID
char & GCNNSAReassignID
void initializeAMDGPURewriteOutArgumentsPass(PassRegistry &)
void initializeAMDGPUExternalAAWrapperPass(PassRegistry &)
void initializeAMDGPULowerKernelArgumentsPass(PassRegistry &)
void initializeSIModeRegisterLegacyPass(PassRegistry &)
void initializeAMDGPUPreloadKernelArgumentsLegacyPass(PassRegistry &)
char & SILateBranchLoweringPassID
char & SIModeRegisterID
FunctionPass * createAMDGPUNextUseAnalysisPrinterLegacyPass()
char & AMDGPUSwLowerLDSLegacyPassID
void initializeSIMemoryLegalizerLegacyPass(PassRegistry &)
ModulePass * createAMDGPULowerIntrinsicsLegacyPass()
char & GCNDPPCombineLegacyID
FunctionPass * createAMDGPULowerKernelArgumentsPass()
char & AMDGPUInsertDelayAluID
void initializeGCNPreRALongBranchRegLegacyPass(PassRegistry &)
char & SILowerWWMCopiesLegacyID
char & SIOptimizeExecMaskingPreRAID
char & AMDGPULowerModuleLDSLegacyPassID
FunctionPass * createSIPostRABundlerPass()
void initializeAMDGPULowerExecSyncLegacyPass(PassRegistry &)
void initializeAMDGPUPostLegalizerCombinerPass(PassRegistry &)
void initializeAMDGPUExportKernelRuntimeHandlesLegacyPass(PassRegistry &)
FunctionPass * createSIPreAllocateWWMRegsLegacyPass()
Pass * createAMDGPUStructurizeCFGPass()
CodeGenOptLevel
Code generation optimization level.
Definition CodeGen.h:82
void initializeSIInsertWaitcntsLegacyPass(PassRegistry &)
char & AMDGPURegBankSelectID
ModulePass * createAMDGPUPreloadKernelArgumentsLegacyPass(const TargetMachine *)
ModulePass * createAMDGPUPrintfRuntimeBinding()
void initializeAMDGPUImageIntrinsicOptimizerPass(PassRegistry &)
void initializeSILateBranchLoweringLegacyPass(PassRegistry &)
void initializeSILowerControlFlowLegacyPass(PassRegistry &)
void initializeSIFormMemoryClausesLegacyPass(PassRegistry &)
char & SIPreAllocateWWMRegsLegacyID
char & AMDGPUNextUseAnalysisLegacyID
ModulePass * createAMDGPULowerModuleLDSLegacyPass(const AMDGPUTargetMachine *TM=nullptr)
void initializeAMDGPUPreLegalizerCombinerPass(PassRegistry &)
FunctionPass * createAMDGPUPromoteAlloca()
void initializeAMDGPUReserveWWMRegsLegacyPass(PassRegistry &)
char & SIPreEmitPeepholeID
char & SIPostRABundlerLegacyID
ModulePass * createAMDGPURemoveIncompatibleFunctionsPass(const TargetMachine *)
void initializeGCNRegPressurePrinterPass(PassRegistry &)
char & AMDGPURewriteOutArgumentsID
void initializeSILowerI1CopiesLegacyPass(PassRegistry &)
char & SILowerSGPRSpillsLegacyID
char & SILowerControlFlowLegacyID
FunctionPass * createAMDGPUCodeGenPreparePass()
void initializeSIAnnotateControlFlowLegacyPass(PassRegistry &)
FunctionPass * createAMDGPUReserveWWMRegsPass()
FunctionPass * createAMDGPUISelDag(TargetMachine &TM, CodeGenOptLevel OptLevel)
This pass converts a legalized DAG into a AMDGPU-specific.
void initializeGCNCreateVOPDLegacyPass(PassRegistry &)
void initializeAMDGPUUniformIntrinsicCombineLegacyPass(PassRegistry &)
void initializeSIPreAllocateWWMRegsLegacyPass(PassRegistry &)
void initializeSIFixVGPRCopiesLegacyPass(PassRegistry &)
void initializeSIFixSGPRCopiesLegacyPass(PassRegistry &)
char & AMDGPUAnnotateUniformValuesLegacyPassID
void initializeAMDGPUAtomicOptimizerPass(PassRegistry &)
void initializeAMDGPULowerIntrinsicsLegacyPass(PassRegistry &)
FunctionPass * createGCNPreRAOptimizationsLegacyPass()
void initializeAMDGPURewriteAGPRCopyMFMALegacyPass(PassRegistry &)
char & AMDGPULowerKernelAttributesID
void initializeAMDGPUNextUseAnalysisPrinterLegacyPassPass(PassRegistry &)
char & AMDGPUUniformIntrinsicCombineLegacyPassID
void initializeSIPostRABundlerLegacyPass(PassRegistry &)
FunctionPass * createAMDGPURegBankSelectPass()
FunctionPass * createSIWholeQuadModeLegacyPass()
char & GCNRegPressurePrinterID
FunctionPass * createAMDGPURegBankLegalizePass()
char & SIWholeQuadModeID
FunctionPass * createSIOptimizeVGPRLiveRangeLegacyPass()
ImmutablePass * createAMDGPUExternalAAWrapperPass()
void initializeAMDGPUCodeGenPreparePass(PassRegistry &)
FunctionPass * createAMDGPURewriteUndefForPHILegacyPass()
void initializeSIOptimizeExecMaskingLegacyPass(PassRegistry &)
char & AMDGPUNextUseAnalysisPrinterLegacyID
FunctionPass * createSILowerI1CopiesLegacyPass()
char & AMDGPULateCodeGenPrepareLegacyID
FunctionPass * createAMDGPUPostLegalizeCombiner(bool IsOptNone)
void initializeAMDGPULowerKernelAttributesPass(PassRegistry &)
char & SIInsertHardClausesID
char & SIFixSGPRCopiesLegacyID
void initializeGCNDPPCombineLegacyPass(PassRegistry &)
char & GCNCreateVOPDID
char & SIPeepholeSDWALegacyID
char & SIFixVGPRCopiesID
char & SIFoldOperandsLegacyID
void initializeGCNNSAReassignLegacyPass(PassRegistry &)
char & AMDGPUAtomicOptimizerID
char & SILowerI1CopiesLegacyID
void initializeAMDGPUPreloadKernArgPrologLegacyPass(PassRegistry &)
FunctionPass * createLowerWWMCopiesPass()
char & AMDGPURewriteAGPRCopyMFMALegacyID
ModulePass * createAMDGPULowerExecSyncLegacyPass()
char & AMDGPUPromoteAllocaID
char & AMDGPULowerVGPREncodingLegacyID
FunctionPass * createAMDGPUGlobalISelDivergenceLoweringPass()
FunctionPass * createSIMemoryLegalizerPass()
void initializeAMDGPULateCodeGenPrepareLegacyPass(PassRegistry &)
void initializeSIOptimizeVGPRLiveRangeLegacyPass(PassRegistry &)
void initializeSIPeepholeSDWALegacyPass(PassRegistry &)
char & AMDGPURegBankLegalizeID
void initializeAMDGPURegBankLegalizePass(PassRegistry &)
AnalysisManager< Function > FunctionAnalysisManager
Convenience typedef for the Function analysis manager.
FunctionPass * createAMDGPUPreLegalizeCombiner(bool IsOptNone)
void initializeAMDGPURegBankSelectPass(PassRegistry &)
FunctionPass * createAMDGPULateCodeGenPrepareLegacyPass()
char & AMDGPURewriteUndefForPHILegacyPassID
FunctionPass * createAMDGPUImageIntrinsicOptimizerPass(const TargetMachine *)
void initializeAMDGPULowerBufferFatPointersPass(PassRegistry &)
void initializeAMDGPUUnifyDivergentExitNodesLegacyPass(PassRegistry &)
FunctionPass * createSIInsertWaitcntsPass()
FunctionPass * createAMDGPUAnnotateUniformValuesLegacy()
void initializeSIWholeQuadModeLegacyPass(PassRegistry &)
FunctionPass * createSIOptimizeExecMaskingPreRAPass()
FunctionPass * createGCNDPPCombinePass()
void initializeAMDGPUResourceUsageAnalysisWrapperPassPass(PassRegistry &)
FunctionPass * createSIShrinkInstructionsLegacyPass()
char & AMDGPUPrepareAGPRAllocLegacyID
char & AMDGPUMarkLastScratchLoadID
char & AMDGPUPreloadKernelArgumentsLegacyID
void initializeAMDGPUAnnotateUniformValuesLegacyPass(PassRegistry &)
void initializeAMDGPUPrintfRuntimeBindingPass(PassRegistry &)
void initializeAMDGPUPromoteAllocaPass(PassRegistry &)
void initializeAMDGPURemoveIncompatibleFunctionsLegacyPass(PassRegistry &)
FunctionPass * createSIFixControlFlowLiveIntervalsPass()
char & AMDGPULowerKernelArgumentsID
void initializeAMDGPUAlwaysInlinePass(PassRegistry &)
char & AMDGPUCodeGenPrepareID
FunctionPass * createSIFixSGPRCopiesLegacyPass()
void initializeSIPreEmitPeepholeLegacyPass(PassRegistry &)
AnalysisManager< Module > ModuleAnalysisManager
Convenience typedef for the Module analysis manager.
Definition MIRParser.h:39
char & AMDGPUPerfHintAnalysisLegacyID
FunctionPass * createAMDGPUPromoteKernelArgumentsPass()
char & GCNPreRALongBranchRegID
void initializeAMDGPUPerfHintAnalysisLegacyPass(PassRegistry &)
void initializeAMDGPUPromoteKernelArgumentsPass(PassRegistry &)
AMDGPUAlwaysInlinePass(bool GlobalOpt=true)
Definition AMDGPU.h:310
PreservedAnalyses run(Module &M, ModuleAnalysisManager &AM)
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
AMDGPUAtomicOptimizerPass(TargetMachine &TM, ScanOptions ScanImpl)
Definition AMDGPU.h:290
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
AMDGPUImageIntrinsicOptimizerPass(TargetMachine &TM)
Definition AMDGPU.h:83
PreservedAnalyses run(MachineFunction &F, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(Module &M, ModuleAnalysisManager &AM)
AMDGPULowerBufferFatPointersPass(const TargetMachine &TM)
Definition AMDGPU.h:157
PreservedAnalyses run(Module &M, ModuleAnalysisManager &AM)
PreservedAnalyses run(Module &M, ModuleAnalysisManager &MAM)
AMDGPULowerIntrinsicsPass(const AMDGPUTargetMachine &TM)
Definition AMDGPU.h:168
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
PreservedAnalyses run(Module &M, ModuleAnalysisManager &AM)
AMDGPULowerModuleLDSPass(const AMDGPUTargetMachine &TM_)
Definition AMDGPU.h:147
const AMDGPUTargetMachine & TM
Definition AMDGPU.h:146
PreservedAnalyses run(Module &M, ModuleAnalysisManager &AM)
AMDGPUPromoteAllocaPass(TargetMachine &TM)
Definition AMDGPU.h:272
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
AMDGPUPromoteAllocaToVectorPass(TargetMachine &TM)
Definition AMDGPU.h:281
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
const AMDGPUTargetMachine & TM
Definition AMDGPU.h:333
PreservedAnalyses run(Module &M, ModuleAnalysisManager &AM)
AMDGPUSwLowerLDSPass(const AMDGPUTargetMachine &TM_)
Definition AMDGPU.h:334
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
Support structure for SCC passes to communicate updates the call graph back to the CGSCC pass manager...
A CRTP mix-in for passes that can be skipped.
A CRTP mix-in for passes that should not be skipped.