From: Andrew Lenharth Date: Sun, 19 Jun 2005 14:04:55 +0000 (+0000) Subject: va_end fix X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=017fba9d0f2b2f261684bf52c0e36e44f5a10f61;p=oota-llvm.git va_end fix git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@22262 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/AsmParser/llvmAsmParser.y b/lib/AsmParser/llvmAsmParser.y index 46dd988bd34..94d6edf5c54 100644 --- a/lib/AsmParser/llvmAsmParser.y +++ b/lib/AsmParser/llvmAsmParser.y @@ -785,6 +785,7 @@ static PATypeHolder HandleUpRefs(const Type *ty) { while (!F->use_empty()) { CallInst* CI = cast(F->use_back()); AllocaInst* bar = new AllocaInst(ArgTy, 0, "vaend.fix.1", CI); + new StoreInst(CI->getOperand(1), bar, CI); new CallInst(NF, bar, "", CI); CI->getParent()->getInstList().erase(CI); } diff --git a/lib/Bytecode/Reader/ReaderWrappers.cpp b/lib/Bytecode/Reader/ReaderWrappers.cpp index 8d1f3849861..c000c9a3f59 100644 --- a/lib/Bytecode/Reader/ReaderWrappers.cpp +++ b/lib/Bytecode/Reader/ReaderWrappers.cpp @@ -209,6 +209,7 @@ static ModuleProvider* CheckVarargs(ModuleProvider* MP) { for(Value::use_iterator I = F->use_begin(), E = F->use_end(); I != E;) if (CallInst* CI = dyn_cast(*I++)) { AllocaInst* bar = new AllocaInst(ArgTy, 0, "vaend.fix.1", CI); + new StoreInst(CI->getOperand(1), bar, CI); new CallInst(NF, bar, "", CI); CI->getParent()->getInstList().erase(CI); }