aboutsummaryrefslogtreecommitdiff
path: root/lib/ExecutionEngine/JIT/JIT.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-08-15 23:39:59 +0000
committerChris Lattner <sabre@nondot.org>2004-08-15 23:39:59 +0000
commitf7bedf447e080cb57c64d6f0cbf6fbeb9f4c596e (patch)
tree83adb57692e14f70d6198e50d9a95d77f0f0a28e /lib/ExecutionEngine/JIT/JIT.cpp
parentd297aea5f24f2ad369162b8c1084cda4dcc839f0 (diff)
Fine, go all of the way and check that the argument types are correct as well.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@15797 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/ExecutionEngine/JIT/JIT.cpp')
-rw-r--r--lib/ExecutionEngine/JIT/JIT.cpp40
1 files changed, 27 insertions, 13 deletions
diff --git a/lib/ExecutionEngine/JIT/JIT.cpp b/lib/ExecutionEngine/JIT/JIT.cpp
index a2f2275384..e6fd470d34 100644
--- a/lib/ExecutionEngine/JIT/JIT.cpp
+++ b/lib/ExecutionEngine/JIT/JIT.cpp
@@ -64,22 +64,36 @@ GenericValue JIT::runFunction(Function *F,
void *FPtr = getPointerToFunction(F);
assert(FPtr && "Pointer to fn's code was null after getPointerToFunction");
const Type *RetTy = F->getReturnType();
+ const FunctionType *FTy = F->getFunctionType();
// Handle some common cases first.
if (RetTy == Type::IntTy || RetTy == Type::UIntTy || RetTy == Type::VoidTy) {
- if (ArgValues.size() == 3) {
- int (*PF)(int, char **, const char **) =
- (int(*)(int, char **, const char **))FPtr;
-
- // Call the function.
- rv.IntVal = PF(ArgValues[0].IntVal, (char **)GVTOP(ArgValues[1]),
- (const char **)GVTOP(ArgValues[2]));
- return rv;
- } else if (ArgValues.size() == 1) {
- int (*PF)(int) = (int(*)(int))FPtr;
- rv.IntVal = PF(ArgValues[0].IntVal);
- return rv;
- } else if (ArgValues.size() == 0) {
+ switch (ArgValues.size()) {
+ case 3:
+ if (FTy->getNumParams() == 3 &&
+ (FTy->getParamType(0) == Type::IntTy ||
+ FTy->getParamType(0) == Type::UIntTy) &&
+ isa<PointerType>(FTy->getParamType(1)) &&
+ isa<PointerType>(FTy->getParamType(2))) {
+ int (*PF)(int, char **, const char **) =
+ (int(*)(int, char **, const char **))FPtr;
+
+ // Call the function.
+ rv.IntVal = PF(ArgValues[0].IntVal, (char **)GVTOP(ArgValues[1]),
+ (const char **)GVTOP(ArgValues[2]));
+ return rv;
+ }
+ break;
+ case 1:
+ if (FTy->getNumParams() == 1 &&
+ (FTy->getParamType(0) == Type::IntTy ||
+ FTy->getParamType(0) == Type::UIntTy)) {
+ int (*PF)(int) = (int(*)(int))FPtr;
+ rv.IntVal = PF(ArgValues[0].IntVal);
+ return rv;
+ }
+ break;
+ case 0:
int (*PF)() = (int(*)())FPtr;
rv.IntVal = PF();
return rv;