003 File Manager
Current Path:
/usr/src/contrib/llvm-project/llvm/include/llvm/Transforms/IPO
usr
/
src
/
contrib
/
llvm-project
/
llvm
/
include
/
llvm
/
Transforms
/
IPO
/
📁
..
📄
AlwaysInliner.h
(1.6 KB)
📄
ArgumentPromotion.h
(1.75 KB)
📄
Attributor.h
(125.79 KB)
📄
CalledValuePropagation.h
(1.36 KB)
📄
ConstantMerge.h
(1.31 KB)
📄
CrossDSOCFI.h
(959 B)
📄
DeadArgumentElimination.h
(5.04 KB)
📄
ElimAvailExtern.h
(1.05 KB)
📄
ForceFunctionAttrs.h
(1.14 KB)
📄
FunctionAttrs.h
(2.93 KB)
📄
FunctionImport.h
(9.74 KB)
📄
GlobalDCE.h
(2.52 KB)
📄
GlobalOpt.h
(1.03 KB)
📄
GlobalSplit.h
(1.14 KB)
📄
HotColdSplitting.h
(2.53 KB)
📄
InferFunctionAttrs.h
(1.18 KB)
📄
Inliner.h
(5.91 KB)
📄
Internalize.h
(3.18 KB)
📄
LowerTypeTests.h
(7.68 KB)
📄
MergeFunctions.h
(1.03 KB)
📄
OpenMPOpt.h
(2.07 KB)
📄
PartialInlining.h
(1004 B)
📄
PassManagerBuilder.h
(10.26 KB)
📄
SCCP.h
(1.18 KB)
📄
SampleProfile.h
(1.31 KB)
📄
StripDeadPrototypes.h
(1.12 KB)
📄
SyntheticCountsPropagation.h
(747 B)
📄
ThinLTOBitcodeWriter.h
(1.34 KB)
📄
WholeProgramDevirt.h
(9.77 KB)
Editing: Inliner.h
//===- Inliner.h - Inliner pass and infrastructure --------------*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #ifndef LLVM_TRANSFORMS_IPO_INLINER_H #define LLVM_TRANSFORMS_IPO_INLINER_H #include "llvm/Analysis/CGSCCPassManager.h" #include "llvm/Analysis/CallGraphSCCPass.h" #include "llvm/Analysis/InlineAdvisor.h" #include "llvm/Analysis/InlineCost.h" #include "llvm/Analysis/LazyCallGraph.h" #include "llvm/IR/PassManager.h" #include "llvm/Transforms/Utils/ImportedFunctionsInliningStatistics.h" #include <utility> namespace llvm { class AssumptionCacheTracker; class CallGraph; class ProfileSummaryInfo; /// This class contains all of the helper code which is used to perform the /// inlining operations that do not depend on the policy. It contains the core /// bottom-up inlining infrastructure that specific inliner passes use. struct LegacyInlinerBase : public CallGraphSCCPass { explicit LegacyInlinerBase(char &ID); explicit LegacyInlinerBase(char &ID, bool InsertLifetime); /// For this class, we declare that we require and preserve the call graph. /// If the derived class implements this method, it should always explicitly /// call the implementation here. void getAnalysisUsage(AnalysisUsage &Info) const override; using llvm::Pass::doInitialization; bool doInitialization(CallGraph &CG) override; /// Main run interface method, this implements the interface required by the /// Pass class. bool runOnSCC(CallGraphSCC &SCC) override; using llvm::Pass::doFinalization; /// Remove now-dead linkonce functions at the end of processing to avoid /// breaking the SCC traversal. bool doFinalization(CallGraph &CG) override; /// This method must be implemented by the subclass to determine the cost of /// inlining the specified call site. If the cost returned is greater than /// the current inline threshold, the call site is not inlined. virtual InlineCost getInlineCost(CallBase &CB) = 0; /// Remove dead functions. /// /// This also includes a hack in the form of the 'AlwaysInlineOnly' flag /// which restricts it to deleting functions with an 'AlwaysInline' /// attribute. This is useful for the InlineAlways pass that only wants to /// deal with that subset of the functions. bool removeDeadFunctions(CallGraph &CG, bool AlwaysInlineOnly = false); /// This function performs the main work of the pass. The default of /// Inlinter::runOnSCC() calls skipSCC() before calling this method, but /// derived classes which cannot be skipped can override that method and call /// this function unconditionally. bool inlineCalls(CallGraphSCC &SCC); private: // Insert @llvm.lifetime intrinsics. bool InsertLifetime = true; protected: AssumptionCacheTracker *ACT; ProfileSummaryInfo *PSI; std::function<const TargetLibraryInfo &(Function &)> GetTLI; ImportedFunctionsInliningStatistics ImportedFunctionsStats; }; /// The inliner pass for the new pass manager. /// /// This pass wires together the inlining utilities and the inline cost /// analysis into a CGSCC pass. It considers every call in every function in /// the SCC and tries to inline if profitable. It can be tuned with a number of /// parameters to control what cost model is used and what tradeoffs are made /// when making the decision. /// /// It should be noted that the legacy inliners do considerably more than this /// inliner pass does. They provide logic for manually merging allocas, and /// doing considerable DCE including the DCE of dead functions. This pass makes /// every attempt to be simpler. DCE of functions requires complex reasoning /// about comdat groups, etc. Instead, it is expected that other more focused /// passes be composed to achieve the same end result. class InlinerPass : public PassInfoMixin<InlinerPass> { public: InlinerPass() = default; ~InlinerPass(); InlinerPass(InlinerPass &&Arg) : ImportedFunctionsStats(std::move(Arg.ImportedFunctionsStats)) {} PreservedAnalyses run(LazyCallGraph::SCC &C, CGSCCAnalysisManager &AM, LazyCallGraph &CG, CGSCCUpdateResult &UR); private: InlineAdvisor &getAdvisor(const ModuleAnalysisManagerCGSCCProxy::Result &MAM, FunctionAnalysisManager &FAM, Module &M); std::unique_ptr<ImportedFunctionsInliningStatistics> ImportedFunctionsStats; Optional<DefaultInlineAdvisor> OwnedDefaultAdvisor; }; /// Module pass, wrapping the inliner pass. This works in conjunction with the /// InlineAdvisorAnalysis to facilitate inlining decisions taking into account /// module-wide state, that need to keep track of inter-inliner pass runs, for /// a given module. An InlineAdvisor is configured and kept alive for the /// duration of the ModuleInlinerWrapperPass::run. class ModuleInlinerWrapperPass : public PassInfoMixin<ModuleInlinerWrapperPass> { public: ModuleInlinerWrapperPass( InlineParams Params = getInlineParams(), bool Debugging = false, InliningAdvisorMode Mode = InliningAdvisorMode::Default, unsigned MaxDevirtIterations = 0); ModuleInlinerWrapperPass(ModuleInlinerWrapperPass &&Arg) = default; PreservedAnalyses run(Module &, ModuleAnalysisManager &); /// Allow adding more CGSCC passes, besides inlining. This should be called /// before run is called, as part of pass pipeline building. CGSCCPassManager &getPM() { return PM; } /// Allow adding module-level analyses benefiting the contained CGSCC passes. template <class T> void addRequiredModuleAnalysis() { MPM.addPass(RequireAnalysisPass<T, Module>()); } private: const InlineParams Params; const InliningAdvisorMode Mode; const unsigned MaxDevirtIterations; CGSCCPassManager PM; ModulePassManager MPM; }; } // end namespace llvm #endif // LLVM_TRANSFORMS_IPO_INLINER_H
Upload File
Create Folder