diff options
author | Chris Lattner <sabre@nondot.org> | 2006-01-14 20:09:18 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2006-01-14 20:09:18 +0000 |
commit | 432a205769d22e7744dd8b0b45efd687aa6998e3 (patch) | |
tree | 0ee87c02313e083a0e52373ffab880a1b3baa92e | |
parent | 468fb1df7db466e5682ee44341c3990b599e8d6a (diff) |
Let the inliner update the callgraph to reflect the changes it makes, instead
of doing it ourselves. This fixes Transforms/Inline/2006-01-14-CallGraphUpdate.ll
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25321 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Transforms/IPO/Inliner.cpp | 14 |
1 files changed, 2 insertions, 12 deletions
diff --git a/lib/Transforms/IPO/Inliner.cpp b/lib/Transforms/IPO/Inliner.cpp index a10879a150..2ee84276e7 100644 --- a/lib/Transforms/IPO/Inliner.cpp +++ b/lib/Transforms/IPO/Inliner.cpp @@ -42,18 +42,7 @@ static bool InlineCallIfPossible(CallSite CS, CallGraph &CG, const std::set<Function*> &SCCFunctions) { Function *Caller = CS.getInstruction()->getParent()->getParent(); Function *Callee = CS.getCalledFunction(); - if (!InlineFunction(CS)) return false; - - // Update the call graph by deleting the edge from Callee to Caller - CallGraphNode *CalleeNode = CG[Callee]; - CallGraphNode *CallerNode = CG[Caller]; - CallerNode->removeCallEdgeTo(CalleeNode); - - // Since we inlined all uninlined call sites in the callee into the caller, - // add edges from the caller to all of the callees of the callee. - for (CallGraphNode::iterator I = CalleeNode->begin(), - E = CalleeNode->end(); I != E; ++I) - CallerNode->addCalledFunction(*I); + if (!InlineFunction(CS, &CG)) return false; // If we inlined the last possible call site to the function, delete the // function body now. @@ -63,6 +52,7 @@ static bool InlineCallIfPossible(CallSite CS, CallGraph &CG, << Callee->getName() << "\n"); // Remove any call graph edges from the callee to its callees. + CallGraphNode *CalleeNode = CG[Callee]; while (CalleeNode->begin() != CalleeNode->end()) CalleeNode->removeCallEdgeTo(*(CalleeNode->end()-1)); |