summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/InstSimplify/AndOrXor.ll
diff options
context:
space:
mode:
authorCraig Topper <craig.topper@gmail.com>2017-05-14 07:54:40 +0000
committerCraig Topper <craig.topper@gmail.com>2017-05-14 07:54:40 +0000
commit982cc3b1d5b767b16d29197694ad17a108667407 (patch)
treebcef9cd6e9ba376f92b6849aaa306c0058160019 /llvm/test/Transforms/InstSimplify/AndOrXor.ll
parentdfc8955ee6d09f0b8a607868463d171209c640de (diff)
downloadbcm5719-llvm-982cc3b1d5b767b16d29197694ad17a108667407.tar.gz
bcm5719-llvm-982cc3b1d5b767b16d29197694ad17a108667407.zip
foo
llvm-svn: 303003
Diffstat (limited to 'llvm/test/Transforms/InstSimplify/AndOrXor.ll')
-rw-r--r--llvm/test/Transforms/InstSimplify/AndOrXor.ll122
1 files changed, 122 insertions, 0 deletions
diff --git a/llvm/test/Transforms/InstSimplify/AndOrXor.ll b/llvm/test/Transforms/InstSimplify/AndOrXor.ll
index e059d77f1fa..abca8222f31 100644
--- a/llvm/test/Transforms/InstSimplify/AndOrXor.ll
+++ b/llvm/test/Transforms/InstSimplify/AndOrXor.ll
@@ -628,3 +628,125 @@ define i32 @test46_commuted_and(i32 %a, i32 %b) {
%or = or i32 %xor, %and
ret i32 %or
}
+
+; (~A ^ B) | (A & B) -> ~A ^ B
+
+define i32 @test47(i32 %a, i32 %b) {
+; CHECK-LABEL: @test47(
+; CHECK-NEXT: [[NEGA:%.*]] = xor i32 [[A:%.*]], -1
+; CHECK-NEXT: [[AND:%.*]] = and i32 [[A]], [[B:%.*]]
+; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[NEGA]], [[B]]
+; CHECK-NEXT: [[OR:%.*]] = or i32 [[XOR]], [[AND]]
+; CHECK-NEXT: ret i32 [[OR]]
+;
+ %nega = xor i32 %a, -1
+ %and = and i32 %a, %b
+ %xor = xor i32 %nega, %b
+ %or = or i32 %xor, %and
+ ret i32 %or
+}
+
+define i32 @test48(i32 %a, i32 %b) {
+; CHECK-LABEL: @test48(
+; CHECK-NEXT: [[NEGA:%.*]] = xor i32 [[A:%.*]], -1
+; CHECK-NEXT: [[AND:%.*]] = and i32 [[A]], [[B:%.*]]
+; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[B]], [[NEGA]]
+; CHECK-NEXT: [[OR:%.*]] = or i32 [[XOR]], [[AND]]
+; CHECK-NEXT: ret i32 [[OR]]
+;
+ %nega = xor i32 %a, -1
+ %and = and i32 %a, %b
+ %xor = xor i32 %b, %nega
+ %or = or i32 %xor, %and
+ ret i32 %or
+}
+
+define i32 @test49(i32 %a, i32 %b) {
+; CHECK-LABEL: @test49(
+; CHECK-NEXT: [[NEGA:%.*]] = xor i32 [[A:%.*]], -1
+; CHECK-NEXT: [[AND:%.*]] = and i32 [[B:%.*]], [[A]]
+; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[B]], [[NEGA]]
+; CHECK-NEXT: [[OR:%.*]] = or i32 [[XOR]], [[AND]]
+; CHECK-NEXT: ret i32 [[OR]]
+;
+ %nega = xor i32 %a, -1
+ %and = and i32 %b, %a
+ %xor = xor i32 %b, %nega
+ %or = or i32 %xor, %and
+ ret i32 %or
+}
+
+define i32 @test50(i32 %a, i32 %b) {
+; CHECK-LABEL: @test50(
+; CHECK-NEXT: [[NEGA:%.*]] = xor i32 [[A:%.*]], -1
+; CHECK-NEXT: [[AND:%.*]] = and i32 [[B:%.*]], [[A]]
+; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[NEGA]], [[B]]
+; CHECK-NEXT: [[OR:%.*]] = or i32 [[XOR]], [[AND]]
+; CHECK-NEXT: ret i32 [[OR]]
+;
+ %nega = xor i32 %a, -1
+ %and = and i32 %b, %a
+ %xor = xor i32 %nega, %b
+ %or = or i32 %xor, %and
+ ret i32 %or
+}
+
+define i32 @test51(i32 %a, i32 %b) {
+; CHECK-LABEL: @test51(
+; CHECK-NEXT: [[NEGA:%.*]] = xor i32 [[A:%.*]], -1
+; CHECK-NEXT: [[AND:%.*]] = and i32 [[A]], [[B:%.*]]
+; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[NEGA]], [[B]]
+; CHECK-NEXT: [[OR:%.*]] = or i32 [[AND]], [[XOR]]
+; CHECK-NEXT: ret i32 [[OR]]
+;
+ %nega = xor i32 %a, -1
+ %and = and i32 %a, %b
+ %xor = xor i32 %nega, %b
+ %or = or i32 %and, %xor
+ ret i32 %or
+}
+
+define i32 @test52(i32 %a, i32 %b) {
+; CHECK-LABEL: @test52(
+; CHECK-NEXT: [[NEGA:%.*]] = xor i32 [[A:%.*]], -1
+; CHECK-NEXT: [[AND:%.*]] = and i32 [[A]], [[B:%.*]]
+; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[B]], [[NEGA]]
+; CHECK-NEXT: [[OR:%.*]] = or i32 [[AND]], [[XOR]]
+; CHECK-NEXT: ret i32 [[OR]]
+;
+ %nega = xor i32 %a, -1
+ %and = and i32 %a, %b
+ %xor = xor i32 %b, %nega
+ %or = or i32 %and, %xor
+ ret i32 %or
+}
+
+define i32 @test53(i32 %a, i32 %b) {
+; CHECK-LABEL: @test53(
+; CHECK-NEXT: [[NEGA:%.*]] = xor i32 [[A:%.*]], -1
+; CHECK-NEXT: [[AND:%.*]] = and i32 [[B:%.*]], [[A]]
+; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[B]], [[NEGA]]
+; CHECK-NEXT: [[OR:%.*]] = or i32 [[AND]], [[XOR]]
+; CHECK-NEXT: ret i32 [[OR]]
+;
+ %nega = xor i32 %a, -1
+ %and = and i32 %b, %a
+ %xor = xor i32 %b, %nega
+ %or = or i32 %and, %xor
+ ret i32 %or
+}
+
+define i32 @test54(i32 %a, i32 %b) {
+; CHECK-LABEL: @test54(
+; CHECK-NEXT: [[NEGA:%.*]] = xor i32 [[A:%.*]], -1
+; CHECK-NEXT: [[AND:%.*]] = and i32 [[B:%.*]], [[A]]
+; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[NEGA]], [[B]]
+; CHECK-NEXT: [[OR:%.*]] = or i32 [[AND]], [[XOR]]
+; CHECK-NEXT: ret i32 [[OR]]
+;
+ %nega = xor i32 %a, -1
+ %and = and i32 %b, %a
+ %xor = xor i32 %nega, %b
+ %or = or i32 %and, %xor
+ ret i32 %or
+}
OpenPOWER on IntegriCloud