mirror of
https://github.com/RPCSX/llvm.git
synced 2025-02-16 19:19:10 +00:00
There is only one instance of this placeholder being created. Just use that
instead of a vector. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@137099 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4fa93b7ce1
commit
8d676c2199
@ -406,7 +406,7 @@ bool LowerInvoke::insertExpensiveEHSupport(Function &F) {
|
||||
SmallVector<ReturnInst*,16> Returns;
|
||||
SmallVector<UnwindInst*,16> Unwinds;
|
||||
SmallVector<InvokeInst*,16> Invokes;
|
||||
SmallVector<UnreachableInst*, 16> Unreachables;
|
||||
UnreachableInst* UnreachablePlaceholder = 0;
|
||||
|
||||
for (Function::iterator BB = F.begin(), E = F.end(); BB != E; ++BB)
|
||||
if (ReturnInst *RI = dyn_cast<ReturnInst>(BB->getTerminator())) {
|
||||
@ -490,7 +490,7 @@ bool LowerInvoke::insertExpensiveEHSupport(Function &F) {
|
||||
// for a standard call). We insert an unreachable instruction here and
|
||||
// modify the block to jump to the correct unwinding pad later.
|
||||
BasicBlock *UnwindBB = BasicBlock::Create(F.getContext(), "unwindbb", &F);
|
||||
Unreachables.push_back(new UnreachableInst(F.getContext(), UnwindBB));
|
||||
UnreachablePlaceholder = new UnreachableInst(F.getContext(), UnwindBB);
|
||||
|
||||
Value *CatchLoad = new LoadInst(InvokeNum, "invoke.num", true, CatchBB);
|
||||
SwitchInst *CatchSwitch =
|
||||
@ -579,10 +579,10 @@ bool LowerInvoke::insertExpensiveEHSupport(Function &F) {
|
||||
Unwinds[i]->eraseFromParent();
|
||||
}
|
||||
|
||||
// Replace all inserted unreachables with a branch to the unwind handler.
|
||||
for (unsigned i = 0, e = Unreachables.size(); i != e; ++i) {
|
||||
BranchInst::Create(UnwindHandler, Unreachables[i]);
|
||||
Unreachables[i]->eraseFromParent();
|
||||
// Replace the inserted unreachable with a branch to the unwind handler.
|
||||
if (UnreachablePlaceholder) {
|
||||
BranchInst::Create(UnwindHandler, UnreachablePlaceholder);
|
||||
UnreachablePlaceholder->eraseFromParent();
|
||||
}
|
||||
|
||||
// Finally, for any returns from this function, if this function contains an
|
||||
|
Loading…
x
Reference in New Issue
Block a user