diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/Analysis/InlineCost.cpp | 36 | ||||
| -rw-r--r-- | lib/Transforms/IPO/InlineAlways.cpp | 5 | ||||
| -rw-r--r-- | lib/Transforms/IPO/InlineSimple.cpp | 3 | ||||
| -rw-r--r-- | lib/Transforms/IPO/Inliner.cpp | 10 | 
4 files changed, 6 insertions, 48 deletions
| diff --git a/lib/Analysis/InlineCost.cpp b/lib/Analysis/InlineCost.cpp index 09e6648..140e7da 100644 --- a/lib/Analysis/InlineCost.cpp +++ b/lib/Analysis/InlineCost.cpp @@ -383,39 +383,3 @@ float InlineCostAnalyzer::getInlineFudgeFactor(CallSite CS) {      Factor += 1.5f;    return Factor;  } - -/// growCachedCostInfo - update the cached cost info for Caller after Callee has -/// been inlined. -void -InlineCostAnalyzer::growCachedCostInfo(Function* Caller, Function* Callee) { -  FunctionInfo &CallerFI = CachedFunctionInfo[Caller]; - -  // For small functions we prefer to recalculate the cost for better accuracy. -  if (!CallerFI.Metrics.NumBlocks || CallerFI.Metrics.NumInsts < 100) { -    resetCachedCostInfo(Caller); -    return; -  } - -  // For large functions, we can save a lot of computation time by skipping -  // recalculations. -  if (CallerFI.Metrics.NumCalls > 0) -    --CallerFI.Metrics.NumCalls; - -  if (Callee) { -    FunctionInfo &CalleeFI = CachedFunctionInfo[Callee]; -    if (!CalleeFI.Metrics.NumBlocks) { -      resetCachedCostInfo(Caller); -      return; -    } -    CallerFI.Metrics.NeverInline |= CalleeFI.Metrics.NeverInline; -    CallerFI.Metrics.usesDynamicAlloca |= CalleeFI.Metrics.usesDynamicAlloca; - -    CallerFI.Metrics.NumInsts += CalleeFI.Metrics.NumInsts; -    CallerFI.Metrics.NumBlocks += CalleeFI.Metrics.NumBlocks; -    CallerFI.Metrics.NumCalls += CalleeFI.Metrics.NumCalls; -    CallerFI.Metrics.NumVectorInsts += CalleeFI.Metrics.NumVectorInsts; -    CallerFI.Metrics.NumRets += CalleeFI.Metrics.NumRets; -  } -  // We are not updating the argumentweights. We have already determined that -  // Caller is a fairly large function, so we accept the loss of precision. -} diff --git a/lib/Transforms/IPO/InlineAlways.cpp b/lib/Transforms/IPO/InlineAlways.cpp index bc8028c..f11ecae 100644 --- a/lib/Transforms/IPO/InlineAlways.cpp +++ b/lib/Transforms/IPO/InlineAlways.cpp @@ -45,10 +45,7 @@ namespace {        return CA.getInlineFudgeFactor(CS);      }      void resetCachedCostInfo(Function *Caller) { -      CA.resetCachedCostInfo(Caller); -    } -    void growCachedCostInfo(Function* Caller, Function* Callee) { -      CA.growCachedCostInfo(Caller, Callee); +      return CA.resetCachedCostInfo(Caller);      }      virtual bool doFinalization(CallGraph &CG) {         return removeDeadFunctions(CG, &NeverInline);  diff --git a/lib/Transforms/IPO/InlineSimple.cpp b/lib/Transforms/IPO/InlineSimple.cpp index 46cf4b2..598043d 100644 --- a/lib/Transforms/IPO/InlineSimple.cpp +++ b/lib/Transforms/IPO/InlineSimple.cpp @@ -45,9 +45,6 @@ namespace {      void resetCachedCostInfo(Function *Caller) {        CA.resetCachedCostInfo(Caller);      } -    void growCachedCostInfo(Function* Caller, Function* Callee) { -      CA.growCachedCostInfo(Caller, Callee); -    }      virtual bool doInitialization(CallGraph &CG);    };  } diff --git a/lib/Transforms/IPO/Inliner.cpp b/lib/Transforms/IPO/Inliner.cpp index 03ec72c..3d0309f 100644 --- a/lib/Transforms/IPO/Inliner.cpp +++ b/lib/Transforms/IPO/Inliner.cpp @@ -369,8 +369,6 @@ bool Inliner::runOnSCC(std::vector<CallGraphNode*> &SCC) {          CG[Caller]->removeCallEdgeFor(CS);          CS.getInstruction()->eraseFromParent();          ++NumCallsDeleted; -        // Update the cached cost info with the missing call -        growCachedCostInfo(Caller, NULL);        } else {          // We can only inline direct calls to non-declarations.          if (Callee == 0 || Callee->isDeclaration()) continue; @@ -384,9 +382,6 @@ bool Inliner::runOnSCC(std::vector<CallGraphNode*> &SCC) {          if (!InlineCallIfPossible(CS, CG, TD, InlinedArrayAllocas))            continue;          ++NumInlined; - -        // Update the cached cost info with the inlined call. -        growCachedCostInfo(Caller, Callee);        }        // If we inlined or deleted the last possible call site to the function, @@ -412,6 +407,11 @@ bool Inliner::runOnSCC(std::vector<CallGraphNode*> &SCC) {          delete CG.removeFunctionFromModule(CalleeNode);          ++NumDeleted;        } +       +      // Remove any cached cost info for this caller, as inlining the +      // callee has increased the size of the caller (which may be the +      // same as the callee). +      resetCachedCostInfo(Caller);        // Remove this call site from the list.  If possible, use         // swap/pop_back for efficiency, but do not use it if doing so would | 
