From: Chris Lattner Date: Mon, 16 Aug 2004 01:07:04 +0000 (+0000) Subject: Add a special case for argc,argv X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=174f2264649d9ae062bdb0a038131c2836596be5;p=oota-llvm.git Add a special case for argc,argv git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@15802 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/ExecutionEngine/JIT/JIT.cpp b/lib/ExecutionEngine/JIT/JIT.cpp index d185e00d87c..675ef479d11 100644 --- a/lib/ExecutionEngine/JIT/JIT.cpp +++ b/lib/ExecutionEngine/JIT/JIT.cpp @@ -77,8 +77,7 @@ GenericValue JIT::runFunction(Function *F, if (RetTy == Type::IntTy || RetTy == Type::UIntTy || RetTy == Type::VoidTy) { switch (ArgValues.size()) { case 3: - if (FTy->getNumParams() == 3 && - (FTy->getParamType(0) == Type::IntTy || + if ((FTy->getParamType(0) == Type::IntTy || FTy->getParamType(0) == Type::UIntTy) && isa(FTy->getParamType(1)) && isa(FTy->getParamType(2))) { @@ -92,6 +91,18 @@ GenericValue JIT::runFunction(Function *F, return rv; } break; + case 2: + if ((FTy->getParamType(0) == Type::IntTy || + FTy->getParamType(0) == Type::UIntTy) && + isa(FTy->getParamType(1))) { + int (*PF)(int, char **) = (int(*)(int, char **))FPtr; + + // Call the function. + GenericValue rv; + rv.IntVal = PF(ArgValues[0].IntVal, (char **)GVTOP(ArgValues[1])); + return rv; + } + break; case 1: if (FTy->getNumParams() == 1 && (FTy->getParamType(0) == Type::IntTy ||