mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 03:33:20 +01:00
Preserve calling conventions when doing IPO
llvm-svn: 21798
This commit is contained in:
parent
eff214d7de
commit
2d9c054f4e
@ -394,6 +394,7 @@ Function *ArgPromotion::DoPromotion(Function *F,
|
||||
|
||||
// Create the new function body and insert it into the module...
|
||||
Function *NF = new Function(NFTy, F->getLinkage(), F->getName());
|
||||
NF->setCallingConv(F->getCallingConv());
|
||||
F->getParent()->getFunctionList().insert(F, NF);
|
||||
|
||||
// Get the alias analysis information that we need to update to reflect our
|
||||
@ -411,7 +412,8 @@ Function *ArgPromotion::DoPromotion(Function *F,
|
||||
// Loop over the operands, inserting GEP and loads in the caller as
|
||||
// appropriate.
|
||||
CallSite::arg_iterator AI = CS.arg_begin();
|
||||
for (Function::arg_iterator I = F->arg_begin(), E = F->arg_end(); I != E; ++I, ++AI)
|
||||
for (Function::arg_iterator I = F->arg_begin(), E = F->arg_end();
|
||||
I != E; ++I, ++AI)
|
||||
if (!ArgsToPromote.count(I))
|
||||
Args.push_back(*AI); // Unmodified argument
|
||||
else if (!I->use_empty()) {
|
||||
@ -441,8 +443,10 @@ Function *ArgPromotion::DoPromotion(Function *F,
|
||||
if (InvokeInst *II = dyn_cast<InvokeInst>(Call)) {
|
||||
New = new InvokeInst(NF, II->getNormalDest(), II->getUnwindDest(),
|
||||
Args, "", Call);
|
||||
cast<InvokeInst>(New)->setCallingConv(CS.getCallingConv());
|
||||
} else {
|
||||
New = new CallInst(NF, Args, "", Call);
|
||||
cast<CallInst>(New)->setCallingConv(CS.getCallingConv());
|
||||
if (cast<CallInst>(Call)->isTailCall())
|
||||
cast<CallInst>(New)->setTailCall();
|
||||
}
|
||||
|
@ -400,6 +400,7 @@ void DAE::RemoveDeadArgumentsFromFunction(Function *F) {
|
||||
|
||||
// Create the new function body and insert it into the module...
|
||||
Function *NF = new Function(NFTy, F->getLinkage(), F->getName());
|
||||
NF->setCallingConv(F->getCallingConv());
|
||||
F->getParent()->getFunctionList().insert(F, NF);
|
||||
|
||||
// Loop over all of the callers of the function, transforming the call sites
|
||||
@ -428,8 +429,10 @@ void DAE::RemoveDeadArgumentsFromFunction(Function *F) {
|
||||
if (InvokeInst *II = dyn_cast<InvokeInst>(Call)) {
|
||||
New = new InvokeInst(NF, II->getNormalDest(), II->getUnwindDest(),
|
||||
Args, "", Call);
|
||||
cast<InvokeInst>(New)->setCallingConv(CS.getCallingConv());
|
||||
} else {
|
||||
New = new CallInst(NF, Args, "", Call);
|
||||
cast<CallInst>(New)->setCallingConv(CS.getCallingConv());
|
||||
if (cast<CallInst>(Call)->isTailCall())
|
||||
cast<CallInst>(New)->setTailCall();
|
||||
}
|
||||
|
@ -144,10 +144,11 @@ bool PruneEH::SimplifyFunction(Function *F) {
|
||||
if (DoesNotUnwind.count(CG[F])) {
|
||||
// Insert a call instruction before the invoke...
|
||||
std::string Name = II->getName(); II->setName("");
|
||||
Value *Call = new CallInst(II->getCalledValue(),
|
||||
std::vector<Value*>(II->op_begin()+3,
|
||||
II->op_end()),
|
||||
Name, II);
|
||||
CallInst *Call = new CallInst(II->getCalledValue(),
|
||||
std::vector<Value*>(II->op_begin()+3,
|
||||
II->op_end()),
|
||||
Name, II);
|
||||
Call->setCallingConv(II->getCallingConv());
|
||||
|
||||
// Anything that used the value produced by the invoke instruction
|
||||
// now uses the value produced by the call instruction.
|
||||
|
Loading…
Reference in New Issue
Block a user