summaryrefslogtreecommitdiff
path: root/lib/Transforms/IPO/FunctionResolution.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-05-31 20:44:46 +0000
committerChris Lattner <sabre@nondot.org>2003-05-31 20:44:46 +0000
commit40c4959e9fe77b8379e23f850a191bbacdfe6c03 (patch)
treea9b1dc35a3fbb9f35b460acd12336b871ba2db5e /lib/Transforms/IPO/FunctionResolution.cpp
parent567cceea49f66ed7e743853cdd0ba689651f79bb (diff)
downloadllvm-40c4959e9fe77b8379e23f850a191bbacdfe6c03.tar.gz
llvm-40c4959e9fe77b8379e23f850a191bbacdfe6c03.tar.bz2
llvm-40c4959e9fe77b8379e23f850a191bbacdfe6c03.tar.xz
Simplify funcresolve a bit more
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@6480 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/IPO/FunctionResolution.cpp')
-rw-r--r--lib/Transforms/IPO/FunctionResolution.cpp14
1 files changed, 7 insertions, 7 deletions
diff --git a/lib/Transforms/IPO/FunctionResolution.cpp b/lib/Transforms/IPO/FunctionResolution.cpp
index 75159eaaf7..5b2e39fdad 100644
--- a/lib/Transforms/IPO/FunctionResolution.cpp
+++ b/lib/Transforms/IPO/FunctionResolution.cpp
@@ -183,19 +183,19 @@ static bool ResolveFunctions(Module &M, std::vector<GlobalValue*> &Globals,
Changed = true;
++NumResolved;
} else {
- std::cerr << "Couldn't cleanup this function call, must be an"
- << " argument or something!" << CI;
++i;
}
- } else if (ConstantPointerRef *CPR = dyn_cast<ConstantPointerRef>(U)) {
- Constant *NewCPR = ConstantPointerRef::get(Concrete);
- CPR->replaceAllUsesWith(ConstantExpr::getCast(NewCPR,CPR->getType()));
- CPR->destroyConstant();
} else {
- std::cerr << "Cannot convert use of function: " << U << "\n";
++i;
}
}
+
+ // If there are any more uses that we could not resolve, force them to use
+ // a casted pointer now.
+ if (!Old->use_empty()) {
+ Constant *NewCPR = ConstantPointerRef::get(Concrete);
+ Old->replaceAllUsesWith(ConstantExpr::getCast(NewCPR, Old->getType()));
+ }
}
return Changed;
}