summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
diff options
context:
space:
mode:
authorCraig Topper <craig.topper@intel.com>2017-07-16 05:37:58 +0000
committerCraig Topper <craig.topper@intel.com>2017-07-16 05:37:58 +0000
commit2072aca51cc8fd67c346e367fbeeab57722a46c5 (patch)
treed2cc84fed91bada83a40669fe0bb2612865b1230 /llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
parent923ddad4c6ee78a7175b05e027eac8584b7facb6 (diff)
downloadbcm5719-llvm-2072aca51cc8fd67c346e367fbeeab57722a46c5.tar.gz
bcm5719-llvm-2072aca51cc8fd67c346e367fbeeab57722a46c5.zip
[InstCombine] Move (0 - x) & 1 --> x & 1 to SimplifyDemandedUseBits.
This removes a dedicated matcher and allows us to support more than just an AND masking the lower bit. llvm-svn: 308124
Diffstat (limited to 'llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp')
-rw-r--r--llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp6
1 files changed, 1 insertions, 5 deletions
diff --git a/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp b/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
index f2f174e5c24..fdc9c373b95 100644
--- a/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
+++ b/llvm/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
@@ -1285,13 +1285,9 @@ Instruction *InstCombiner::visitAnd(BinaryOperator &I) {
return replaceInstUsesWith(I, V);
if (match(Op1, m_One())) {
- Value *X;
- // (0 - x) & 1 --> x & 1
- if (match(Op0, m_Sub(m_Zero(), m_Value(X))))
- return BinaryOperator::CreateAnd(X, Op1);
-
// (1 << x) & 1 --> zext(x == 0)
// (1 >> x) & 1 --> zext(x == 0)
+ Value *X;
if (match(Op0, m_OneUse(m_LogicalShift(m_One(), m_Value(X))))) {
Value *IsZero = Builder.CreateICmpEQ(X, ConstantInt::get(I.getType(), 0));
return new ZExtInst(IsZero, I.getType());
OpenPOWER on IntegriCloud