summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2008-12-01 05:16:26 +0000
committerChris Lattner <sabre@nondot.org>2008-12-01 05:16:26 +0000
commit9e6b24342874a84186c38ba1ea98dc772921b92e (patch)
tree9905eb896ef774aadb6f3077ec49807639ed1780 /llvm/lib
parent88a1f0213dcf303ab8cd11e0ad052dfefcc0dce0 (diff)
downloadbcm5719-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.cpp22
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)) {
OpenPOWER on IntegriCloud