[PATCH] D45664: [InstCombine] Canonicalize variable mask in masked merge
Sanjay Patel via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Apr 18 10:41:46 PDT 2018
spatel added inline comments.
================
Comment at: lib/Transforms/InstCombine/InstCombineAndOrXor.cpp:2495-2497
+ if (Instruction *Xor = invertMaskInMaskedMerge(I, Builder))
+ return Xor;
+
----------------
Make sure I haven't missed anything, but it seems easier to match this inline here more simply as:
// Eliminate a 'not' from xor form of masked-merge (aka, bitwise select).
// The 'not' must be operand 1 of the 'and' (complexity-based op ordering).
// ((Op1 ^ X) & ~Y) ^ Op1 --> ((Op1 ^ X) & Y) ^ X
if (match(Op0, m_OneUse(m_And(m_c_Xor(m_Specific(Op1), m_Value(X)),
m_Not(m_Value(Y)))))) {
Value *Op00 = cast<BinaryOperator>(Op0)->getOperand(0);
return BinaryOperator::CreateXor(Builder.CreateAnd(Op00, Y), X);
}
// Op0 ^ ((Op0 ^ X) & ~Y) --> ((Op0 ^ X) & Y) ^ X
if (match(Op1, m_OneUse(m_And(m_c_Xor(m_Specific(Op0), m_Value(X)),
m_Not(m_Value(Y)))))) {
Value *Op10 = cast<BinaryOperator>(Op1)->getOperand(0);
return BinaryOperator::CreateXor(Builder.CreateAnd(Op10, Y), X);
}
Repository:
rL LLVM
https://reviews.llvm.org/D45664
More information about the llvm-commits
mailing list