164 cl::desc(
"Enable ML policy for inliner. Currently trained for -Oz only"),
166 "Heuristics-based inliner version"),
168 "Use development mode (runtime-loadable model)"),
170 "Use release mode (AOT-compiled model)")));
176 cl::desc(
"Enable inline deferral during PGO"));
184 cl::desc(
"Perform mandatory inlinings module-wide, before performing "
189 cl::desc(
"Eagerly invalidate more analyses in default pipelines"));
193 cl::desc(
"Enable function merging as part of the optimization pipeline"));
197 cl::desc(
"Run the loop rotation transformation after PGO instrumentation"));
201 cl::desc(
"Trigger crash in optimization pipeline"));
205 cl::desc(
"Enable inter-procedural analyses"));
209 cl::desc(
"Run Partial inlining pass"));
213 cl::desc(
"Run cleanup optimization passes after vectorization"));
220 cl::desc(
"Enable the LoopInterchange Pass"));
224 cl::desc(
"Enable Unroll And Jam Pass"));
228 cl::desc(
"Enable the LoopFlatten Pass"));
232 cl::desc(
"Enable the Instrumentor Pass"));
236 cl::desc(
"Enable DFA jump threading"),
241 cl::desc(
"Enable hot-cold splitting pass"));
245 cl::desc(
"Enable ir outliner pass"));
249 cl::desc(
"Disable pre-instrumentation inliner"));
253 cl::desc(
"Control the amount of inlining in pre-instrumentation inliner "
258 cl::desc(
"Enable the GVN hoisting pass (default = off)"));
262 cl::desc(
"Enable the GVN sinking pass (default = off)"));
265 "enable-jump-table-to-switch",
cl::init(
true),
266 cl::desc(
"Enable JumpTableToSwitch pass (default = true)"));
272 cl::desc(
"Enable control height reduction optimization (CHR)"));
276 cl::desc(
"Indicate the sample profile being used is flattened, i.e., "
277 "no inline hierarchy exists in the profile"));
281 cl::desc(
"Enable lowering of the matrix intrinsics"));
285 cl::desc(
"Enable MergeICmps pass in the optimization pipeline"));
290 "Enable pass to eliminate conditions based on linear constraints"));
294 cl::desc(
"Enable the attributor inter-procedural deduction pass"),
296 "enable all full attributor runs"),
298 "enable all attributor-light runs"),
300 "enable module-wide attributor runs"),
302 "enable module-wide attributor-light runs"),
304 "enable call graph SCC attributor runs"),
306 "enable call graph SCC attributor-light runs"),
308 "disable attributor runs")));
312 cl::desc(
"Enable profile instrumentation sampling (default = off)"));
315 cl::desc(
"Enable the experimental Loop Versioning LICM pass"));
318 "instrument-cold-function-only-path",
cl::init(
""),
319 cl::desc(
"File path for cold function only instrumentation(requires use "
320 "with --pgo-instrument-cold-function-only)"),
326 "enable-devirtualize-speculatively",
327 cl::desc(
"Enable speculative devirtualization optimization"),
360 for (
auto &
C : PeepholeEPCallbacks)
365 for (
auto &
C : LateLoopOptimizationsEPCallbacks)
370 for (
auto &
C : LoopOptimizerEndEPCallbacks)
375 for (
auto &
C : ScalarOptimizerLateEPCallbacks)
380 for (
auto &
C : CGSCCOptimizerLateEPCallbacks)
385 for (
auto &
C : VectorizerStartEPCallbacks)
390 for (
auto &
C : VectorizerEndEPCallbacks)
396 for (
auto &
C : OptimizerEarlyEPCallbacks)
402 for (
auto &
C : OptimizerLastEPCallbacks)
407 for (
auto &
C : FullLinkTimeOptimizationEarlyEPCallbacks)
412 for (
auto &
C : FullLinkTimeOptimizationLastEPCallbacks)
417 for (
auto &
C : PipelineStartEPCallbacks)
422 for (
auto &
C : PipelineEarlySimplificationEPCallbacks)
428 bool IsPreOptimization) {
495 FPM.
addPass(CountVisitsPass());
502 FPM.
addPass(EarlyCSEPass(
true ));
506 SimplifyCFGPass(SimplifyCFGOptions().convertSwitchRangeToICmp(
true)));
507 FPM.
addPass(InstCombinePass());
509 FPM.
addPass(LibCallsShrinkWrapPass());
514 SimplifyCFGPass(SimplifyCFGOptions().convertSwitchRangeToICmp(
true)));
519 FPM.
addPass(ReassociatePass());
535 LPM1.addPass(LoopInstSimplifyPass());
536 LPM1.addPass(LoopSimplifyCFGPass());
544 LPM1.addPass(LICMPass(PTO.LicmMssaOptCap, PTO.LicmMssaNoAccForPromotionCap,
550 LPM1.addPass(LICMPass(PTO.LicmMssaOptCap, PTO.LicmMssaNoAccForPromotionCap,
552 LPM1.addPass(SimpleLoopUnswitchPass());
554 LPM1.addPass(LoopFlattenPass());
556 LPM2.addPass(LoopIdiomRecognizePass());
557 LPM2.addPass(IndVarSimplifyPass());
561 LPM2.addPass(LoopDeletionPass());
570 LPM2.addPass(LoopFullUnrollPass(
Level.getSpeedupLevel(),
572 PTO.ForgetAllSCEVInLoopUnroll));
579 SimplifyCFGPass(SimplifyCFGOptions().convertSwitchRangeToICmp(
true)));
580 FPM.
addPass(InstCombinePass());
604 FPM.
addPass(InstCombinePass());
616 SimplifyCFGPass(SimplifyCFGOptions().convertSwitchRangeToICmp(
true)));
617 FPM.
addPass(InstCombinePass());
630 if (Level.getSpeedupLevel() == 1)
631 return buildO1FunctionSimplificationPipeline(Level,
Phase);
683 isInstrumentedPGOUse()));
718 LPM1.addPass(
LICMPass(PTO.LicmMssaOptCap, PTO.LicmMssaNoAccForPromotionCap,
724 LPM1.addPass(
LICMPass(PTO.LicmMssaOptCap, PTO.LicmMssaNoAccForPromotionCap,
738 LPM2.addPass(std::move(ExtraPasses));
754 PTO.ForgetAllSCEVInLoopUnroll));
818 LICMPass(PTO.LicmMssaOptCap, PTO.LicmMssaNoAccForPromotionCap,
827 .convertSwitchRangeToICmp(
true)
828 .convertSwitchToArithmetic(
true)
829 .hoistCommonInsts(
true)
830 .sinkCommonInsts(
true)));
866 FPM.
addPass(SimplifyCFGPass(SimplifyCFGOptions().convertSwitchRangeToICmp(
868 FPM.
addPass(InstCombinePass());
872 std::move(FPM), PTO.EagerlyInvalidateAnalyses));
889 PTO.EagerlyInvalidateAnalyses));
895 bool IsCS,
bool AtomicCounterUpdate,
896 std::string ProfileFile,
897 std::string ProfileRemappingFile) {
900 if (!RunProfileGen) {
901 assert(!ProfileFile.empty() &&
"Profile use expecting a profile file!");
903 PGOInstrumentationUse(ProfileFile, ProfileRemappingFile, IsCS, FS));
906 MPM.
addPass(RequireAnalysisPass<ProfileSummaryAnalysis, Module>());
914 addPostPGOLoopRotation(MPM, Level);
917 if (!ProfileFile.empty())
918 Options.InstrProfileOutput = ProfileFile;
920 Options.DoCounterPromotion =
true;
921 Options.UseBFIInPromotion = IsCS;
926 Options.DoCounterPromotion =
false;
928 Options.Atomic = AtomicCounterUpdate;
933 bool RunProfileGen,
bool IsCS,
934 bool AtomicCounterUpdate,
935 std::string ProfileFile,
936 std::string ProfileRemappingFile) {
937 if (!RunProfileGen) {
938 assert(!ProfileFile.empty() &&
"Profile use expecting a profile file!");
952 if (!ProfileFile.empty())
953 Options.InstrProfileOutput = ProfileFile;
955 Options.DoCounterPromotion =
false;
956 Options.UseBFIInPromotion = IsCS;
957 Options.Atomic = AtomicCounterUpdate;
969 if (PTO.InlinerThreshold == -1)
1042 PTO.EagerlyInvalidateAnalyses,
true));
1102 PTO.EagerlyInvalidateAnalyses));
1118 "Should not be used for O0 pipeline");
1121 "FullLTOPostLink shouldn't call buildModuleSimplificationPipeline!");
1135 bool LoadSampleProfile =
1176 std::move(EarlyFPM), PTO.EagerlyInvalidateAnalyses));
1179 if (LoadSampleProfile) {
1183 PGOOpt->ProfileFile, PGOOpt->ProfileRemappingFile,
Phase, FS));
1239 PTO.EagerlyInvalidateAnalyses));
1244 const bool IsCtxProfGen =
1246 const bool IsPGOPreLink = !IsCtxProfGen && PGOOpt && IsPreLink;
1247 const bool IsPGOInstrGen =
1249 const bool IsPGOInstrUse =
1251 const bool IsMemprofUse = IsPGOPreLink && !PGOOpt->MemoryProfile.empty();
1255 "Enabling both instrumented PGO and contextual instrumentation is not "
1261 "--instrument-cold-function-only-path is provided but "
1262 "--pgo-instrument-cold-function-only is not enabled");
1267 if (IsPGOInstrGen || IsPGOInstrUse || IsMemprofUse || IsCtxProfGen ||
1268 IsCtxProfUse || IsColdFuncOnlyInstrGen)
1269 addPreInlinerPasses(MPM, Level,
Phase);
1272 if (IsPGOInstrGen || IsPGOInstrUse) {
1273 addPGOInstrPasses(MPM, Level,
1275 false, PGOOpt->AtomicCounterUpdate,
1276 PGOOpt->ProfileFile, PGOOpt->ProfileRemappingFile);
1277 }
else if (IsCtxProfGen || IsCtxProfUse) {
1296 addPostPGOLoopRotation(MPM, Level);
1298 }
else if (IsColdFuncOnlyInstrGen) {
1299 addPGOInstrPasses(MPM, Level,
true,
false,
1305 if (IsPGOInstrGen || IsPGOInstrUse || IsCtxProfGen)
1396 FPM.
addPass(InstCombinePass());
1399 ExtraFunctionPassManager<ShouldRunExtraVectorPasses> ExtraPasses;
1406 ExtraPasses.
addPass(EarlyCSEPass());
1407 ExtraPasses.
addPass(CorrelatedValuePropagationPass());
1408 ExtraPasses.
addPass(InstCombinePass());
1410 LPM.addPass(LICMPass(PTO.LicmMssaOptCap, PTO.LicmMssaNoAccForPromotionCap,
1412 LPM.addPass(SimpleLoopUnswitchPass( Level ==
1417 SimplifyCFGPass(SimplifyCFGOptions().convertSwitchRangeToICmp(
true)));
1418 ExtraPasses.
addPass(InstCombinePass());
1419 FPM.
addPass(std::move(ExtraPasses));
1431 FPM.
addPass(SimplifyCFGPass(SimplifyCFGOptions()
1432 .forwardSwitchCondToPhi(
true)
1433 .convertSwitchRangeToICmp(
true)
1434 .convertSwitchToArithmetic(
true)
1435 .convertSwitchToLookupTable(
true)
1436 .needCanonicalLoops(
false)
1437 .hoistCommonInsts(
true)
1438 .sinkCommonInsts(
true)));
1442 FPM.
addPass(InstCombinePass());
1447 if (PTO.SLPVectorization) {
1448 FPM.
addPass(SLPVectorizerPass());
1454 FPM.
addPass(VectorCombinePass());
1457 FPM.
addPass(InstCombinePass());
1467 LoopUnrollAndJamPass(
Level.getSpeedupLevel())));
1469 FPM.
addPass(LoopUnrollPass(LoopUnrollOptions(
1470 Level.getSpeedupLevel(), !PTO.LoopUnrolling,
1471 PTO.ForgetAllSCEVInLoopUnroll)));
1472 FPM.
addPass(WarnMissedTransformationsPass());
1491 FPM.
addPass(InferAlignmentPass());
1492 FPM.
addPass(InstCombinePass());
1501 LICMPass(PTO.LicmMssaOptCap, PTO.LicmMssaNoAccForPromotionCap,
1507 FPM.
addPass(AlignmentFromAssumptionsPass());
1543 addPGOInstrPasses(MPM, Level,
true,
1544 true, PGOOpt->AtomicCounterUpdate,
1545 PGOOpt->CSProfileGenFile, PGOOpt->ProfileRemappingFile);
1547 addPGOInstrPasses(MPM, Level,
false,
1548 true, PGOOpt->AtomicCounterUpdate,
1549 PGOOpt->ProfileFile, PGOOpt->ProfileRemappingFile);
1582 LICMPass(PTO.LicmMssaOptCap, PTO.LicmMssaNoAccForPromotionCap,
1621 if (PTO.LoopInterchange)
1642 addVectorPasses(Level, OptimizePM, LTOPhase);
1674 .convertSwitchRangeToICmp(
true)
1675 .convertSwitchToArithmetic(
true)
1676 .speculateUnpredictables(
true)
1677 .hoistLoadsStoresWithCondFaulting(
true)));
1681 PTO.EagerlyInvalidateAnalyses));
1716 if (PTO.MergeFunctions)
1734 PTO.DevirtualizeSpeculatively));
1783 if (PGOOpt && PGOOpt->DebugInfoForProfiling)
1795 if (PGOOpt && PGOOpt->PseudoProbeForProfiling &&
1803 addRequiredLTOPreLinkPasses(MPM);
1878 if (PGOOpt && PGOOpt->DebugInfoForProfiling)
1893 addRequiredLTOPreLinkPasses(MPM);
1907 if (PGOOpt && PGOOpt->PseudoProbeForProfiling &&
1922 addRequiredLTOPreLinkPasses(MPM);
1941 if (ImportSummary) {
2056 PGOOpt->ProfileRemappingFile,
2074 if (Level.getSpeedupLevel() > 1) {
2165 if (Level.getSpeedupLevel() > 1)
2170 PTO.EagerlyInvalidateAnalyses));
2231 addPGOInstrPasses(MPM, Level,
true,
2232 true, PGOOpt->AtomicCounterUpdate,
2233 PGOOpt->CSProfileGenFile, PGOOpt->ProfileRemappingFile);
2235 addPGOInstrPasses(MPM, Level,
false,
2236 true, PGOOpt->AtomicCounterUpdate,
2237 PGOOpt->ProfileFile, PGOOpt->ProfileRemappingFile);
2250 PTO.EagerlyInvalidateAnalyses));
2267 LICMPass(PTO.LicmMssaOptCap, PTO.LicmMssaNoAccForPromotionCap,
2296 PTO.ForgetAllSCEVInLoopUnroll));
2315 PTO.EagerlyInvalidateAnalyses));
2346 .convertSwitchRangeToICmp(
true)
2347 .convertSwitchToArithmetic(
true)
2348 .hoistCommonInsts(
true)
2349 .speculateUnpredictables(
true)));
2358 if (PTO.MergeFunctions)
2363 if (PTO.CallGraphProfile)
2386 "buildO0DefaultPipeline should only be used with O0");
2396 if (PGOOpt && PGOOpt->PseudoProbeForProfiling)
2404 false, PGOOpt->AtomicCounterUpdate, PGOOpt->ProfileFile,
2405 PGOOpt->ProfileRemappingFile);
2413 if (PGOOpt && PGOOpt->DebugInfoForProfiling)
2420 PGOOpt->ProfileRemappingFile,
2438 if (PTO.MergeFunctions)
2445 if (!CGSCCOptimizerLateEPCallbacks.empty()) {
2451 if (!LateLoopOptimizationsEPCallbacks.empty()) {
2454 if (!LPM.isEmpty()) {
2459 if (!LoopOptimizerEndEPCallbacks.empty()) {
2462 if (!LPM.isEmpty()) {
2467 if (!ScalarOptimizerLateEPCallbacks.empty()) {
2476 if (!VectorizerStartEPCallbacks.empty()) {
2483 if (!VectorizerEndEPCallbacks.empty()) {
2503 addRequiredLTOPreLinkPasses(MPM);
2521 TM->registerEarlyDefaultAliasAnalyses(
AA);
2542 TM->registerDefaultAliasAnalyses(
AA);
2547bool PassBuilder::isInstrumentedPGOUse()
const {
aarch64 falkor hwpf fix Falkor HW Prefetch Fix Late Phase
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
AggressiveInstCombiner - Combine expression patterns to form expressions with fewer,...
Provides passes to inlining "always_inline" functions.
This is the interface for LLVM's primary stateless and local alias analysis.
This file provides the interface for LLVM's Call Graph Profile pass.
This header provides classes for managing passes over SCCs of the call graph.
#define clEnumValN(ENUMVAL, FLAGNAME, DESC)
This file provides the interface for a simple, fast CSE pass.
This file provides a pass which clones the current module and runs the provided pass pipeline on the ...
Super simple passes to force specific function attrs from the commandline into the IR for debugging p...
Provides passes for computing function attributes based on interprocedural analyses.
This file provides the interface for LLVM's Global Value Numbering pass which eliminates fully redund...
This is the interface for a simple mod/ref and alias analysis over globals.
AcceleratorCodeSelection - Identify all functions reachable from a kernel, removing those that are un...
This header defines various interfaces for pass management in LLVM.
Interfaces for passes which infer implicit function attributes from the name and signature of functio...
This file provides the primary interface to the instcombine pass.
Defines passes for running instruction simplification across chunks of IR.
This file provides the interface for LLVM's PGO Instrumentation lowering pass.
See the comments on JumpThreadingPass.
This file implements the Loop Fusion pass.
This header defines the LoopLoadEliminationPass object.
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.
The header file for the LowerExpectIntrinsic pass as used by the new pass manager.
This pass performs merges of loads and stores on both sides of a.
This file provides the interface for LLVM's Global Value Numbering pass.
This header enumerates the LLVM-provided high-level optimization levels.
This file provides the interface for IR based instrumentation passes ( (profile-gen,...
Define option tunables for PGO.
static bool isThinLTOPostLink(ThinOrFullLTOPhase Phase)
static void addAnnotationRemarksPass(ModulePassManager &MPM)
static CoroConditionalWrapper buildCoroWrapper(ThinOrFullLTOPhase Phase)
static bool isFullLTOPostLink(ThinOrFullLTOPhase Phase)
static bool isThinLTOPreLink(ThinOrFullLTOPhase Phase)
static bool isLTOPreLink(ThinOrFullLTOPhase Phase)
static void instructionCountersPass(ModulePassManager &MPM, bool IsPreOptimization)
static bool isFullLTOPreLink(ThinOrFullLTOPhase Phase)
static bool isLTOPostLink(ThinOrFullLTOPhase Phase)
This file implements relative lookup table converter that converts lookup tables to relative lookup t...
This file provides the interface for LLVM's Scalar Replacement of Aggregates pass.
This file provides the interface for the pseudo probe implementation for AutoFDO.
This file provides the interface for the sampled PGO loader pass.
This is the interface for a metadata-based scoped no-alias analysis.
This file provides the interface for the pass responsible for both simplifying and canonicalizing the...
This file defines the 'Statistic' class, which is designed to be an easy way to expose various metric...
This is the interface for a metadata-based TBAA.
Defines the virtual file system interface vfs::FileSystem.
A manager for alias analyses.
A module pass that rewrites heap allocations to use token-enabled allocation functions based on vario...
Inlines functions marked as "always_inline".
Assign a GUID to functions as metadata.
Analysis pass providing a never-invalidated alias analysis result.
Simple pass that canonicalizes aliases.
A pass that merges duplicate global constants into a single constant.
This class implements a trivial dead store elimination.
Eliminate dead arguments (and return values) from functions.
A pass that transforms external global definitions into declarations.
Pass embeds a copy of the module optimized with the provided pass pipeline into a global variable.
Statistics pass for the FunctionPropertiesAnalysis results.
The core GVN pass object.
Pass to remove unused function declarations.
Optimize globals that never have their address taken.
Pass to perform split of global variables.
Analysis pass providing a never-invalidated alias analysis result.
Pass to outline cold regions.
Pass to perform interprocedural constant propagation.
Pass to outline similar regions.
Run instruction simplification across each instruction in the function.
Instrumentation based profiling lowering pass.
This pass performs 'jump threading', which looks at blocks that have multiple predecessors and multip...
Performs Loop Invariant Code Motion Pass.
Loop unroll pass that only does full loop unrolling and peeling.
Performs Loop Idiom Recognize Pass.
Performs Loop Inst Simplify Pass.
A simple loop rotation transformation.
Performs basic CFG simplifications to assist other loop passes.
A pass that does profile-guided sinking of instructions into loops.
A simple loop rotation transformation.
Loop unroll pass that will support both full and partial unrolling.
Strips MemProf attributes and metadata.
Merge identical functions.
The module inliner pass for the new pass manager.
Module pass, wrapping the inliner pass.
void addModulePass(T Pass)
Add a module pass that runs before the CGSCC passes.
Class to hold module path string table and global value map, and encapsulate methods for operating on...
bool withSupportsHotColdNew() const
Simple pass that provides a name to every anonymous globals.
Additional 'norecurse' attribute deduction during postlink LTO phase.
OpenMP optimizations pass.
static LLVM_ABI const OptimizationLevel O3
Optimize for fast execution as much as possible.
static LLVM_ABI const OptimizationLevel O0
Disable as many optimizations as possible.
static LLVM_ABI const OptimizationLevel O2
Optimize for fast execution as much as possible without triggering significant incremental compile ti...
static LLVM_ABI const OptimizationLevel O1
Optimize quickly without destroying debuggability.
static LLVM_ABI bool isCtxIRPGOInstrEnabled()
The instrumentation (profile-instr-gen) pass for IR based PGO.
The instrumentation (profile-instr-gen) pass for IR based PGO.
The profile annotation (profile-instr-use) pass for IR based PGO.
The profile size based optimization pass for memory intrinsics.
Pass to remove unused function declarations.
LLVM_ABI void invokeFullLinkTimeOptimizationLastEPCallbacks(ModulePassManager &MPM, OptimizationLevel Level)
LLVM_ABI ModuleInlinerWrapperPass buildInlinerPipeline(OptimizationLevel Level, ThinOrFullLTOPhase Phase)
Construct the module pipeline that performs inlining as well as the inlining-driven cleanups.
LLVM_ABI void invokeOptimizerEarlyEPCallbacks(ModulePassManager &MPM, OptimizationLevel Level, ThinOrFullLTOPhase Phase)
LLVM_ABI void invokeVectorizerStartEPCallbacks(FunctionPassManager &FPM, OptimizationLevel Level)
LLVM_ABI AAManager buildDefaultAAPipeline()
Build the default AAManager with the default alias analysis pipeline registered.
LLVM_ABI void invokeCGSCCOptimizerLateEPCallbacks(CGSCCPassManager &CGPM, OptimizationLevel Level)
LLVM_ABI ModulePassManager buildThinLTOPreLinkDefaultPipeline(OptimizationLevel Level)
Build a pre-link, ThinLTO-targeting default optimization pipeline to a pass manager.
LLVM_ABI void addPGOInstrPassesForO0(ModulePassManager &MPM, bool RunProfileGen, bool IsCS, bool AtomicCounterUpdate, std::string ProfileFile, std::string ProfileRemappingFile)
Add PGOInstrumenation passes for O0 only.
LLVM_ABI void invokeScalarOptimizerLateEPCallbacks(FunctionPassManager &FPM, OptimizationLevel Level)
LLVM_ABI ModulePassManager buildPerModuleDefaultPipeline(OptimizationLevel Level, ThinOrFullLTOPhase Phase=ThinOrFullLTOPhase::None)
Build a per-module default optimization pipeline.
LLVM_ABI void invokePipelineStartEPCallbacks(ModulePassManager &MPM, OptimizationLevel Level)
LLVM_ABI void invokeVectorizerEndEPCallbacks(FunctionPassManager &FPM, OptimizationLevel Level)
LLVM_ABI ModulePassManager buildO0DefaultPipeline(OptimizationLevel Level, ThinOrFullLTOPhase Phase=ThinOrFullLTOPhase::None)
Build an O0 pipeline with the minimal semantically required passes.
LLVM_ABI FunctionPassManager buildFunctionSimplificationPipeline(OptimizationLevel Level, ThinOrFullLTOPhase Phase)
Construct the core LLVM function canonicalization and simplification pipeline.
LLVM_ABI void invokePeepholeEPCallbacks(FunctionPassManager &FPM, OptimizationLevel Level)
LLVM_ABI void invokePipelineEarlySimplificationEPCallbacks(ModulePassManager &MPM, OptimizationLevel Level, ThinOrFullLTOPhase Phase)
LLVM_ABI void invokeLoopOptimizerEndEPCallbacks(LoopPassManager &LPM, OptimizationLevel Level)
LLVM_ABI ModulePassManager buildLTODefaultPipeline(OptimizationLevel Level, ModuleSummaryIndex *ExportSummary)
Build an LTO default optimization pipeline to a pass manager.
LLVM_ABI ModulePassManager buildModuleInlinerPipeline(OptimizationLevel Level, ThinOrFullLTOPhase Phase)
Construct the module pipeline that performs inlining with module inliner pass.
LLVM_ABI ModulePassManager buildThinLTODefaultPipeline(OptimizationLevel Level, const ModuleSummaryIndex *ImportSummary)
Build a ThinLTO default optimization pipeline to a pass manager.
LLVM_ABI void invokeLateLoopOptimizationsEPCallbacks(LoopPassManager &LPM, OptimizationLevel Level)
LLVM_ABI void invokeFullLinkTimeOptimizationEarlyEPCallbacks(ModulePassManager &MPM, OptimizationLevel Level)
LLVM_ABI ModulePassManager buildFatLTODefaultPipeline(OptimizationLevel Level, bool ThinLTO, bool EmitSummary)
Build a fat object default optimization pipeline.
LLVM_ABI ModulePassManager buildModuleSimplificationPipeline(OptimizationLevel Level, ThinOrFullLTOPhase Phase)
Construct the core LLVM module canonicalization and simplification pipeline.
LLVM_ABI ModulePassManager buildModuleOptimizationPipeline(OptimizationLevel Level, ThinOrFullLTOPhase LTOPhase)
Construct the core LLVM module optimization pipeline.
LLVM_ABI void invokeOptimizerLastEPCallbacks(ModulePassManager &MPM, OptimizationLevel Level, ThinOrFullLTOPhase Phase)
LLVM_ABI ModulePassManager buildLTOPreLinkDefaultPipeline(OptimizationLevel Level)
Build a pre-link, LTO-targeting default optimization pipeline to a pass manager.
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.
unsigned LicmMssaNoAccForPromotionCap
Tuning option to disable promotion to scalars in LICM with MemorySSA, if the number of access is too ...
bool SLPVectorization
Tuning option to enable/disable slp loop vectorization, set based on opt level.
bool DevirtualizeSpeculatively
int InlinerThreshold
Tuning option to override the default inliner threshold.
bool LoopFusion
Tuning option to enable/disable loop fusion. Its default value is false.
bool EagerlyInvalidateAnalyses
bool CallGraphProfile
Tuning option to enable/disable call graph profile.
bool MergeFunctions
Tuning option to enable/disable function merging.
bool ForgetAllSCEVInLoopUnroll
Tuning option to forget all SCEV loops in LoopUnroll.
unsigned LicmMssaOptCap
Tuning option to cap the number of calls to retrive clobbering accesses in MemorySSA,...
bool LoopInterleaving
Tuning option to set loop interleaving on/off, set based on opt level.
LLVM_ABI PipelineTuningOptions()
Constructor sets pipeline tuning defaults based on cl::opts.
bool LoopUnrolling
Tuning option to enable/disable loop unrolling. Its default value is true.
bool LoopInterchange
Tuning option to enable/disable loop interchange.
bool LoopVectorization
Tuning option to enable/disable loop vectorization, set based on opt level.
Reassociate commutative expressions.
A pass to do RPO deduction and propagation of function attributes.
This pass performs function-level constant propagation and merging.
The sample profiler data loader pass.
Analysis pass providing a never-invalidated alias analysis result.
This pass transforms loops that contain branches or switches on loop- invariant conditions to have mu...
A pass to simplify and canonicalize the CFG of a function.
Analysis pass providing a never-invalidated alias analysis result.
Optimize scalar/vector interactions in IR using target cost models.
Interfaces for registering analysis passes, producing common pass manager configurations,...
Abstract Attribute helper functions.
@ C
The default llvm calling convention, compatible with C.
ValuesClass values(OptsTy... Options)
Helper to build a ValuesClass by forwarding a variable number of arguments as an initializer list to ...
initializer< Ty > init(const Ty &Val)
@ All
Drop only llvm.assumes using type test value.
This is an optimization pass for GlobalISel generic memory operations.
LLVM_ABI cl::opt< bool > EnableKnowledgeRetention
static cl::opt< bool > RunNewGVN("enable-newgvn", cl::init(false), cl::Hidden, cl::desc("Run the NewGVN pass"))
static cl::opt< bool > DisablePreInliner("disable-preinline", cl::init(false), cl::Hidden, cl::desc("Disable pre-instrumentation inliner"))
static cl::opt< bool > PerformMandatoryInliningsFirst("mandatory-inlining-first", cl::init(false), cl::Hidden, cl::desc("Perform mandatory inlinings module-wide, before performing " "inlining"))
static cl::opt< bool > RunPartialInlining("enable-partial-inlining", cl::init(false), cl::Hidden, cl::desc("Run Partial inlining pass"))
static cl::opt< bool > EnableGVNSink("enable-gvn-sink", cl::desc("Enable the GVN sinking pass (default = off)"))
static cl::opt< bool > EnableModuleInliner("enable-module-inliner", cl::init(false), cl::Hidden, cl::desc("Enable module inliner"))
static cl::opt< bool > EnableEagerlyInvalidateAnalyses("eagerly-invalidate-analyses", cl::init(true), cl::Hidden, cl::desc("Eagerly invalidate more analyses in default pipelines"))
static cl::opt< bool > EnableMatrix("enable-matrix", cl::init(false), cl::Hidden, cl::desc("Enable lowering of the matrix intrinsics"))
ModuleToFunctionPassAdaptor createModuleToFunctionPassAdaptor(FunctionPassT &&Pass, bool EagerlyInvalidate=false)
A function to deduce a function pass type and wrap it in the templated adaptor.
cl::opt< std::string > UseCtxProfile("use-ctx-profile", cl::init(""), cl::Hidden, cl::desc("Use the specified contextual profile file"))
static cl::opt< bool > EnableSampledInstr("enable-sampled-instrumentation", cl::init(false), cl::Hidden, cl::desc("Enable profile instrumentation sampling (default = off)"))
static cl::opt< bool > EnableLoopFlatten("enable-loop-flatten", cl::init(false), cl::Hidden, cl::desc("Enable the LoopFlatten Pass"))
static cl::opt< InliningAdvisorMode > UseInlineAdvisor("enable-ml-inliner", cl::init(InliningAdvisorMode::Default), cl::Hidden, cl::desc("Enable ML policy for inliner. Currently trained for -Oz only"), cl::values(clEnumValN(InliningAdvisorMode::Default, "default", "Heuristics-based inliner version"), clEnumValN(InliningAdvisorMode::Development, "development", "Use development mode (runtime-loadable model)"), clEnumValN(InliningAdvisorMode::Release, "release", "Use release mode (AOT-compiled model)")))
static cl::opt< bool > EnableJumpTableToSwitch("enable-jump-table-to-switch", cl::init(true), cl::desc("Enable JumpTableToSwitch pass (default = true)"))
PassManager< LazyCallGraph::SCC, CGSCCAnalysisManager, LazyCallGraph &, CGSCCUpdateResult & > CGSCCPassManager
The CGSCC pass manager.
static cl::opt< bool > EnableUnrollAndJam("enable-unroll-and-jam", cl::init(false), cl::Hidden, cl::desc("Enable Unroll And Jam Pass"))
ThinOrFullLTOPhase
This enumerates the LLVM full LTO or ThinLTO optimization phases.
@ FullLTOPreLink
Full LTO prelink phase.
@ ThinLTOPostLink
ThinLTO postlink (backend compile) phase.
@ None
No LTO/ThinLTO behavior needed.
@ FullLTOPostLink
Full LTO postlink (backend compile) phase.
@ ThinLTOPreLink
ThinLTO prelink (summary) phase.
PassManager< Loop, LoopAnalysisManager, LoopStandardAnalysisResults &, LPMUpdater & > LoopPassManager
The Loop pass manager.
static cl::opt< bool > EnableConstraintElimination("enable-constraint-elimination", cl::init(true), cl::Hidden, cl::desc("Enable pass to eliminate conditions based on linear constraints"))
ModuleToPostOrderCGSCCPassAdaptor createModuleToPostOrderCGSCCPassAdaptor(CGSCCPassT &&Pass)
A function to deduce a function pass type and wrap it in the templated adaptor.
static cl::opt< bool > EnablePGOInlineDeferral("enable-npm-pgo-inline-deferral", cl::init(true), cl::Hidden, cl::desc("Enable inline deferral during PGO"))
Flag to enable inline deferral during PGO.
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.
LLVM_ABI cl::opt< bool > ForgetSCEVInLoopUnroll
PassManager< Module > ModulePassManager
Convenience typedef for a pass manager over modules.
static cl::opt< bool > EnablePostPGOLoopRotation("enable-post-pgo-loop-rotation", cl::init(true), cl::Hidden, cl::desc("Run the loop rotation transformation after PGO instrumentation"))
LLVM_ABI bool AreStatisticsEnabled()
Check if statistics are enabled.
static cl::opt< std::string > InstrumentColdFuncOnlyPath("instrument-cold-function-only-path", cl::init(""), cl::desc("File path for cold function only instrumentation(requires use " "with --pgo-instrument-cold-function-only)"), cl::Hidden)
static cl::opt< bool > EnableGlobalAnalyses("enable-global-analyses", cl::init(true), cl::Hidden, cl::desc("Enable inter-procedural analyses"))
static cl::opt< bool > EnableDFAJumpThreading("enable-dfa-jump-thread", cl::desc("Enable DFA jump threading"), cl::init(false), cl::Hidden)
static cl::opt< bool > FlattenedProfileUsed("flattened-profile-used", cl::init(false), cl::Hidden, cl::desc("Indicate the sample profile being used is flattened, i.e., " "no inline hierarchy exists in the profile"))
static cl::opt< AttributorRunOption > AttributorRun("attributor-enable", cl::Hidden, cl::init(AttributorRunOption::NONE), cl::desc("Enable the attributor inter-procedural deduction pass"), cl::values(clEnumValN(AttributorRunOption::FULL, "full", "enable all full attributor runs"), clEnumValN(AttributorRunOption::LIGHT, "light", "enable all attributor-light runs"), clEnumValN(AttributorRunOption::MODULE, "module", "enable module-wide attributor runs"), clEnumValN(AttributorRunOption::MODULE_LIGHT, "module-light", "enable module-wide attributor-light runs"), clEnumValN(AttributorRunOption::CGSCC, "cgscc", "enable call graph SCC attributor runs"), clEnumValN(AttributorRunOption::CGSCC_LIGHT, "cgscc-light", "enable call graph SCC attributor-light runs"), clEnumValN(AttributorRunOption::NONE, "none", "disable attributor runs")))
static cl::opt< bool > EnableLoopInterchange("enable-loopinterchange", cl::init(true), cl::Hidden, cl::desc("Enable the LoopInterchange Pass"))
static cl::opt< bool > ExtraVectorizerPasses("extra-vectorizer-passes", cl::init(false), cl::Hidden, cl::desc("Run cleanup optimization passes after vectorization"))
static cl::opt< bool > EnableHotColdSplit("hot-cold-split", cl::desc("Enable hot-cold splitting pass"))
cl::opt< bool > EnableMemProfContextDisambiguation
Enable MemProf context disambiguation for thin link.
static cl::opt< bool > TriggerCrash("opt-pipeline-trigger-crash", cl::init(false), cl::Hidden, cl::desc("Trigger crash in optimization pipeline"))
PassManager< Function > FunctionPassManager
Convenience typedef for a pass manager over functions.
LLVM_ABI InlineParams getInlineParams()
Generate the parameters to tune the inline cost analysis based only on the commandline options.
cl::opt< bool > PGOInstrumentColdFunctionOnly
static cl::opt< bool > EnableCHR("enable-chr", cl::init(true), cl::Hidden, cl::desc("Enable control height reduction optimization (CHR)"))
static cl::opt< bool > EnableMergeFunctions("enable-merge-functions", cl::init(false), cl::Hidden, cl::desc("Enable function merging as part of the optimization pipeline"))
static cl::opt< bool > EnableDevirtualizeSpeculatively("enable-devirtualize-speculatively", cl::desc("Enable speculative devirtualization optimization"), cl::init(false))
static cl::opt< bool > EnableGVNHoist("enable-gvn-hoist", cl::desc("Enable the GVN hoisting pass (default = off)"))
LLVM_ABI cl::opt< unsigned > SetLicmMssaNoAccForPromotionCap
LLVM_ABI InlineParams getInlineParamsFromOptLevel(unsigned OptLevel)
Generate the parameters to tune the inline cost analysis based on command line options.
static cl::opt< bool > EnableIROutliner("ir-outliner", cl::init(false), cl::Hidden, cl::desc("Enable ir outliner pass"))
static cl::opt< int > PreInlineThreshold("preinline-threshold", cl::Hidden, cl::init(75), cl::desc("Control the amount of inlining in pre-instrumentation inliner " "(default = 75)"))
static cl::opt< bool > UseLoopVersioningLICM("enable-loop-versioning-licm", cl::init(false), cl::Hidden, cl::desc("Enable the experimental Loop Versioning LICM pass"))
cl::opt< unsigned > MaxDevirtIterations("max-devirt-iterations", cl::ReallyHidden, cl::init(4))
LLVM_ABI cl::opt< unsigned > SetLicmMssaOptCap
static cl::opt< bool > EnableInstrumentor("enable-instrumentor", cl::init(false), cl::Hidden, cl::desc("Enable the Instrumentor Pass"))
static cl::opt< bool > EnableMergeICmps("enable-mergeicmps", cl::init(true), cl::Hidden, cl::desc("Enable MergeICmps pass in the optimization pipeline"))
A DCE pass that assumes instructions are dead until proven otherwise.
This pass attempts to minimize the number of assume without loosing any information.
A more lightweight version of the Attributor which only runs attribute inference but no simplificatio...
A more lightweight version of the Attributor which only runs attribute inference but no simplificatio...
Hoist/decompose integer division and remainder instructions to enable CFG improvements and better cod...
A simple and fast domtree-based CSE pass.
Pass which forces specific function attributes into the IR, primarily as a debugging tool.
A simple and fast domtree-based GVN pass to hoist common expressions from sibling branches.
Uses an "inverted" value numbering to decide the similarity of expressions and sinks similar expressi...
A set of parameters to control various transforms performed by IPSCCP pass.
A pass which infers function attributes from the names and signatures of function declarations in a m...
Provides context on when an inline advisor is constructed in the pipeline (e.g., link phase,...
Thresholds to tune inline cost analysis.
std::optional< int > OptSizeHintThreshold
Threshold to use for callees with inline hint, when the caller is optimized for size.
std::optional< int > HotCallSiteThreshold
Threshold to use when the callsite is considered hot.
int DefaultThreshold
The default threshold to start with for a callee.
std::optional< bool > EnableDeferral
Indicate whether we should allow inline deferral.
std::optional< int > HintThreshold
Threshold to use for callees with inline hint.
Options for the frontend instrumentation based profiling pass.
A no-op pass template which simply forces a specific analysis result to be invalidated.
Pass to forward loads in a loop around the backedge to subsequent iterations.
A set of parameters used to control various transforms performed by the LoopUnroll pass.
Computes function attributes in post-order over the call graph.
A utility pass template to force an analysis result to be available.