[llvm] r358003 - [InstCombine] add tests/comments for negate+sdiv; NFC

Sanjay Patel via llvm-commits llvm-commits at lists.llvm.org
Tue Apr 9 06:41:29 PDT 2019


Author: spatel
Date: Tue Apr  9 06:41:29 2019
New Revision: 358003

URL: http://llvm.org/viewvc/llvm-project?rev=358003&view=rev
Log:
[InstCombine] add tests/comments for negate+sdiv; NFC

Modified:
    llvm/trunk/test/Transforms/InstCombine/div.ll

Modified: llvm/trunk/test/Transforms/InstCombine/div.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstCombine/div.ll?rev=358003&r1=358002&r2=358003&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/InstCombine/div.ll (original)
+++ llvm/trunk/test/Transforms/InstCombine/div.ll Tue Apr  9 06:41:29 2019
@@ -780,6 +780,20 @@ define <2 x i64> @test_exact_vec(<2 x i6
   ret <2 x i64> %neg
 }
 
+; Constant is safe to negate.
+
+define <2 x i8> @negate_sdiv_vec_splat(<2 x i8> %x) {
+; CHECK-LABEL: @negate_sdiv_vec_splat(
+; CHECK-NEXT:    [[NEG:%.*]] = sdiv <2 x i8> [[X:%.*]], <i8 -42, i8 -42>
+; CHECK-NEXT:    ret <2 x i8> [[NEG]]
+;
+  %div = sdiv <2 x i8> %x, <i8 42, i8 42>
+  %neg = sub <2 x i8> zeroinitializer, %div
+  ret <2 x i8> %neg
+}
+
+; Dividing by undef is UB.
+
 define <2 x i8> @negate_sdiv_vec_undef_elt(<2 x i8> %x) {
 ; CHECK-LABEL: @negate_sdiv_vec_undef_elt(
 ; CHECK-NEXT:    ret <2 x i8> undef
@@ -789,6 +803,8 @@ define <2 x i8> @negate_sdiv_vec_undef_e
   ret <2 x i8> %neg
 }
 
+; Division by -1 may be UB (if numerator is the signed min val), but div-by-1 can be simplified.
+
 define <2 x i8> @negate_sdiv_vec_splat_one(<2 x i8> %x) {
 ; CHECK-LABEL: @negate_sdiv_vec_splat_one(
 ; CHECK-NEXT:    [[NEG:%.*]] = sub <2 x i8> zeroinitializer, [[X:%.*]]
@@ -799,6 +815,8 @@ define <2 x i8> @negate_sdiv_vec_splat_o
   ret <2 x i8> %neg
 }
 
+; Can't negate signed-min constant, but can convert to a compare..
+
 define <2 x i8> @negate_sdiv_vec_splat_signed_min(<2 x i8> %x) {
 ; CHECK-LABEL: @negate_sdiv_vec_splat_signed_min(
 ; CHECK-NEXT:    [[TMP1:%.*]] = icmp eq <2 x i8> [[X:%.*]], <i8 -128, i8 -128>
@@ -810,6 +828,8 @@ define <2 x i8> @negate_sdiv_vec_splat_s
   ret <2 x i8> %neg
 }
 
+; Division by -1 may be UB for any element of a vector.
+
 define <2 x i8> @negate_sdiv_vec_one_element(<2 x i8> %x) {
 ; CHECK-LABEL: @negate_sdiv_vec_one_element(
 ; CHECK-NEXT:    [[NEG:%.*]] = sdiv <2 x i8> [[X:%.*]], <i8 1, i8 -1>
@@ -820,6 +840,8 @@ define <2 x i8> @negate_sdiv_vec_one_ele
   ret <2 x i8> %neg
 }
 
+; Division by -1 may be UB and can't negate signed-min.
+
 define <2 x i8> @negate_sdiv_vec_signed_min_elt(<2 x i8> %x) {
 ; CHECK-LABEL: @negate_sdiv_vec_signed_min_elt(
 ; CHECK-NEXT:    [[DIV:%.*]] = sdiv <2 x i8> [[X:%.*]], <i8 -1, i8 -128>
@@ -830,6 +852,19 @@ define <2 x i8> @negate_sdiv_vec_signed_
   %neg = sub <2 x i8> zeroinitializer, %div
   ret <2 x i8> %neg
 }
+
+; Can't negate signed-min constant for any element of a vector.
+
+define <2 x i8> @negate_sdiv_vec_signed_min_and_one_elt(<2 x i8> %x) {
+; CHECK-LABEL: @negate_sdiv_vec_signed_min_and_one_elt(
+; CHECK-NEXT:    [[DIV:%.*]] = sdiv <2 x i8> [[X:%.*]], <i8 1, i8 -128>
+; CHECK-NEXT:    [[NEG:%.*]] = sub <2 x i8> zeroinitializer, [[DIV]]
+; CHECK-NEXT:    ret <2 x i8> [[NEG]]
+;
+  %div = sdiv <2 x i8> %x, <i8 1, i8 -128>
+  %neg = sub <2 x i8> zeroinitializer, %div
+  ret <2 x i8> %neg
+}
 
 define i32 @test_exact_nonsw_exact(i32 %x) {
 ; CHECK-LABEL: @test_exact_nonsw_exact(




More information about the llvm-commits mailing list