summaryrefslogtreecommitdiff
path: root/lib/Transforms/Scalar/CorrelatedValuePropagation.cpp
diff options
context:
space:
mode:
authorOwen Anderson <resistor@mac.com>2010-12-15 00:55:35 +0000
committerOwen Anderson <resistor@mac.com>2010-12-15 00:55:35 +0000
commit86e8a700f516e8993417fb57d5386614b35c775d (patch)
tree07070adf1ac277abd6807a74239d4ad044d53784 /lib/Transforms/Scalar/CorrelatedValuePropagation.cpp
parent93f83deba1df95211898fe756758e81969955bd9 (diff)
downloadllvm-86e8a700f516e8993417fb57d5386614b35c775d.tar.gz
llvm-86e8a700f516e8993417fb57d5386614b35c775d.tar.bz2
llvm-86e8a700f516e8993417fb57d5386614b35c775d.tar.xz
Fix PR8790, another instance where unreachable code can cause instruction simplification to fail,
this case involve a select that simplifies to itself. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@121817 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/Scalar/CorrelatedValuePropagation.cpp')
-rw-r--r--lib/Transforms/Scalar/CorrelatedValuePropagation.cpp7
1 files changed, 6 insertions, 1 deletions
diff --git a/lib/Transforms/Scalar/CorrelatedValuePropagation.cpp b/lib/Transforms/Scalar/CorrelatedValuePropagation.cpp
index f364375ebd..be12973b64 100644
--- a/lib/Transforms/Scalar/CorrelatedValuePropagation.cpp
+++ b/lib/Transforms/Scalar/CorrelatedValuePropagation.cpp
@@ -73,7 +73,12 @@ bool CorrelatedValuePropagation::processSelect(SelectInst *S) {
ConstantInt *CI = dyn_cast<ConstantInt>(C);
if (!CI) return false;
- S->replaceAllUsesWith(S->getOperand(CI->isOne() ? 1 : 2));
+ Value *ReplaceWith = S->getOperand(1);
+ Value *Other = S->getOperand(2);
+ if (!CI->isOne()) std::swap(ReplaceWith, Other);
+ if (ReplaceWith == S) ReplaceWith = UndefValue::get(S->getType());
+
+ S->replaceAllUsesWith(ReplaceWith);
S->eraseFromParent();
++NumSelects;