mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-23 02:32:11 +00:00
Fix: CodeExtractor/2004-11-12-InvokeExtract.ll
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@17699 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
8de2da4105
commit
9ecc046184
@ -488,6 +488,9 @@ emitCallAndSwitchStatement(Function *newFunction, BasicBlock *codeReplacer,
|
||||
// For an invoke, the normal destination is the only one that is
|
||||
// dominated by the result of the invocation
|
||||
BasicBlock *DefBlock = cast<Instruction>(outputs[out])->getParent();
|
||||
|
||||
bool DominatesDef = true;
|
||||
|
||||
if (InvokeInst *Invoke = dyn_cast<InvokeInst>(outputs[out])) {
|
||||
DefBlock = Invoke->getNormalDest();
|
||||
|
||||
@ -500,9 +503,18 @@ emitCallAndSwitchStatement(Function *newFunction, BasicBlock *codeReplacer,
|
||||
DefBlock = I->first;
|
||||
break;
|
||||
}
|
||||
|
||||
// In the extract block case, if the block we are extracting ends
|
||||
// with an invoke instruction, make sure that we don't emit a
|
||||
// store of the invoke value for the unwind block.
|
||||
if (!DS && DefBlock != OldTarget)
|
||||
DominatesDef = false;
|
||||
}
|
||||
|
||||
if (!DS || DS->dominates(DefBlock, TI->getParent()))
|
||||
if (DS)
|
||||
DominatesDef = DS->dominates(DefBlock, OldTarget);
|
||||
|
||||
if (DominatesDef) {
|
||||
if (AggregateArgs) {
|
||||
std::vector<Value*> Indices;
|
||||
Indices.push_back(Constant::getNullValue(Type::UIntTy));
|
||||
@ -512,8 +524,10 @@ emitCallAndSwitchStatement(Function *newFunction, BasicBlock *codeReplacer,
|
||||
"gep_" + outputs[out]->getName(),
|
||||
NTRet);
|
||||
new StoreInst(outputs[out], GEP, NTRet);
|
||||
} else
|
||||
} else {
|
||||
new StoreInst(outputs[out], OAI, NTRet);
|
||||
}
|
||||
}
|
||||
// Advance output iterator even if we don't emit a store
|
||||
if (!AggregateArgs) ++OAI;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user