[llvm] r341332 - [InstCombine] consolidate tests for ~(X+C); NFC

Sanjay Patel via llvm-commits llvm-commits at lists.llvm.org
Mon Sep 3 11:04:22 PDT 2018


Author: spatel
Date: Mon Sep  3 11:04:21 2018
New Revision: 341332

URL: http://llvm.org/viewvc/llvm-project?rev=341332&view=rev
Log:
[InstCombine] consolidate tests for ~(X+C); NFC

Modified:
    llvm/trunk/test/Transforms/InstCombine/not.ll
    llvm/trunk/test/Transforms/InstCombine/vector-xor.ll
    llvm/trunk/test/Transforms/InstCombine/xor.ll

Modified: llvm/trunk/test/Transforms/InstCombine/not.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstCombine/not.ll?rev=341332&r1=341331&r2=341332&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/InstCombine/not.ll (original)
+++ llvm/trunk/test/Transforms/InstCombine/not.ll Mon Sep  3 11:04:21 2018
@@ -219,3 +219,36 @@ define <2 x i32> @not_sub_extra_use_vec(
   ret <2 x i32> %r
 }
 
+; ~(X + C) --> -X - C - 1 --> -(C + 1) - X
+
+define i32 @not_add(i32 %x) {
+; CHECK-LABEL: @not_add(
+; CHECK-NEXT:    [[R:%.*]] = sub i32 -124, [[X:%.*]]
+; CHECK-NEXT:    ret i32 [[R]]
+;
+  %a = add i32 %x, 123
+  %r = xor i32 %a, -1
+  ret i32 %r
+}
+
+define <2 x i32> @not_add_splat(<2 x i32> %x) {
+; CHECK-LABEL: @not_add_splat(
+; CHECK-NEXT:    [[R:%.*]] = sub <2 x i32> <i32 -124, i32 -124>, [[X:%.*]]
+; CHECK-NEXT:    ret <2 x i32> [[R]]
+;
+  %a = add <2 x i32> %x, <i32 123, i32 123>
+  %r = xor <2 x i32> %a, <i32 -1, i32 -1>
+  ret <2 x i32> %r
+}
+
+define <2 x i32> @not_add_vec(<2 x i32> %x) {
+; CHECK-LABEL: @not_add_vec(
+; CHECK-NEXT:    [[A:%.*]] = add <2 x i32> [[X:%.*]], <i32 42, i32 123>
+; CHECK-NEXT:    [[R:%.*]] = xor <2 x i32> [[A]], <i32 -1, i32 -1>
+; CHECK-NEXT:    ret <2 x i32> [[R]]
+;
+  %a = add <2 x i32> %x, <i32 42, i32 123>
+  %r = xor <2 x i32> %a, <i32 -1, i32 -1>
+  ret <2 x i32> %r
+}
+

Modified: llvm/trunk/test/Transforms/InstCombine/vector-xor.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstCombine/vector-xor.ll?rev=341332&r1=341331&r2=341332&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/InstCombine/vector-xor.ll (original)
+++ llvm/trunk/test/Transforms/InstCombine/vector-xor.ll Mon Sep  3 11:04:21 2018
@@ -246,40 +246,6 @@ define <4 x i32> @test_v4i32_xor_signmas
   ret <4 x i32> %2
 }
 
-; ~(X-C) --> (-C-1)-X
-
-define <4 x i32> @test_v4i32_not_signmask_sub_var_splatconst(<4 x i32> %a0) {
-; CHECK-LABEL: @test_v4i32_not_signmask_sub_var_splatconst(
-; CHECK-NEXT:    [[TMP1:%.*]] = sub <4 x i32> <i32 2, i32 2, i32 2, i32 2>, [[A0:%.*]]
-; CHECK-NEXT:    ret <4 x i32> [[TMP1]]
-;
-  %1 = sub <4 x i32> %a0, <i32  3, i32  3, i32  3, i32  3>
-  %2 = xor <4 x i32> <i32 -1, i32 -1, i32 -1, i32 -1>, %1
-  ret <4 x i32> %2
-}
-
-define <4 x i32> @test_v4i32_not_signmask_sub_var_const(<4 x i32> %a0) {
-; CHECK-LABEL: @test_v4i32_not_signmask_sub_var_const(
-; CHECK-NEXT:    [[TMP1:%.*]] = add <4 x i32> [[A0:%.*]], <i32 -3, i32 -5, i32 1, i32 -15>
-; CHECK-NEXT:    [[TMP2:%.*]] = xor <4 x i32> [[TMP1]], <i32 -1, i32 -1, i32 -1, i32 -1>
-; CHECK-NEXT:    ret <4 x i32> [[TMP2]]
-;
-  %1 = sub <4 x i32> %a0, <i32 3, i32 5, i32 -1, i32 15>
-  %2 = xor <4 x i32> <i32 -1, i32 -1, i32 -1, i32 -1>, %1
-  ret <4 x i32> %2
-}
-
-define <4 x i32> @test_v4i32_not_signmask_sub_var_const_undef(<4 x i32> %a0) {
-; CHECK-LABEL: @test_v4i32_not_signmask_sub_var_const_undef(
-; CHECK-NEXT:    [[TMP1:%.*]] = add <4 x i32> [[A0:%.*]], <i32 -3, i32 undef, i32 1, i32 -15>
-; CHECK-NEXT:    [[TMP2:%.*]] = xor <4 x i32> [[TMP1]], <i32 -1, i32 -1, i32 -1, i32 undef>
-; CHECK-NEXT:    ret <4 x i32> [[TMP2]]
-;
-  %1 = sub <4 x i32> %a0, <i32 3, i32 undef, i32 -1, i32 15>
-  %2 = xor <4 x i32> <i32 -1, i32 -1, i32 -1, i32 undef>, %1
-  ret <4 x i32> %2
-}
-
 ; (X + C) ^ signmask -> (X + C + signmask)
 
 define <4 x i32> @test_v4i32_xor_signmask_add_splatconst(<4 x i32> %a0) {

Modified: llvm/trunk/test/Transforms/InstCombine/xor.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstCombine/xor.ll?rev=341332&r1=341331&r2=341332&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/InstCombine/xor.ll (original)
+++ llvm/trunk/test/Transforms/InstCombine/xor.ll Mon Sep  3 11:04:21 2018
@@ -157,46 +157,6 @@ define <2 x i1> @test12vec(<2 x i8> %a)
   ret <2 x i1> %c
 }
 
-define i32 @test15(i32 %A) {
-; CHECK-LABEL: @test15(
-; CHECK-NEXT:    [[C:%.*]] = sub i32 0, %A
-; CHECK-NEXT:    ret i32 [[C]]
-;
-  %B = add i32 %A, -1
-  %C = xor i32 %B, -1
-  ret i32 %C
-}
-
-define <2 x i32> @test15vec(<2 x i32> %A) {
-; CHECK-LABEL: @test15vec(
-; CHECK-NEXT:    [[C:%.*]] = sub <2 x i32> zeroinitializer, [[A:%.*]]
-; CHECK-NEXT:    ret <2 x i32> [[C]]
-;
-  %B = add <2 x i32> %A, <i32 -1, i32 -1>
-  %C = xor <2 x i32> %B, <i32 -1, i32 -1>
-  ret <2 x i32> %C
-}
-
-define i32 @test16(i32 %A) {
-; CHECK-LABEL: @test16(
-; CHECK-NEXT:    [[C:%.*]] = sub i32 -124, %A
-; CHECK-NEXT:    ret i32 [[C]]
-;
-  %B = add i32 %A, 123
-  %C = xor i32 %B, -1
-  ret i32 %C
-}
-
-define <2 x i32> @test16vec(<2 x i32> %A) {
-; CHECK-LABEL: @test16vec(
-; CHECK-NEXT:    [[C:%.*]] = sub <2 x i32> <i32 -124, i32 -124>, [[A:%.*]]
-; CHECK-NEXT:    ret <2 x i32> [[C]]
-;
-  %B = add <2 x i32> %A, <i32 123, i32 123>
-  %C = xor <2 x i32> %B, <i32 -1, i32 -1>
-  ret <2 x i32> %C
-}
-
 define i32 @test18(i32 %A) {
 ; CHECK-LABEL: @test18(
 ; CHECK-NEXT:    [[C:%.*]] = add i32 %A, 124




More information about the llvm-commits mailing list