mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 07:34:33 +00:00
Simplify r132022 based on Cameron's feedback.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@132071 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4c62f765a3
commit
237d10db8c
@ -919,18 +919,11 @@ void LoopUnswitch::RewriteLoopBodyWithConditionConstant(Loop *L, Value *LIC,
|
|||||||
BasicBlock *Switch = SI->getParent();
|
BasicBlock *Switch = SI->getParent();
|
||||||
BasicBlock *SISucc = SI->getSuccessor(DeadCase);
|
BasicBlock *SISucc = SI->getSuccessor(DeadCase);
|
||||||
BasicBlock *Latch = L->getLoopLatch();
|
BasicBlock *Latch = L->getLoopLatch();
|
||||||
// If the DeadCase successor dominates all of the predecessors of the
|
// If the DeadCase successor dominates the loop latch, then the
|
||||||
// loop latch, then the transformation isn't safe since it will delete
|
// transformation isn't safe since it will delete the sole predecessor edge
|
||||||
// the predecessor edges to the latch.
|
// to the latch.
|
||||||
if (Latch) {
|
if (Latch && DT->dominates(SISucc, Latch))
|
||||||
bool DominateAll = true;
|
|
||||||
for (pred_iterator PI = pred_begin(Latch), PE = pred_end(Latch);
|
|
||||||
DominateAll && PI != PE; ++PI)
|
|
||||||
if (!DT->dominates(SISucc, *PI))
|
|
||||||
DominateAll = false;
|
|
||||||
if (DominateAll)
|
|
||||||
continue;
|
continue;
|
||||||
}
|
|
||||||
|
|
||||||
// FIXME: This is a hack. We need to keep the successor around
|
// FIXME: This is a hack. We need to keep the successor around
|
||||||
// and hooked up so as to preserve the loop structure, because
|
// and hooked up so as to preserve the loop structure, because
|
||||||
|
Loading…
x
Reference in New Issue
Block a user