aboutsummaryrefslogtreecommitdiff
path: root/lib/Transforms/IPO/FunctionResolution.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-02-14 19:12:29 +0000
committerChris Lattner <sabre@nondot.org>2003-02-14 19:12:29 +0000
commitfd595203bd0d501fae9c1341e8424b9f86af2bb8 (patch)
tree40f379be86a24baf6a288d5af1d0a720f05aab1b /lib/Transforms/IPO/FunctionResolution.cpp
parent5f07a8b312e9d4ca0142b05ebb1ef088d88b4770 (diff)
Fix a bug that cause a crash resolving questionable function calls
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@5567 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/IPO/FunctionResolution.cpp')
-rw-r--r--lib/Transforms/IPO/FunctionResolution.cpp6
1 files changed, 4 insertions, 2 deletions
diff --git a/lib/Transforms/IPO/FunctionResolution.cpp b/lib/Transforms/IPO/FunctionResolution.cpp
index 9c5580b3b2..3d5991aba9 100644
--- a/lib/Transforms/IPO/FunctionResolution.cpp
+++ b/lib/Transforms/IPO/FunctionResolution.cpp
@@ -49,8 +49,8 @@ static void ConvertCallTo(CallInst *CI, Function *Dest) {
//
BasicBlock::iterator BBI = CI;
unsigned NumArgsToCopy = CI->getNumOperands()-1;
- if (CI->getNumOperands()-1 != ParamTys.size() &&
- !(CI->getNumOperands()-1 > ParamTys.size() &&
+ if (NumArgsToCopy != ParamTys.size() &&
+ !(NumArgsToCopy > ParamTys.size() &&
Dest->getFunctionType()->isVarArg())) {
std::cerr << "WARNING: Call arguments do not match expected number of"
<< " parameters.\n";
@@ -59,6 +59,8 @@ static void ConvertCallTo(CallInst *CI, Function *Dest) {
std::cerr << "Function resolved to: ";
WriteAsOperand(std::cerr, Dest);
std::cerr << "\n";
+ if (NumArgsToCopy > ParamTys.size())
+ NumArgsToCopy = ParamTys.size();
}
std::vector<Value*> Params;