mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-14 11:32:34 +00:00
Now that hasConstantValue is more careful w.r.t. returning values that only
dominate the PHI node, this code can go away. This also makes passes more aggressive, e.g. implementing Transforms/CondProp/phisimplify2.ll git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@22670 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b3b48e11da
commit
1325b42a7d
@ -193,11 +193,10 @@ void BasicBlock::removePredecessor(BasicBlock *Pred,
|
|||||||
PN->removeIncomingValue(Pred, false);
|
PN->removeIncomingValue(Pred, false);
|
||||||
// If all incoming values to the Phi are the same, we can replace the Phi
|
// If all incoming values to the Phi are the same, we can replace the Phi
|
||||||
// with that value.
|
// with that value.
|
||||||
if (Value *PNV = PN->hasConstantValue())
|
if (Value *PNV = PN->hasConstantValue()) {
|
||||||
if (!isa<Instruction>(PNV)) {
|
PN->replaceAllUsesWith(PNV);
|
||||||
PN->replaceAllUsesWith(PNV);
|
PN->eraseFromParent();
|
||||||
PN->eraseFromParent();
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user