From: David Bolvansky Date: Wed, 4 Sep 2019 12:18:53 +0000 (+0000) Subject: [NFC] Added tests for new fold X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=6595e6c5eef5f7735db475b7badbe0d63fdf5ea5;p=llvm [NFC] Added tests for new fold git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@370885 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/Transforms/InstCombine/sub-and-or-not-xor.ll b/test/Transforms/InstCombine/sub-and-or-not-xor.ll new file mode 100644 index 00000000000..23dcb890339 --- /dev/null +++ b/test/Transforms/InstCombine/sub-and-or-not-xor.ll @@ -0,0 +1,101 @@ +; NOTE: Assertions have been autogenerated by utils/update_test_checks.py +; RUN: opt -instcombine -S < %s | FileCheck %s + +declare void @use(i32) + +define i32 @sub_to_xor(i32 %x, i32 %y) { +; CHECK-LABEL: @sub_to_xor( +; CHECK-NEXT: [[OR:%.*]] = or i32 [[X:%.*]], [[Y:%.*]] +; CHECK-NEXT: [[AND:%.*]] = and i32 [[X]], [[Y]] +; CHECK-NEXT: [[SUB:%.*]] = sub i32 [[AND]], [[OR]] +; CHECK-NEXT: ret i32 [[SUB]] +; + %or = or i32 %x, %y + %and = and i32 %x, %y + %sub = sub i32 %and, %or + ret i32 %sub +} + +define i32 @sub_to_xor_extra_use_sub(i32 %x, i32 %y) { +; CHECK-LABEL: @sub_to_xor_extra_use_sub( +; CHECK-NEXT: [[OR:%.*]] = or i32 [[X:%.*]], [[Y:%.*]] +; CHECK-NEXT: [[AND:%.*]] = and i32 [[X]], [[Y]] +; CHECK-NEXT: [[SUB:%.*]] = sub i32 [[AND]], [[OR]] +; CHECK-NEXT: call void @use(i32 [[SUB]]) +; CHECK-NEXT: ret i32 [[SUB]] +; + %or = or i32 %x, %y + %and = and i32 %x, %y + %sub = sub i32 %and, %or + call void @use(i32 %sub) + ret i32 %sub +} + +define i32 @sub_to_xor_extra_use_and(i32 %x, i32 %y) { +; CHECK-LABEL: @sub_to_xor_extra_use_and( +; CHECK-NEXT: [[OR:%.*]] = or i32 [[X:%.*]], [[Y:%.*]] +; CHECK-NEXT: [[AND:%.*]] = and i32 [[X]], [[Y]] +; CHECK-NEXT: call void @use(i32 [[AND]]) +; CHECK-NEXT: [[SUB:%.*]] = sub i32 [[AND]], [[OR]] +; CHECK-NEXT: ret i32 [[SUB]] +; + %or = or i32 %x, %y + %and = and i32 %x, %y + call void @use(i32 %and) + %sub = sub i32 %and, %or + ret i32 %sub +} + +define i32 @sub_to_xor_extra_use_or(i32 %x, i32 %y) { +; CHECK-LABEL: @sub_to_xor_extra_use_or( +; CHECK-NEXT: [[OR:%.*]] = or i32 [[X:%.*]], [[Y:%.*]] +; CHECK-NEXT: call void @use(i32 [[OR]]) +; CHECK-NEXT: [[AND:%.*]] = and i32 [[X]], [[Y]] +; CHECK-NEXT: [[SUB:%.*]] = sub i32 [[AND]], [[OR]] +; CHECK-NEXT: ret i32 [[SUB]] +; + %or = or i32 %x, %y + call void @use(i32 %or) + %and = and i32 %x, %y + %sub = sub i32 %and, %or + ret i32 %sub +} + +define i32 @sub_to_xor_or_commuted(i32 %x, i32 %y) { +; CHECK-LABEL: @sub_to_xor_or_commuted( +; CHECK-NEXT: [[OR:%.*]] = or i32 [[Y:%.*]], [[X:%.*]] +; CHECK-NEXT: [[AND:%.*]] = and i32 [[X]], [[Y]] +; CHECK-NEXT: [[SUB:%.*]] = sub i32 [[AND]], [[OR]] +; CHECK-NEXT: ret i32 [[SUB]] +; + %or = or i32 %y, %x + %and = and i32 %x, %y + %sub = sub i32 %and, %or + ret i32 %sub +} + +define i32 @sub_to_xor_and_commuted(i32 %x, i32 %y) { +; CHECK-LABEL: @sub_to_xor_and_commuted( +; CHECK-NEXT: [[OR:%.*]] = or i32 [[X:%.*]], [[Y:%.*]] +; CHECK-NEXT: [[AND:%.*]] = and i32 [[Y]], [[X]] +; CHECK-NEXT: [[SUB:%.*]] = sub i32 [[AND]], [[OR]] +; CHECK-NEXT: ret i32 [[SUB]] +; + %or = or i32 %x, %y + %and = and i32 %y, %x + %sub = sub i32 %and, %or + ret i32 %sub +} + +define <2 x i32> @sub_to_xor_vec(<2 x i32> %x, <2 x i32> %y) { +; CHECK-LABEL: @sub_to_xor_vec( +; CHECK-NEXT: [[OR:%.*]] = or <2 x i32> [[X:%.*]], [[Y:%.*]] +; CHECK-NEXT: [[AND:%.*]] = and <2 x i32> [[Y]], [[X]] +; CHECK-NEXT: [[SUB:%.*]] = sub <2 x i32> [[OR]], [[AND]] +; CHECK-NEXT: ret <2 x i32> [[SUB]] +; + %or = or <2 x i32> %x, %y + %and = and <2 x i32> %y, %x + %sub = sub <2 x i32> %or, %and + ret <2 x i32> %sub +}