forked from OSchip/llvm-project
A BB that unwind_to an "unwind" inst is that same as one that doesn't unwind_to
at all. llvm-svn: 48096
This commit is contained in:
parent
95f4b77b0d
commit
f3d637fa14
|
@ -1370,7 +1370,7 @@ bool llvm::SimplifyCFG(BasicBlock *BB) {
|
|||
new UnwindInst(Pred); // Use unwind.
|
||||
Changed = true;
|
||||
}
|
||||
} else if (InvokeInst *II = dyn_cast<InvokeInst>(Pred->getTerminator()))
|
||||
} else if (InvokeInst *II = dyn_cast<InvokeInst>(Pred->getTerminator())) {
|
||||
if (II->getUnwindDest() == BB) {
|
||||
// Insert a new branch instruction before the invoke, because this
|
||||
// is now a fall through...
|
||||
|
@ -1388,6 +1388,9 @@ bool llvm::SimplifyCFG(BasicBlock *BB) {
|
|||
delete II;
|
||||
Changed = true;
|
||||
}
|
||||
} else if (Pred->getUnwindDest() == BB) {
|
||||
Pred->setUnwindDest(NULL);
|
||||
}
|
||||
|
||||
Preds.pop_back();
|
||||
}
|
||||
|
|
|
@ -33,3 +33,11 @@ bb4: unwind_to %cleanup
|
|||
cleanup:
|
||||
ret i32 1
|
||||
}
|
||||
|
||||
define i32 @f3() {
|
||||
entry: unwind_to %cleanup
|
||||
call void @g(i32 0)
|
||||
ret i32 0
|
||||
cleanup:
|
||||
unwind
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue