diff options
author | Craig Topper <craig.topper@gmail.com> | 2017-04-07 07:32:00 +0000 |
---|---|---|
committer | Craig Topper <craig.topper@gmail.com> | 2017-04-07 07:32:00 +0000 |
commit | 33e0dbcc5872139a6cdd9337244287fb93fc1a96 (patch) | |
tree | 1905c4321e4a9dc413b951dea73d6e4f2f40597c /llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp | |
parent | ccf85f24c82f4bae943ee68a8d34deae5ae7b1a9 (diff) | |
download | bcm5719-llvm-33e0dbcc5872139a6cdd9337244287fb93fc1a96.tar.gz bcm5719-llvm-33e0dbcc5872139a6cdd9337244287fb93fc1a96.zip |
[InstCombine] Handle more commuted cases of ((A & B) | ~A) -> (~A | B)
llvm-svn: 299747
Diffstat (limited to 'llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp')
-rw-r--r-- | llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp b/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp index 6b6e362a34c..024949f8eee 100644 --- a/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp +++ b/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp @@ -2098,9 +2098,10 @@ Instruction *InstCombiner::visitOr(BinaryOperator &I) { return BinaryOperator::CreateOr(Op0, A); // ((A & B) | ~A) -> (~A | B) - if (match(Op0, m_And(m_Value(A), m_Value(B))) && - match(Op1, m_Not(m_Specific(A)))) - return BinaryOperator::CreateOr(Builder->CreateNot(A), B); + // The NOT is guaranteed to be in the RHS by complexity ordering. + if (match(Op1, m_Not(m_Value(A))) && + match(Op0, m_c_And(m_Specific(A), m_Value(B)))) + return BinaryOperator::CreateOr(Op1, B); // (A & ~B) | (A ^ B) -> (A ^ B) // (~B & A) | (A ^ B) -> (A ^ B) |