diff options
author | Chris Lattner <sabre@nondot.org> | 2008-12-01 05:16:26 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-12-01 05:16:26 +0000 |
commit | 9e6b24342874a84186c38ba1ea98dc772921b92e (patch) | |
tree | 9905eb896ef774aadb6f3077ec49807639ed1780 /llvm/lib | |
parent | 88a1f0213dcf303ab8cd11e0ad052dfefcc0dce0 (diff) | |
download | bcm5719-llvm-9e6b24342874a84186c38ba1ea98dc772921b92e.tar.gz bcm5719-llvm-9e6b24342874a84186c38ba1ea98dc772921b92e.zip |
simplify these patterns using m_Specific. No need to grep for
xor in testcase (or is a substring).
llvm-svn: 60328
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Transforms/Scalar/InstructionCombining.cpp | 22 |
1 files changed, 6 insertions, 16 deletions
diff --git a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp index 11c5f752977..bc8744480c5 100644 --- a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp @@ -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)) { |