diff options
author | Chris Lattner <sabre@nondot.org> | 2004-07-18 21:34:16 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2004-07-18 21:34:16 +0000 |
commit | e2774757fef01dc7a2e805b737c74e8d21f92835 (patch) | |
tree | d943197d6f4d81a5099e573643741316108e9ad6 /llvm/lib | |
parent | d47504d9dbe025f38327c34fc5e1c2c4f678cfbe (diff) | |
download | bcm5719-llvm-e2774757fef01dc7a2e805b737c74e8d21f92835.tar.gz bcm5719-llvm-e2774757fef01dc7a2e805b737c74e8d21f92835.zip |
Fix a performance regression from the CPR patch, simplify code
llvm-svn: 14974
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Transforms/IPO/Inliner.cpp | 20 |
1 files changed, 6 insertions, 14 deletions
diff --git a/llvm/lib/Transforms/IPO/Inliner.cpp b/llvm/lib/Transforms/IPO/Inliner.cpp index bad8295adac..0a1bdea6606 100644 --- a/llvm/lib/Transforms/IPO/Inliner.cpp +++ b/llvm/lib/Transforms/IPO/Inliner.cpp @@ -170,28 +170,20 @@ bool Inliner::doFinalization(CallGraph &CG) { CallGraphNode *CGN = I->second; Function *F = CGN ? CGN->getFunction() : 0; - // If the only remaining use of the function is a dead constant - // pointer ref, remove it. - if (F && F->hasOneUse()) - if (Function *GV = dyn_cast<Function>(F->use_back())) - if (GV->removeDeadConstantUsers()) { - if (F->hasInternalLinkage()) { - // There *MAY* be an edge from the external call node to this - // function. If so, remove it. - CallGraphNode *EN = CG.getExternalCallingNode(); - CallGraphNode::iterator I = std::find(EN->begin(), EN->end(), CGN); - if (I != EN->end()) EN->removeCallEdgeTo(CGN); - } - } + // If the only remaining users of the function are dead constants, + // remove them. + if (F) F->removeDeadConstantUsers(); if (F && (F->hasLinkOnceLinkage() || F->hasInternalLinkage()) && F->use_empty()) { + // Remove any call graph edges from the function to its callees. while (CGN->begin() != CGN->end()) CGN->removeCallEdgeTo(*(CGN->end()-1)); // If the function has external linkage (basically if it's a linkonce - // function) remove the edge from the external node to the callee node. + // function) remove the edge from the external node to the callee + // node. if (!F->hasInternalLinkage()) CG.getExternalCallingNode()->removeCallEdgeTo(CGN); |