aboutsummaryrefslogtreecommitdiff
path: root/lib/ExecutionEngine/JIT/JIT.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-08-15 23:34:48 +0000
committerChris Lattner <sabre@nondot.org>2004-08-15 23:34:48 +0000
commitd297aea5f24f2ad369162b8c1084cda4dcc839f0 (patch)
treedd0b77a3e455f5e47e57e7a9cf7cbf5ebc4619e1 /lib/ExecutionEngine/JIT/JIT.cpp
parent95f114c5a9c5ced8b63034e75ccca8d2d61c956a (diff)
These only really work if returning int or void
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@15796 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/ExecutionEngine/JIT/JIT.cpp')
-rw-r--r--lib/ExecutionEngine/JIT/JIT.cpp38
1 files changed, 21 insertions, 17 deletions
diff --git a/lib/ExecutionEngine/JIT/JIT.cpp b/lib/ExecutionEngine/JIT/JIT.cpp
index 586936f21c..a2f2275384 100644
--- a/lib/ExecutionEngine/JIT/JIT.cpp
+++ b/lib/ExecutionEngine/JIT/JIT.cpp
@@ -63,23 +63,27 @@ GenericValue JIT::runFunction(Function *F,
void *FPtr = getPointerToFunction(F);
assert(FPtr && "Pointer to fn's code was null after getPointerToFunction");
-
- 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) {
- int (*PF)() = (int(*)())FPtr;
- rv.IntVal = PF();
- return rv;
+ const Type *RetTy = F->getReturnType();
+
+ // 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) {
+ int (*PF)() = (int(*)())FPtr;
+ rv.IntVal = PF();
+ return rv;
+ }
}
// FIXME: This code should handle a couple of common cases efficiently, but