diff options
author | Anna Thomas <anna@azul.com> | 2017-03-27 13:52:51 +0000 |
---|---|---|
committer | Anna Thomas <anna@azul.com> | 2017-03-27 13:52:51 +0000 |
commit | f57ae33381f27445d2b174bfae2cd94d49852398 (patch) | |
tree | ffef4d4607f2d887aba8e6756531a810cd14468e /llvm/test/Transforms/InstCombine/phi-select-constexpr.ll | |
parent | 513c3e474d9e9ade4c5e232fdfd4bb962c26cab5 (diff) | |
download | bcm5719-llvm-f57ae33381f27445d2b174bfae2cd94d49852398.tar.gz bcm5719-llvm-f57ae33381f27445d2b174bfae2cd94d49852398.zip |
[InstCombine] Avoid incorrect folding of select into phi nodes when incoming element is a vector type
Summary:
We are incorrectly folding selects into phi nodes when the incoming value of a phi
node is a constant vector. This optimization is done in `FoldOpIntoPhi` when the
select condition is a phi node with constant incoming values.
Without the fix, we are miscompiling (i.e. incorrectly folding the
select into the phi node) when the vector contains non-zero
elements.
This patch fixes the miscompile and we will correctly fold based on the
select vector operand (see added test cases).
Reviewers: majnemer, sanjoy, spatel
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D31189
llvm-svn: 298845
Diffstat (limited to 'llvm/test/Transforms/InstCombine/phi-select-constexpr.ll')
-rw-r--r-- | llvm/test/Transforms/InstCombine/phi-select-constexpr.ll | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/llvm/test/Transforms/InstCombine/phi-select-constexpr.ll b/llvm/test/Transforms/InstCombine/phi-select-constexpr.ll index 054e0691d47..272594d7f4f 100644 --- a/llvm/test/Transforms/InstCombine/phi-select-constexpr.ll +++ b/llvm/test/Transforms/InstCombine/phi-select-constexpr.ll @@ -9,6 +9,7 @@ entry: delay: br label %final +; CHECK-LABEL: @foo ; CHECK-LABEL: final: ; CHECK: phi i32 [ 1, %entry ], [ select (i1 icmp eq (i32* @A, i32* @B), i32 2, i32 1), %delay ] final: @@ -17,3 +18,40 @@ final: ret i32 %value } + +; test folding of select into phi for vectors. +define <4 x i64> @vec1(i1 %which) { +entry: + br i1 %which, label %final, label %delay + +delay: + br label %final + +final: +; CHECK-LABEL: @vec1 +; CHECK-LABEL: final: +; CHECK: %phinode = phi <4 x i64> [ zeroinitializer, %entry ], [ <i64 0, i64 0, i64 126, i64 127>, %delay ] +; CHECK-NOT: select +; CHECK: ret <4 x i64> %phinode + %phinode = phi <4 x i1> [ <i1 true, i1 true, i1 true, i1 true>, %entry ], [ <i1 true, i1 true, i1 false, i1 false>, %delay ] + %sel = select <4 x i1> %phinode, <4 x i64> zeroinitializer, <4 x i64> <i64 124, i64 125, i64 126, i64 127> + ret <4 x i64> %sel +} + +define <4 x i64> @vec2(i1 %which) { +entry: + br i1 %which, label %final, label %delay + +delay: + br label %final + +final: +; CHECK-LABEL: @vec2 +; CHECK-LABEL: final: +; CHECK: %phinode = phi <4 x i64> [ <i64 124, i64 125, i64 126, i64 127>, %entry ], [ <i64 0, i64 125, i64 0, i64 127>, %delay ] +; CHECK-NOT: select +; CHECK: ret <4 x i64> %phinode + %phinode = phi <4 x i1> [ <i1 false, i1 false, i1 false, i1 false>, %entry ], [ <i1 true, i1 false, i1 true, i1 false>, %delay ] + %sel = select <4 x i1> %phinode, <4 x i64> zeroinitializer, <4 x i64> <i64 124, i64 125, i64 126, i64 127> + ret <4 x i64> %sel +} |