forked from OSchip/llvm-project
make various clients of ReplaceAndSimplifyAllUses tolerate
it *changing* the things it replaces, not just causing them to drop to null. There is no functionality change yet, but this is required for a subsequent patch. llvm-svn: 108414
This commit is contained in:
parent
1f7071a3e4
commit
e41ab07c61
|
@ -306,7 +306,7 @@ bool llvm::SimplifyInstructionsInBlock(BasicBlock *BB, const TargetData *TD) {
|
|||
WeakVH BIHandle(BI);
|
||||
ReplaceAndSimplifyAllUses(Inst, V, TD);
|
||||
MadeChange = true;
|
||||
if (BIHandle == 0)
|
||||
if (BIHandle != BI)
|
||||
BI = BB->begin();
|
||||
continue;
|
||||
}
|
||||
|
@ -354,12 +354,13 @@ void llvm::RemovePredecessorAndSimplify(BasicBlock *BB, BasicBlock *Pred,
|
|||
// value into all of its uses.
|
||||
assert(PNV != PN && "hasConstantValue broken");
|
||||
|
||||
Value *OldPhiIt = PhiIt;
|
||||
ReplaceAndSimplifyAllUses(PN, PNV, TD);
|
||||
|
||||
// If recursive simplification ended up deleting the next PHI node we would
|
||||
// iterate to, then our iterator is invalid, restart scanning from the top
|
||||
// of the block.
|
||||
if (PhiIt == 0) PhiIt = &BB->front();
|
||||
if (PhiIt != OldPhiIt) PhiIt = &BB->front();
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue