mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-01 03:33:42 +00:00
simplify these patterns using m_Specific. No need to grep for
xor in testcase (or is a substring). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@60328 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ef0c6744d5
commit
d8aafcb200
@ -3980,22 +3980,12 @@ Instruction *InstCombiner::visitAnd(BinaryOperator &I) {
|
||||
}
|
||||
|
||||
// (A&((~A)|B)) -> A&B
|
||||
if (match(Op0, m_Or(m_Not(m_Value(A)), m_Value(B)))) {
|
||||
if (A == Op1)
|
||||
return BinaryOperator::CreateAnd(A, B);
|
||||
}
|
||||
if (match(Op0, m_Or(m_Value(A), m_Not(m_Value(B))))) {
|
||||
if (B == Op1)
|
||||
return BinaryOperator::CreateAnd(A, B);
|
||||
}
|
||||
if (match(Op1, m_Or(m_Not(m_Value(A)), m_Value(B)))) {
|
||||
if (A == Op0)
|
||||
return BinaryOperator::CreateAnd(A, B);
|
||||
}
|
||||
if (match(Op1, m_Or(m_Value(A), m_Not(m_Value(B))))) {
|
||||
if (B == Op0)
|
||||
return BinaryOperator::CreateAnd(A, B);
|
||||
}
|
||||
if (match(Op0, m_Or(m_Not(m_Specific(Op1)), m_Value(A))) ||
|
||||
match(Op0, m_Or(m_Value(A), m_Not(m_Specific(Op1)))))
|
||||
return BinaryOperator::CreateAnd(A, Op1);
|
||||
if (match(Op1, m_Or(m_Not(m_Specific(Op0)), m_Value(A))) ||
|
||||
match(Op1, m_Or(m_Value(A), m_Not(m_Specific(Op0)))))
|
||||
return BinaryOperator::CreateAnd(A, Op0);
|
||||
}
|
||||
|
||||
if (ICmpInst *RHS = dyn_cast<ICmpInst>(Op1)) {
|
||||
|
@ -1,6 +1,4 @@
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep {and i32 %y, %x} | count 2
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep {and i32 %x, %y} | count 2
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep {xor}
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep {and i32 %x, %y} | count 4
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep {or}
|
||||
|
||||
define i32 @func1(i32 %x, i32 %y) nounwind {
|
||||
|
Loading…
x
Reference in New Issue
Block a user