diff options
-rw-r--r-- | lib/Core/Executor.cpp | 12 | ||||
-rw-r--r-- | lib/Module/KModule.cpp | 52 |
2 files changed, 38 insertions, 26 deletions
diff --git a/lib/Core/Executor.cpp b/lib/Core/Executor.cpp index 5632b208..b0af78a1 100644 --- a/lib/Core/Executor.cpp +++ b/lib/Core/Executor.cpp @@ -1499,15 +1499,7 @@ void Executor::executeInstruction(ExecutionState &state, KInstruction *ki) { case Instruction::Invoke: case Instruction::Call: { - CallSite cs; - unsigned argStart; - if (i->getOpcode()==Instruction::Call) { - cs = CallSite(cast<CallInst>(i)); - argStart = 1; - } else { - cs = CallSite(cast<InvokeInst>(i)); - argStart = 3; - } + CallSite cs(i); unsigned numArgs = cs.arg_size(); Function *f = getCalledFunction(cs, state); @@ -1521,7 +1513,7 @@ void Executor::executeInstruction(ExecutionState &state, KInstruction *ki) { arguments.reserve(numArgs); for (unsigned j=0; j<numArgs; ++j) - arguments.push_back(eval(ki, argStart+j, state).value); + arguments.push_back(eval(ki, j+1, state).value); if (!f) { // special case the call with a bitcast case diff --git a/lib/Module/KModule.cpp b/lib/Module/KModule.cpp index 2982ad67..8842febb 100644 --- a/lib/Module/KModule.cpp +++ b/lib/Module/KModule.cpp @@ -28,6 +28,7 @@ #include "llvm/Module.h" #include "llvm/PassManager.h" #include "llvm/ValueSymbolTable.h" +#include "llvm/Support/CallSite.h" #include "llvm/Support/CommandLine.h" #include "llvm/Support/raw_ostream.h" #if !(LLVM_VERSION_MAJOR == 2 && LLVM_VERSION_MINOR < 7) @@ -481,6 +482,24 @@ KConstant::KConstant(llvm::Constant* _ct, unsigned _id, KInstruction* _ki) { /***/ +static int getOperandNum(Value *v, + std::map<Instruction*, unsigned> ®isterMap, + KModule *km, + KInstruction *ki) { + if (Instruction *inst = dyn_cast<Instruction>(v)) { + return registerMap[inst]; + } else if (Argument *a = dyn_cast<Argument>(v)) { + return a->getArgNo(); + } else if (isa<BasicBlock>(v) || isa<InlineAsm>(v) || + isa<MDNode>(v)) { + return -1; + } else { + assert(isa<Constant>(v)); + Constant *c = cast<Constant>(v); + return -(km->getConstantID(c, ki) + 2); + } +} + KFunction::KFunction(llvm::Function *_function, KModule *km) : function(_function), @@ -524,24 +543,25 @@ KFunction::KFunction(llvm::Function *_function, ki = new KInstruction(); break; } - unsigned numOperands = it->getNumOperands(); ki->inst = it; - ki->operands = new int[numOperands]; ki->dest = registerMap[it]; - for (unsigned j=0; j<numOperands; j++) { - Value *v = it->getOperand(j); - - if (Instruction *inst = dyn_cast<Instruction>(v)) { - ki->operands[j] = registerMap[inst]; - } else if (Argument *a = dyn_cast<Argument>(v)) { - ki->operands[j] = a->getArgNo(); - } else if (isa<BasicBlock>(v) || isa<InlineAsm>(v) || - isa<MDNode>(v)) { - ki->operands[j] = -1; - } else { - assert(isa<Constant>(v)); - Constant *c = cast<Constant>(v); - ki->operands[j] = -(km->getConstantID(c, ki) + 2); + + if (isa<CallInst>(it) || isa<InvokeInst>(it)) { + CallSite cs(it); + unsigned numArgs = cs.arg_size(); + ki->operands = new int[numArgs+1]; + ki->operands[0] = getOperandNum(cs.getCalledValue(), registerMap, km, + ki); + for (unsigned j=0; j<numArgs; j++) { + Value *v = cs.getArgument(j); + ki->operands[j+1] = getOperandNum(v, registerMap, km, ki); + } + } else { + unsigned numOperands = it->getNumOperands(); + ki->operands = new int[numOperands]; + for (unsigned j=0; j<numOperands; j++) { + Value *v = it->getOperand(j); + ki->operands[j] = getOperandNum(v, registerMap, km, ki); } } |