[llvm] r299737 - [InstCombine] Add more commuted patterns to support folding ((~A & B) | A) -> (A | B).

Craig Topper via llvm-commits llvm-commits at lists.llvm.org
Thu Apr 6 17:29:47 PDT 2017


Author: ctopper
Date: Thu Apr  6 19:29:47 2017
New Revision: 299737

URL: http://llvm.org/viewvc/llvm-project?rev=299737&view=rev
Log:
[InstCombine] Add more commuted patterns to support folding ((~A & B) | A) -> (A | B).

Modified:
    llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
    llvm/trunk/test/Transforms/InstCombine/or.ll

Modified: llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp?rev=299737&r1=299736&r2=299737&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp (original)
+++ llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp Thu Apr  6 19:29:47 2017
@@ -2092,9 +2092,10 @@ Instruction *InstCombiner::visitOr(Binar
   }
 
   // ((~A & B) | A) -> (A | B)
-  if (match(Op0, m_And(m_Not(m_Value(A)), m_Value(B))) &&
-      match(Op1, m_Specific(A)))
-    return BinaryOperator::CreateOr(A, B);
+  if (match(Op0, m_c_And(m_Not(m_Specific(Op1)), m_Value(A))))
+    return BinaryOperator::CreateOr(A, Op1);
+  if (match(Op1, m_c_And(m_Not(m_Specific(Op0)), m_Value(A))))
+    return BinaryOperator::CreateOr(Op0, A);
 
   // ((A & B) | ~A) -> (~A | B)
   if (match(Op0, m_And(m_Value(A), m_Value(B))) &&

Modified: llvm/trunk/test/Transforms/InstCombine/or.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstCombine/or.ll?rev=299737&r1=299736&r2=299737&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/InstCombine/or.ll (original)
+++ llvm/trunk/test/Transforms/InstCombine/or.ll Thu Apr  6 19:29:47 2017
@@ -521,7 +521,7 @@ define <2 x i132> @orsext_to_sel_vec_swa
 
 define i32 @test39(i32 %a, i32 %b) {
 ; CHECK-LABEL: @test39(
-; CHECK-NEXT:    [[OR:%.*]] = or i32 %a, %b
+; CHECK-NEXT:    [[OR:%.*]] = or i32 %b, %a
 ; CHECK-NEXT:    ret i32 [[OR]]
 ;
   %xor = xor i32 %a, -1
@@ -801,9 +801,7 @@ final:
 define i8 @test51(i8 %a, i8 %b, i8 %c) {
 ; CHECK-LABEL: @test51(
 ; CHECK-NEXT:    [[W:%.*]] = mul i8 [[B:%.*]], [[C:%.*]]
-; CHECK-NEXT:    [[Z:%.*]] = xor i8 [[A:%.*]], -1
-; CHECK-NEXT:    [[Y:%.*]] = and i8 [[W]], [[Z]]
-; CHECK-NEXT:    [[X:%.*]] = or i8 [[Y]], [[A]]
+; CHECK-NEXT:    [[X:%.*]] = or i8 [[W]], [[A:%.*]]
 ; CHECK-NEXT:    ret i8 [[X]]
 ;
   %w = mul i8 %b, %c
@@ -816,9 +814,7 @@ define i8 @test51(i8 %a, i8 %b, i8 %c) {
 define i8 @test52(i8 %a, i8 %b, i8 %c) {
 ; CHECK-LABEL: @test52(
 ; CHECK-NEXT:    [[W:%.*]] = mul i8 [[B:%.*]], [[C:%.*]]
-; CHECK-NEXT:    [[Z:%.*]] = xor i8 [[W]], -1
-; CHECK-NEXT:    [[Y:%.*]] = and i8 [[Z]], [[A:%.*]]
-; CHECK-NEXT:    [[X:%.*]] = or i8 [[W]], [[Y]]
+; CHECK-NEXT:    [[X:%.*]] = or i8 [[W]], [[A:%.*]]
 ; CHECK-NEXT:    ret i8 [[X]]
 ;
   %w = mul i8 %b, %c
@@ -831,9 +827,7 @@ define i8 @test52(i8 %a, i8 %b, i8 %c) {
 define i8 @test53(i8 %a, i8 %b, i8 %c) {
 ; CHECK-LABEL: @test53(
 ; CHECK-NEXT:    [[W:%.*]] = mul i8 [[B:%.*]], [[C:%.*]]
-; CHECK-NEXT:    [[Z:%.*]] = xor i8 [[W]], -1
-; CHECK-NEXT:    [[Y:%.*]] = and i8 [[Z]], [[A:%.*]]
-; CHECK-NEXT:    [[X:%.*]] = or i8 [[W]], [[Y]]
+; CHECK-NEXT:    [[X:%.*]] = or i8 [[W]], [[A:%.*]]
 ; CHECK-NEXT:    ret i8 [[X]]
 ;
   %w = mul i8 %b, %c




More information about the llvm-commits mailing list