mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-22 04:22:57 +02:00
[InstCombine] Remove some code from visitAnd that dealt with trying to reduce the LHS of a sub to 0. This should now be fully handled by SimplifyDemandedInstructionBits now.
Now that we call ShrinkDemandedConstant on the RHS of sub this should be taken care of. This code doesn't trigger on any in tree regressions, but did before ShrinkDemandedConstant was added to the RHS. llvm-svn: 298644
This commit is contained in:
parent
651b5e54e8
commit
d73b0024f8
@ -1335,18 +1335,6 @@ Instruction *InstCombiner::visitAnd(BinaryOperator &I) {
|
||||
if (AndRHSMask == 1 && match(Op0LHS, m_Zero()))
|
||||
return BinaryOperator::CreateAnd(Op0RHS, AndRHS);
|
||||
|
||||
// (A - N) & AndRHS -> -N & AndRHS iff A&AndRHS==0 and AndRHS
|
||||
// has 1's for all bits that the subtraction with A might affect.
|
||||
if (Op0I->hasOneUse() && !match(Op0LHS, m_Zero())) {
|
||||
uint32_t BitWidth = AndRHSMask.getBitWidth();
|
||||
uint32_t Zeros = AndRHSMask.countLeadingZeros();
|
||||
APInt Mask = APInt::getLowBitsSet(BitWidth, BitWidth - Zeros);
|
||||
|
||||
if (MaskedValueIsZero(Op0LHS, Mask, 0, &I)) {
|
||||
Value *NewNeg = Builder->CreateNeg(Op0RHS);
|
||||
return BinaryOperator::CreateAnd(NewNeg, AndRHS);
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
||||
case Instruction::Shl:
|
||||
|
Loading…
Reference in New Issue
Block a user