diff options
author | Easwaran Raman <eraman@google.com> | 2016-06-09 22:23:21 +0000 |
---|---|---|
committer | Easwaran Raman <eraman@google.com> | 2016-06-09 22:23:21 +0000 |
commit | 71069cf67de73a0230df65b04167f814fd4309f3 (patch) | |
tree | b5dd913928b268b7ac09524c158bbb13d7e85688 /llvm/lib/Transforms/IPO/Inliner.cpp | |
parent | b37674dca0cc31a7f7fb1425d4af959bb228cdc9 (diff) | |
download | bcm5719-llvm-71069cf67de73a0230df65b04167f814fd4309f3.tar.gz bcm5719-llvm-71069cf67de73a0230df65b04167f814fd4309f3.zip |
Use ProfileSummaryInfo in inline cost analysis.
Instead of directly using MaxFunctionCount and function entry count to determine callee hotness, use the isHotFunction/isColdFunction methods provided by ProfileSummaryInfo.
Differential revision: http://reviews.llvm.org/D21045
llvm-svn: 272321
Diffstat (limited to 'llvm/lib/Transforms/IPO/Inliner.cpp')
-rw-r--r-- | llvm/lib/Transforms/IPO/Inliner.cpp | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/IPO/Inliner.cpp b/llvm/lib/Transforms/IPO/Inliner.cpp index a3956ad296f..79535ca4978 100644 --- a/llvm/lib/Transforms/IPO/Inliner.cpp +++ b/llvm/lib/Transforms/IPO/Inliner.cpp @@ -20,6 +20,7 @@ #include "llvm/Analysis/BasicAliasAnalysis.h" #include "llvm/Analysis/CallGraph.h" #include "llvm/Analysis/InlineCost.h" +#include "llvm/Analysis/ProfileSummaryInfo.h" #include "llvm/Analysis/TargetLibraryInfo.h" #include "llvm/IR/CallSite.h" #include "llvm/IR/DataLayout.h" @@ -56,6 +57,7 @@ Inliner::Inliner(char &ID, bool InsertLifetime) /// always explicitly call the implementation here. void Inliner::getAnalysisUsage(AnalysisUsage &AU) const { AU.addRequired<AssumptionCacheTracker>(); + AU.addRequired<ProfileSummaryInfoWrapperPass>(); AU.addRequired<TargetLibraryInfoWrapperPass>(); getAAResultsAnalysisUsage(AU); CallGraphSCCPass::getAnalysisUsage(AU); @@ -374,6 +376,7 @@ bool Inliner::runOnSCC(CallGraphSCC &SCC) { bool Inliner::inlineCalls(CallGraphSCC &SCC) { CallGraph &CG = getAnalysis<CallGraphWrapperPass>().getCallGraph(); ACT = &getAnalysis<AssumptionCacheTracker>(); + PSI = getAnalysis<ProfileSummaryInfoWrapperPass>().getPSI(CG.getModule()); auto &TLI = getAnalysis<TargetLibraryInfoWrapperPass>().getTLI(); SmallPtrSet<Function*, 8> SCCFunctions; |