[llvm] r373222 - [InstCombine] add tests for negate disguised as mul; NFC
Sanjay Patel via llvm-commits
llvm-commits at lists.llvm.org
Mon Sep 30 08:43:27 PDT 2019
Author: spatel
Date: Mon Sep 30 08:43:27 2019
New Revision: 373222
URL: http://llvm.org/viewvc/llvm-project?rev=373222&view=rev
Log:
[InstCombine] add tests for negate disguised as mul; NFC
Modified:
llvm/trunk/test/Transforms/InstCombine/mul.ll
Modified: llvm/trunk/test/Transforms/InstCombine/mul.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstCombine/mul.ll?rev=373222&r1=373221&r2=373222&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/InstCombine/mul.ll (original)
+++ llvm/trunk/test/Transforms/InstCombine/mul.ll Mon Sep 30 08:43:27 2019
@@ -517,3 +517,77 @@ define i64 @test_mul_canonicalize_neg_is
%B4 = mul i64 %B8, %L1
ret i64 %B4
}
+
+define i32 @negate_if_true(i32 %x, i1 %cond) {
+; CHECK-LABEL: @negate_if_true(
+; CHECK-NEXT: [[SEL:%.*]] = select i1 [[COND:%.*]], i32 -1, i32 1
+; CHECK-NEXT: [[R:%.*]] = mul i32 [[SEL]], [[X:%.*]]
+; CHECK-NEXT: ret i32 [[R]]
+;
+ %sel = select i1 %cond, i32 -1, i32 1
+ %r = mul i32 %sel, %x
+ ret i32 %r
+}
+
+define i32 @negate_if_false(i32 %x, i1 %cond) {
+; CHECK-LABEL: @negate_if_false(
+; CHECK-NEXT: [[SEL:%.*]] = select i1 [[COND:%.*]], i32 1, i32 -1
+; CHECK-NEXT: [[R:%.*]] = mul i32 [[SEL]], [[X:%.*]]
+; CHECK-NEXT: ret i32 [[R]]
+;
+ %sel = select i1 %cond, i32 1, i32 -1
+ %r = mul i32 %sel, %x
+ ret i32 %r
+}
+
+define <2 x i8> @negate_if_true_commute(<2 x i8> %px, i1 %cond) {
+; CHECK-LABEL: @negate_if_true_commute(
+; CHECK-NEXT: [[X:%.*]] = sdiv <2 x i8> <i8 42, i8 42>, [[PX:%.*]]
+; CHECK-NEXT: [[SEL:%.*]] = select i1 [[COND:%.*]], <2 x i8> <i8 -1, i8 -1>, <2 x i8> <i8 1, i8 1>
+; CHECK-NEXT: [[R:%.*]] = mul <2 x i8> [[X]], [[SEL]]
+; CHECK-NEXT: ret <2 x i8> [[R]]
+;
+ %x = sdiv <2 x i8> <i8 42, i8 42>, %px ; thwart complexity-based canonicalization
+ %sel = select i1 %cond, <2 x i8> <i8 -1, i8 -1>, <2 x i8> <i8 1, i8 1>
+ %r = mul <2 x i8> %x, %sel
+ ret <2 x i8> %r
+}
+
+define <2 x i8> @negate_if_false_commute(<2 x i8> %px, <2 x i1> %cond) {
+; CHECK-LABEL: @negate_if_false_commute(
+; CHECK-NEXT: [[X:%.*]] = sdiv <2 x i8> <i8 42, i8 5>, [[PX:%.*]]
+; CHECK-NEXT: [[SEL:%.*]] = select <2 x i1> [[COND:%.*]], <2 x i8> <i8 1, i8 undef>, <2 x i8> <i8 -1, i8 -1>
+; CHECK-NEXT: [[R:%.*]] = mul <2 x i8> [[X]], [[SEL]]
+; CHECK-NEXT: ret <2 x i8> [[R]]
+;
+ %x = sdiv <2 x i8> <i8 42, i8 5>, %px ; thwart complexity-based canonicalization
+ %sel = select <2 x i1> %cond, <2 x i8> <i8 1, i8 undef>, <2 x i8> <i8 -1, i8 -1>
+ %r = mul <2 x i8> %x, %sel
+ ret <2 x i8> %r
+}
+
+define i32 @negate_if_true_extra_use(i32 %x, i1 %cond) {
+; CHECK-LABEL: @negate_if_true_extra_use(
+; CHECK-NEXT: [[SEL:%.*]] = select i1 [[COND:%.*]], i32 -1, i32 1
+; CHECK-NEXT: call void @use32(i32 [[SEL]])
+; CHECK-NEXT: [[R:%.*]] = mul i32 [[SEL]], [[X:%.*]]
+; CHECK-NEXT: ret i32 [[R]]
+;
+ %sel = select i1 %cond, i32 -1, i32 1
+ call void @use32(i32 %sel)
+ %r = mul i32 %sel, %x
+ ret i32 %r
+}
+
+define <2 x i8> @negate_if_true_wrong_constant(<2 x i8> %px, i1 %cond) {
+; CHECK-LABEL: @negate_if_true_wrong_constant(
+; CHECK-NEXT: [[X:%.*]] = sdiv <2 x i8> <i8 42, i8 42>, [[PX:%.*]]
+; CHECK-NEXT: [[SEL:%.*]] = select i1 [[COND:%.*]], <2 x i8> <i8 -1, i8 0>, <2 x i8> <i8 1, i8 1>
+; CHECK-NEXT: [[R:%.*]] = mul <2 x i8> [[X]], [[SEL]]
+; CHECK-NEXT: ret <2 x i8> [[R]]
+;
+ %x = sdiv <2 x i8> <i8 42, i8 42>, %px ; thwart complexity-based canonicalization
+ %sel = select i1 %cond, <2 x i8> <i8 -1, i8 0>, <2 x i8> <i8 1, i8 1>
+ %r = mul <2 x i8> %x, %sel
+ ret <2 x i8> %r
+}
More information about the llvm-commits
mailing list