diff options
| author | Craig Topper <craig.topper@gmail.com> | 2017-05-14 07:54:43 +0000 |
|---|---|---|
| committer | Craig Topper <craig.topper@gmail.com> | 2017-05-14 07:54:43 +0000 |
| commit | 479daaf74c6d0c5facdf2eceef06d5411c8bf322 (patch) | |
| tree | 88225be46c7eba2e0ec98c2ec63a5387f9f4819d /llvm/test | |
| parent | 982cc3b1d5b767b16d29197694ad17a108667407 (diff) | |
| download | bcm5719-llvm-479daaf74c6d0c5facdf2eceef06d5411c8bf322.tar.gz bcm5719-llvm-479daaf74c6d0c5facdf2eceef06d5411c8bf322.zip | |
[InstSimplify] Add patterns for folding (A & B) | (~A ^ B) -> (~A ^ B) and its commuted variants.
We already had (A & ~B) | (A ^ B), but we missed the cases where the not was part of the xor.
llvm-svn: 303004
Diffstat (limited to 'llvm/test')
| -rw-r--r-- | llvm/test/Transforms/InstSimplify/AndOrXor.ll | 48 |
1 files changed, 16 insertions, 32 deletions
diff --git a/llvm/test/Transforms/InstSimplify/AndOrXor.ll b/llvm/test/Transforms/InstSimplify/AndOrXor.ll index abca8222f31..9aa96eb2bdb 100644 --- a/llvm/test/Transforms/InstSimplify/AndOrXor.ll +++ b/llvm/test/Transforms/InstSimplify/AndOrXor.ll @@ -634,10 +634,8 @@ define i32 @test46_commuted_and(i32 %a, i32 %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]] +; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[NEGA]], [[B:%.*]] +; CHECK-NEXT: ret i32 [[XOR]] ; %nega = xor i32 %a, -1 %and = and i32 %a, %b @@ -649,10 +647,8 @@ define i32 @test47(i32 %a, i32 %b) { 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]] +; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[B:%.*]], [[NEGA]] +; CHECK-NEXT: ret i32 [[XOR]] ; %nega = xor i32 %a, -1 %and = and i32 %a, %b @@ -664,10 +660,8 @@ define i32 @test48(i32 %a, i32 %b) { 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]] +; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[B:%.*]], [[NEGA]] +; CHECK-NEXT: ret i32 [[XOR]] ; %nega = xor i32 %a, -1 %and = and i32 %b, %a @@ -679,10 +673,8 @@ define i32 @test49(i32 %a, i32 %b) { 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]] +; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[NEGA]], [[B:%.*]] +; CHECK-NEXT: ret i32 [[XOR]] ; %nega = xor i32 %a, -1 %and = and i32 %b, %a @@ -694,10 +686,8 @@ define i32 @test50(i32 %a, i32 %b) { 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]] +; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[NEGA]], [[B:%.*]] +; CHECK-NEXT: ret i32 [[XOR]] ; %nega = xor i32 %a, -1 %and = and i32 %a, %b @@ -709,10 +699,8 @@ define i32 @test51(i32 %a, i32 %b) { 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]] +; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[B:%.*]], [[NEGA]] +; CHECK-NEXT: ret i32 [[XOR]] ; %nega = xor i32 %a, -1 %and = and i32 %a, %b @@ -724,10 +712,8 @@ define i32 @test52(i32 %a, i32 %b) { 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]] +; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[B:%.*]], [[NEGA]] +; CHECK-NEXT: ret i32 [[XOR]] ; %nega = xor i32 %a, -1 %and = and i32 %b, %a @@ -739,10 +725,8 @@ define i32 @test53(i32 %a, i32 %b) { 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]] +; CHECK-NEXT: [[XOR:%.*]] = xor i32 [[NEGA]], [[B:%.*]] +; CHECK-NEXT: ret i32 [[XOR]] ; %nega = xor i32 %a, -1 %and = and i32 %b, %a |

