From e43702695dd4500c2a11671f9d353b5cc6b2603b Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 14 May 2005 12:25:32 +0000 Subject: [PATCH] preserve calling conventions when hacking on code git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@22024 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Transforms/Scalar/ADCE.cpp | 3 ++- lib/Transforms/Scalar/InstructionCombining.cpp | 2 ++ 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/lib/Transforms/Scalar/ADCE.cpp b/lib/Transforms/Scalar/ADCE.cpp index 7307ff813a2..65e816e2e81 100644 --- a/lib/Transforms/Scalar/ADCE.cpp +++ b/lib/Transforms/Scalar/ADCE.cpp @@ -188,7 +188,8 @@ bool ADCE::doADCE() { // after it to the normal destination. std::vector Args(II->op_begin()+3, II->op_end()); std::string Name = II->getName(); II->setName(""); - Instruction *NewCall = new CallInst(F, Args, Name, II); + CallInst *NewCall = new CallInst(F, Args, Name, II); + NewCall->setCallingConv(II->getCallingConv()); II->replaceAllUsesWith(NewCall); new BranchInst(II->getNormalDest(), II); diff --git a/lib/Transforms/Scalar/InstructionCombining.cpp b/lib/Transforms/Scalar/InstructionCombining.cpp index 2077b329160..218910feb20 100644 --- a/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/lib/Transforms/Scalar/InstructionCombining.cpp @@ -4271,10 +4271,12 @@ bool InstCombiner::transformConstExprCastCall(CallSite CS) { if (InvokeInst *II = dyn_cast(Caller)) { NC = new InvokeInst(Callee, II->getNormalDest(), II->getUnwindDest(), Args, Caller->getName(), Caller); + cast(II)->setCallingConv(II->getCallingConv()); } else { NC = new CallInst(Callee, Args, Caller->getName(), Caller); if (cast(Caller)->isTailCall()) cast(NC)->setTailCall(); + cast(NC)->setCallingConv(cast(Caller)->getCallingConv()); } // Insert a cast of the return type as necessary...