diff options
author | Sanjay Patel <spatel@rotateright.com> | 2016-08-04 16:48:30 +0000 |
---|---|---|
committer | Sanjay Patel <spatel@rotateright.com> | 2016-08-04 16:48:30 +0000 |
commit | bf82f44e7b9769c5de3cb62a984fed83016963d1 (patch) | |
tree | c9ac12cf99b4f23a4f8f635e44b779c71a69580b /llvm/test/Transforms/InstSimplify/compare.ll | |
parent | 6f937b1144aeaf93ee57bdfaeb13d6cbbde5850d (diff) | |
download | bcm5719-llvm-bf82f44e7b9769c5de3cb62a984fed83016963d1.tar.gz bcm5719-llvm-bf82f44e7b9769c5de3cb62a984fed83016963d1.zip |
add tests for missing vector folds
llvm-svn: 277736
Diffstat (limited to 'llvm/test/Transforms/InstSimplify/compare.ll')
-rw-r--r-- | llvm/test/Transforms/InstSimplify/compare.ll | 36 |
1 files changed, 30 insertions, 6 deletions
diff --git a/llvm/test/Transforms/InstSimplify/compare.ll b/llvm/test/Transforms/InstSimplify/compare.ll index 9d6fd74ae56..4d302036d88 100644 --- a/llvm/test/Transforms/InstSimplify/compare.ll +++ b/llvm/test/Transforms/InstSimplify/compare.ll @@ -1005,22 +1005,46 @@ define i1 @nonnull_load_as_inner(i32 addrspace(1)** %addr) { ; If a bit is known to be zero for A and known to be one for B, ; then A and B cannot be equal. -define i1 @icmp_eq_const(i32 %a) nounwind { +define i1 @icmp_eq_const(i32 %a) { +; CHECK-LABEL: @icmp_eq_const( +; CHECK-NEXT: ret i1 false +; %b = mul nsw i32 %a, -2 %c = icmp eq i32 %b, 1 ret i1 %c +} -; CHECK-LABEL: @icmp_eq_const -; CHECK-NEXT: ret i1 false +; FIXME: Vectors should fold the same way. +define <2 x i1> @icmp_eq_const_vec(<2 x i32> %a) { +; CHECK-LABEL: @icmp_eq_const_vec( +; CHECK-NEXT: [[B:%.*]] = mul nsw <2 x i32> %a, <i32 -2, i32 -2> +; CHECK-NEXT: [[C:%.*]] = icmp eq <2 x i32> [[B]], <i32 1, i32 1> +; CHECK-NEXT: ret <2 x i1> [[C]] +; + %b = mul nsw <2 x i32> %a, <i32 -2, i32 -2> + %c = icmp eq <2 x i32> %b, <i32 1, i32 1> + ret <2 x i1> %c } -define i1 @icmp_ne_const(i32 %a) nounwind { +define i1 @icmp_ne_const(i32 %a) { +; CHECK-LABEL: @icmp_ne_const( +; CHECK-NEXT: ret i1 true +; %b = mul nsw i32 %a, -2 %c = icmp ne i32 %b, 1 ret i1 %c +} -; CHECK-LABEL: @icmp_ne_const -; CHECK-NEXT: ret i1 true +; FIXME: Vectors should fold the same way. +define <2 x i1> @icmp_ne_const_vec(<2 x i32> %a) { +; CHECK-LABEL: @icmp_ne_const_vec( +; CHECK-NEXT: [[B:%.*]] = mul nsw <2 x i32> %a, <i32 -2, i32 -2> +; CHECK-NEXT: [[C:%.*]] = icmp ne <2 x i32> [[B]], <i32 1, i32 1> +; CHECK-NEXT: ret <2 x i1> [[C]] +; + %b = mul nsw <2 x i32> %a, <i32 -2, i32 -2> + %c = icmp ne <2 x i32> %b, <i32 1, i32 1> + ret <2 x i1> %c } define i1 @icmp_sdiv_int_min(i32 %a) { |