14#ifndef LLVM_PASSES_CODEGENPASSBUILDER_H
15#define LLVM_PASSES_CODEGENPASSBUILDER_H
134#define DUMMY_FUNCTION_PASS(NAME, PASS_NAME) \
135 struct PASS_NAME : public PassInfoMixin<PASS_NAME> { \
136 template <typename... Ts> PASS_NAME(Ts &&...) {} \
137 PreservedAnalyses run(Function &, FunctionAnalysisManager &) { \
138 return PreservedAnalyses::all(); \
141#define DUMMY_MACHINE_MODULE_PASS(NAME, PASS_NAME) \
142 struct PASS_NAME : public PassInfoMixin<PASS_NAME> { \
143 template <typename... Ts> PASS_NAME(Ts &&...) {} \
144 PreservedAnalyses run(Module &, ModuleAnalysisManager &) { \
145 return PreservedAnalyses::all(); \
148#define DUMMY_MACHINE_FUNCTION_PASS(NAME, PASS_NAME) \
149 struct PASS_NAME : public PassInfoMixin<PASS_NAME> { \
150 template <typename... Ts> PASS_NAME(Ts &&...) {} \
151 PreservedAnalyses run(MachineFunction &, \
152 MachineFunctionAnalysisManager &) { \
153 return PreservedAnalyses::all(); \
156#include "llvm/Passes/MachinePassRegistry.def"
158class PassManagerWrapper {
166 template <
typename DerivedT,
typename TargetMachineT>
187 if (
Opt.EnableIPRA) {
188 TM.Options.EnableIPRA = *Opt.EnableIPRA;
191 TM.Options.EnableIPRA |= TM.useIPRA();
194 if (
Opt.EnableGlobalISelAbort)
195 TM.Options.GlobalISelAbort = *
Opt.EnableGlobalISelAbort;
197 if (!
Opt.OptimizeRegAlloc)
210 template <
typename PassT>
212 std::declval<Module &>(), std::declval<ModuleAnalysisManager &>()));
214 template <
typename PassT>
216 std::declval<Function &>(), std::declval<FunctionAnalysisManager &>()));
218 template <
typename PassT>
220 std::declval<MachineFunction &>(),
221 std::declval<MachineFunctionAnalysisManager &>()));
223 template <
typename PassT>
228 "Only function passes are supported.");
229 if (!Force && !runBeforeAdding(Name))
234 template <
typename PassT>
238 "Only module passes are suported.");
240 "You cannot insert a module pass without first flushing the current "
241 "function pipelines to the module pipeline.");
242 if (!Force && !runBeforeAdding(Name))
247 template <
typename PassT>
252 "Only machine function passes are supported.");
254 if (!Force && !runBeforeAdding(Name))
257 for (
auto &
C : AfterCallbacks)
262 bool FreeMachineFunctions =
false)
const {
270 if (FreeMachineFunctions)
272 if (AddInCGSCCOrder) {
284 "Requiring CGSCC ordering requires flushing the current function "
285 "pipelines to the MPM.");
286 AddInCGSCCOrder =
true;
292 "Stopping CGSCC ordering requires flushing the current function "
293 "pipelines to the MPM.");
294 AddInCGSCCOrder =
false;
301 template <
typename TMC> TMC &
getTM()
const {
return static_cast<TMC &
>(
TM); }
426 "addGlobalInstructionSelect is not overridden",
511 bool Optimized)
const;
525 BeforeCallbacks.emplace_back(
526 [](
StringRef Name) {
return ((Name != PassTs::name()) && ...); });
531 template <
typename TargetPassT,
typename InsertedPassT>
533 AfterCallbacks.emplace_back(
535 if (Name == TargetPassT::name() &&
536 runBeforeAdding(InsertedPassT::name())) {
543 DerivedT &derived() {
return static_cast<DerivedT &
>(*this); }
544 const DerivedT &derived()
const {
545 return static_cast<const DerivedT &
>(*this);
548 bool runBeforeAdding(StringRef Name)
const {
549 bool ShouldAdd =
true;
550 for (
auto &
C : BeforeCallbacks)
551 ShouldAdd &=
C(Name);
555 void setStartStopPasses(
const TargetPassConfig::StartStopInfo &Info)
const;
557 Error verifyStartStop(
const TargetPassConfig::StartStopInfo &Info)
const;
559 mutable SmallVector<llvm::unique_function<bool(StringRef)>, 4>
566 mutable bool Started =
true;
567 mutable bool Stopped =
true;
568 mutable bool AddInCGSCCOrder =
false;
571template <
typename Derived,
typename TargetMachineT>
577 return StartStopInfo.takeError();
578 setStartStopPasses(*StartStopInfo);
601 TM.createMCStreamer(Out, DwoOut, FileType, Ctx);
602 if (!MCStreamerOrErr)
604 std::unique_ptr<AsmPrinter>
Printer(
605 TM.getTarget().createAsmPrinter(
TM, std::move(*MCStreamerOrErr)));
609 derived().addAsmPrinterBegin(PMW);
616 return std::move(Err);
619 return std::move(Err);
621 if (!
Opt.DisableVerify)
625 derived().addAsmPrinter(PMW);
627 derived().addAsmPrinterEnd(PMW);
634 return verifyStartStop(*StartStopInfo);
637template <
typename Derived,
typename TargetMachineT>
638void CodeGenPassBuilder<Derived, TargetMachineT>::setStartStopPasses(
640 if (!Info.StartPass.empty()) {
642 BeforeCallbacks.emplace_back([
this, &Info, AfterFlag = Info.StartAfter,
644 if (Count == Info.StartInstanceNum) {
652 auto PassName =
PIC->getPassNameForClassName(ClassName);
654 Started = !Info.StartAfter;
660 if (!
Info.StopPass.empty()) {
662 BeforeCallbacks.emplace_back([
this, &Info, AfterFlag =
Info.StopAfter,
664 if (Count == Info.StopInstanceNum) {
674 Stopped = !
Info.StopAfter;
680template <
typename Derived,
typename TargetMachineT>
681Error CodeGenPassBuilder<Derived, TargetMachineT>::verifyStartStop(
683 if (Started && Stopped)
688 "Can't find start pass \"" + Info.StartPass +
"\".",
689 std::make_error_code(std::errc::invalid_argument));
692 "Can't find stop pass \"" + Info.StopPass +
"\".",
693 std::make_error_code(std::errc::invalid_argument));
697template <
typename Derived,
typename TargetMachineT>
700 derived().addGlobalMergePass(PMW);
701 if (
TM.useEmulatedTLS())
713 derived().addIRPasses(PMW);
714 derived().addCodeGenPrepare(PMW);
716 derived().addISelPrepare(PMW);
721template <
typename Derived,
typename TargetMachineT>
726 if (!
Opt.DisableVerify)
735 if (
Opt.EnableLoopTermFold)
765 !
Opt.DisablePartialLibcallInlining)
777 if (!
Opt.DisableExpandReductions)
784 if (
Opt.EnableGlobalMergeFunc) {
792template <
typename Derived,
typename TargetMachineT>
838template <
typename Derived,
typename TargetMachineT>
849template <
typename Derived,
typename TargetMachineT>
852 derived().addPreISel(PMW);
854 if (
Opt.RequiresCodeGenSCCOrder && !AddInCGSCCOrder)
863 if (
Opt.PrintISelInput)
865 dbgs(),
"\n\n*** Final LLVM Code input to ISel ***\n"),
870 if (!
Opt.DisableVerify)
874template <
typename Derived,
typename TargetMachineT>
878 TM.setO0WantsFastISel(
Opt.EnableFastISelOption.value_or(
true));
882 SelectorType Selector;
884 if (
Opt.EnableFastISelOption && *
Opt.EnableFastISelOption ==
true)
885 Selector = SelectorType::FastISel;
886 else if ((
Opt.EnableGlobalISelOption &&
887 *
Opt.EnableGlobalISelOption ==
true) ||
888 (
TM.Options.EnableGlobalISel &&
889 (!
Opt.EnableGlobalISelOption ||
890 *
Opt.EnableGlobalISelOption ==
false)))
891 Selector = SelectorType::GlobalISel;
893 Selector = SelectorType::FastISel;
895 Selector = SelectorType::SelectionDAG;
898 if (Selector == SelectorType::FastISel) {
899 TM.setFastISel(
true);
900 TM.setGlobalISel(
false);
901 }
else if (Selector == SelectorType::GlobalISel) {
902 TM.setFastISel(
false);
903 TM.setGlobalISel(
true);
907 if (Selector == SelectorType::GlobalISel) {
909 return std::move(Err);
911 derived().addPreLegalizeMachineIR(PMW);
914 return std::move(Err);
918 derived().addPreRegBankSelect(PMW);
921 return std::move(Err);
923 derived().addPreGlobalInstructionSelect(PMW);
926 return std::move(Err);
938 return std::move(Err);
941 return std::move(Err);
969template <
typename Derived,
typename TargetMachineT>
974 derived().addMachineSSAOptimization(PMW);
981 if (
TM.Options.EnableIPRA) {
988 derived().addPreRegAlloc(PMW);
994 return std::move(Err);
997 derived().addPostRegAlloc(PMW);
1012 derived().addMachineLateOptimization(PMW);
1018 derived().addPreSched2(PMW);
1020 if (
Opt.EnableImplicitNullChecks)
1027 !
TM.targetSchedulesPostRAScheduling()) {
1028 if (
Opt.MISchedPostRA)
1035 derived().addGCPasses(PMW);
1039 derived().addBlockPlacement(PMW);
1047 derived().addPreEmitPass(PMW);
1049 if (
TM.Options.EnableIPRA) {
1054 if (
Opt.PrintRegUsage) {
1070 if (
TM.Options.EnableMachineOutliner &&
1074 TM.Options.SupportsDefaultOutlining) {
1080 if (
Opt.EnableGCEmptyBlocks)
1083 derived().addPostBBSections(PMW);
1088 derived().addPreEmitPass2(PMW);
1094template <
typename Derived,
typename TargetMachineT>
1121 derived().addILPOpts(PMW);
1148template <
typename Derived,
typename TargetMachineT>
1163template <
typename Derived,
typename TargetMachineT>
1168 switch (
Opt.RegAlloc) {
1182 derived().addTargetRegisterAllocator(PMW, Optimized);
1185template <
typename Derived,
typename TargetMachineT>
1193template <
typename Derived,
typename TargetMachineT>
1200 derived().addPreRewrite(PMW);
1215template <
typename Derived,
typename TargetMachineT>
1220 return derived().addRegAssignmentFast(PMW);
1226template <
typename Derived,
typename TargetMachineT>
1255 if (
Opt.EarlyLiveIntervals)
1271 return std::move(E);
1277 derived().addPostRewrite(PMW);
1296template <
typename Derived,
typename TargetMachineT>
1309 if (!
TM.requiresStructuredCFG())
1317template <
typename Derived,
typename TargetMachineT>
1322 if (
Opt.EnableBlockPlacementStats)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
amdgpu next use AMDGPU Next Use Analysis Printer
This is the interface for LLVM's primary stateless and local alias analysis.
This header provides classes for managing passes over SCCs of the call graph.
Defines an IR pass for CodeGen Prepare.
Analysis that tracks defined/used subregister lanes across COPY instructions and instructions that ge...
This file defines passes to print out IR in various granularities.
This header defines various interfaces for pass management in LLVM.
This file contains the declaration of the InterleavedAccessPass class, its corresponding pass name is...
This header provides classes for managing a pipeline of passes over loops in LLVM IR.
The header file for the LowerConstantIntrinsics pass as used by the new pass manager.
ModuleAnalysisManager MAM
PassInstrumentationCallbacks PIC
This pass is required to take advantage of the interprocedural register allocation infrastructure.
This is the interface for a metadata-based scoped no-alias analysis.
This file contains the declaration of the SelectOptimizePass class, its corresponding pass name is se...
This file defines the SmallVector class.
Target-Independent Code Generator Pass Configuration Options pass.
This is the interface for a metadata-based TBAA.
static const char PassName[]
A pass that canonicalizes freeze instructions in a loop.
void addPostRegAlloc(PassManagerWrapper &PMW) const
This method may be implemented by targets that want to run passes after register allocation pass pipe...
void addGlobalMergePass(PassManagerWrapper &PMW) const
Target can override this to add GlobalMergePass before all IR passes.
Error addOptimizedRegAlloc(PassManagerWrapper &PMW) const
addOptimizedRegAlloc - Add passes related to register allocation.
void addModulePass(PassT &&Pass, PassManagerWrapper &PMW, bool Force=false, StringRef Name=PassT::name()) const
decltype(std::declval< PassT & >().run( std::declval< Function & >(), std::declval< FunctionAnalysisManager & >())) is_function_pass_t
void flushFPMsToMPM(PassManagerWrapper &PMW, bool FreeMachineFunctions=false) const
void addPreGlobalInstructionSelect(PassManagerWrapper &PMW) const
This method may be implemented by targets that want to run passes immediately before the (global) ins...
Error addRegAssignmentFast(PassManagerWrapper &PMW) const
Add core register allocator passes which do the actual register assignment and rewriting.
void requireCGSCCOrder(PassManagerWrapper &PMW) const
void addISelPrepare(PassManagerWrapper &PMW) const
Add common passes that perform LLVM IR to IR transforms in preparation for instruction selection.
void addTargetRegisterAllocator(PassManagerWrapper &PMW, bool Optimized) const
Utilities for targets to add passes to the pass manager.
bool isGlobalISelAbortEnabled() const
Check whether or not GlobalISel should abort on error.
Error addMachinePasses(PassManagerWrapper &PMW) const
Add the complete, standard set of LLVM CodeGen passes.
void insertPass(InsertedPassT &&Pass) const
Insert InsertedPass pass after TargetPass pass.
void addPreRewrite(PassManagerWrapper &PMW) const
addPreRewrite - Add passes to the optimized register allocation pipeline after register allocation is...
Error addFastRegAlloc(PassManagerWrapper &PMW) const
addFastRegAlloc - Add the minimum set of target-independent passes that are required for fast registe...
Error buildPipeline(ModulePassManager &MPM, ModuleAnalysisManager &MAM, raw_pwrite_stream &Out, raw_pwrite_stream *DwoOut, CodeGenFileType FileType, MCContext &Ctx) const
Error addRegAssignmentOptimized(PassManagerWrapper &PMW) const
void addPreISel(PassManagerWrapper &PMW) const
{{@ For GlobalISel
Error addCoreISelPasses(PassManagerWrapper &PMW) const
Add the actual instruction selection passes.
void stopAddingInCGSCCOrder(PassManagerWrapper &PMW) const
void addPreLegalizeMachineIR(PassManagerWrapper &PMW) const
This method may be implemented by targets that want to run passes immediately before legalization.
void addCodeGenPrepare(PassManagerWrapper &PMW) const
Add pass to prepare the LLVM IR for code generation.
void addPreEmitPass(PassManagerWrapper &PMW) const
This pass may be implemented by targets that want to run passes immediately before machine code is em...
void addMachineSSAOptimization(PassManagerWrapper &PMW) const
Methods with trivial inline returns are convenient points in the common codegen pass pipeline where t...
void addIRPasses(PassManagerWrapper &PMW) const
Add common target configurable passes that perform LLVM IR to IR transforms following machine indepen...
decltype(std::declval< PassT & >().run( std::declval< MachineFunction & >(), std::declval< MachineFunctionAnalysisManager & >())) is_machine_function_pass_t
void addMachineLateOptimization(PassManagerWrapper &PMW) const
Add passes that optimize machine instructions after register allocation.
Error addLegalizeMachineIR(PassManagerWrapper &PMW) const
This method should install a legalize pass, which converts the instruction sequence into one that can...
PassInstrumentationCallbacks * PIC
CodeGenPassBuilder(TargetMachineT &TM, const CGPassBuilderOption &Opts, PassInstrumentationCallbacks *PIC)
void addPreEmitPass2(PassManagerWrapper &PMW) const
Targets may add passes immediately before machine code is emitted in this callback.
Error addIRTranslator(PassManagerWrapper &PMW) const
This method should install an IR translator pass, which converts from LLVM code to machine instructio...
void addGCPasses(PassManagerWrapper &PMW) const
addGCPasses - Add late codegen passes that analyze code for garbage collection.
void addRegAllocPass(PassManagerWrapper &PMW, bool Optimized) const
addMachinePasses helper to create the target-selected or overriden regalloc pass.
Error addRegBankSelect(PassManagerWrapper &PMW) const
This method should install a register bank selector pass, which assigns register banks to virtual reg...
void addMachineFunctionPass(PassT &&Pass, PassManagerWrapper &PMW, bool Force=false, StringRef Name=PassT::name()) const
void addISelPasses(PassManagerWrapper &PMW) const
High level function that adds all passes necessary to go from llvm IR representation to the MI repres...
void disablePass()
Allow the target to disable a specific pass by default.
Error addInstSelector(PassManagerWrapper &PMW) const
addInstSelector - This method should install an instruction selector pass, which converts from LLVM c...
void addPreRegAlloc(PassManagerWrapper &PMW) const
This method may be implemented by targets that want to run passes immediately before register allocat...
void addPassesToHandleExceptions(PassManagerWrapper &PMW) const
Add passes to lower exception handling for the code generator.
void addBlockPlacement(PassManagerWrapper &PMW) const
Add standard basic block placement passes.
void addAsmPrinterEnd(PassManagerWrapper &PMW) const
void addPreRegBankSelect(PassManagerWrapper &PMW) const
This method may be implemented by targets that want to run passes immediately before the register ban...
void addPreSched2(PassManagerWrapper &PMW) const
This method may be implemented by targets that want to run passes after prolog-epilog insertion and b...
Error addGlobalInstructionSelect(PassManagerWrapper &PMWM) const
This method should install a (global) instruction selector pass, which converts possibly generic inst...
void addAsmPrinterBegin(PassManagerWrapper &PMW) const
void addFunctionPass(PassT &&Pass, PassManagerWrapper &PMW, bool Force=false, StringRef Name=PassT::name()) const
void addILPOpts(PassManagerWrapper &PMW) const
Add passes that optimize instruction level parallelism for out-of-order targets.
decltype(std::declval< PassT & >().run( std::declval< Module & >(), std::declval< ModuleAnalysisManager & >())) is_module_pass_t
void addPostBBSections(PassManagerWrapper &PMW) const
void addPostRewrite(PassManagerWrapper &PMW) const
Add passes to be run immediately after virtual registers are rewritten to physical registers.
void addAsmPrinter(PassManagerWrapper &PMW) const
CodeGenOptLevel getOptLevel() const
PassInstrumentationCallbacks * getPassInstrumentationCallbacks() const
bool reportDiagnosticWhenGlobalISelFallback() const
Check whether or not a diagnostic should be emitted when GlobalISel uses the fallback path.
Lightweight error class with error context and mandatory checking.
static ErrorSuccess success()
Create a success value.
Tagged union holding either a T or a Error.
Error takeError()
Take ownership of the stored error.
This is a fast-path instruction selection class that generates poor code and doesn't support illegal ...
LowerIntrinsics - This pass rewrites calls to the llvm.gcread or llvm.gcwrite intrinsics,...
Performs Loop Strength Reduce Pass.
This class is intended to be used as a base class for asm properties and features specific to the tar...
ExceptionHandling getExceptionHandlingType() const
Context object for machine code objects.
This class manages callbacks registration, as well as provides a way for PassInstrumentation to pass ...
LLVM_ABI StringRef getPassNameForClassName(StringRef ClassName)
Get the pass name for a given pass class name. Empty if no match found.
friend class CodeGenPassBuilder
LLVM_ATTRIBUTE_MINSIZE std::enable_if_t<!std::is_same_v< PassT, PassManager > > addPass(PassT &&Pass)
bool isEmpty() const
Returns if the pass manager contains any passes.
Pass interface - Implemented by all 'passes'.
Pass (for the new pass manager) for printing a Function as LLVM's text IR assembly.
This is used to represent a portion of an LLVM function in a low-level Data Dependence DAG representa...
Represent a constant reference to a string, i.e.
static Expected< StartStopInfo > getStartStopInfo(PassInstrumentationCallbacks &PIC)
Returns pass name in -stop-before or -stop-after NOTE: New pass manager migration only.
static bool willCompleteCodeGenPipeline()
Returns true if none of the -stop-before and -stop-after options is set.
An abstract base class for streams implementations that also support a pwrite operation.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
@ C
The default llvm calling convention, compatible with C.
This is an optimization pass for GlobalISel generic memory operations.
ModuleToFunctionPassAdaptor createModuleToFunctionPassAdaptor(FunctionPassT &&Pass, bool EagerlyInvalidate=false)
A function to deduce a function pass type and wrap it in the templated adaptor.
LLVM_ABI std::error_code inconvertibleErrorCode()
The value returned by this function can be returned from convertToErrorCode for Error values where no...
@ SjLj
setjmp/longjmp based exceptions
@ ZOS
z/OS MVS Exception Handling.
@ None
No exception support.
@ AIX
AIX Exception Handling.
@ DwarfCFI
DWARF-like instruction based exceptions.
@ WinEH
Windows Exception Handling.
@ Wasm
WebAssembly Exception Handling.
Error createStringError(std::error_code EC, char const *Fmt, const Ts &... Vals)
Create formatted StringError object.
PassManager< Loop, LoopAnalysisManager, LoopStandardAnalysisResults &, LPMUpdater & > LoopPassManager
The Loop pass manager.
ModuleToPostOrderCGSCCPassAdaptor createModuleToPostOrderCGSCCPassAdaptor(CGSCCPassT &&Pass)
A function to deduce a function pass type and wrap it in the templated adaptor.
FunctionToLoopPassAdaptor createFunctionToLoopPassAdaptor(LoopPassT &&Pass, bool UseMemorySSA=false)
A function to deduce a loop pass type and wrap it in the templated adaptor.
CGSCCToFunctionPassAdaptor createCGSCCToFunctionPassAdaptor(FunctionPassT &&Pass, bool EagerlyInvalidate=false, bool NoRerun=false)
A function to deduce a function pass type and wrap it in the templated adaptor.
CodeGenFileType
These enums are meant to be passed into addPassesToEmitFile to indicate what type of file to emit,...
FunctionToMachineFunctionPassAdaptor createFunctionToMachineFunctionPassAdaptor(MachineFunctionPassT &&Pass)
PassManager< Module > ModulePassManager
Convenience typedef for a pass manager over modules.
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
FunctionAddr VTableAddr Count
CodeGenOptLevel
Code generation optimization level.
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
Error make_error(ArgTs &&... Args)
Make a Error instance representing failure using the given error info type.
LLVM_ABI raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
PassManager< Function > FunctionPassManager
Convenience typedef for a pass manager over functions.
typename detail::detector< void, Op, Args... >::value_t is_detected
Detects if a given trait holds for some set of arguments 'Args'.
PassManager< MachineFunction > MachineFunctionPassManager
Convenience typedef for a pass manager over functions.
AnalysisManager< Module > ModuleAnalysisManager
Convenience typedef for the Module analysis manager.
LLVM_ABI void reportFatalUsageError(Error Err)
Report a fatal error that does not indicate a bug in LLVM.
Global function merging pass for new pass manager.
A utility pass template to force an analysis result to be available.