diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2012-09-28 10:42:50 +0000 |
---|---|---|
committer | Benjamin Kramer <benny.kra@googlemail.com> | 2012-09-28 10:42:50 +0000 |
commit | 255dea4b90a622d2912ab0986a245a930dccc1fb (patch) | |
tree | 1f4f437126fbd626ce37896b39135681e2caccf2 /llvm/lib | |
parent | 5651cbdc1368226c8bc9d5f2f0acd67289d7f25c (diff) | |
download | bcm5719-llvm-255dea4b90a622d2912ab0986a245a930dccc1fb.tar.gz bcm5719-llvm-255dea4b90a622d2912ab0986a245a930dccc1fb.zip |
CorrelatedPropagation: BasicBlock::removePredecessor can simplify PHI nodes. If the it's the condition of a SwitchInst, reload it.
Fixes PR13972.
llvm-svn: 164818
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Transforms/Scalar/CorrelatedValuePropagation.cpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/Scalar/CorrelatedValuePropagation.cpp b/llvm/lib/Transforms/Scalar/CorrelatedValuePropagation.cpp index 9b0aadb0b5b..3ec6f3dcc31 100644 --- a/llvm/lib/Transforms/Scalar/CorrelatedValuePropagation.cpp +++ b/llvm/lib/Transforms/Scalar/CorrelatedValuePropagation.cpp @@ -235,6 +235,11 @@ bool CorrelatedValuePropagation::processSwitch(SwitchInst *SI) { // This case never fires - remove it. CI.getCaseSuccessor()->removePredecessor(BB); SI->removeCase(CI); // Does not invalidate the iterator. + + // The condition can be modified by removePredecessor's PHI simplification + // logic. + Cond = SI->getCondition(); + ++NumDeadCases; Changed = true; } else if (State == LazyValueInfo::True) { |