forked from OSchip/llvm-project
[SelectionDAG] Use APInt::isSubsetOf/intersects to simplify some code.
Also use KnownBits::isNegative/isNonNegative to further simplify. llvm-svn: 367518
This commit is contained in:
parent
7a2958bc20
commit
388df2ea19
|
@ -3090,12 +3090,12 @@ KnownBits SelectionDAG::computeKnownBits(SDValue Op, const APInt &DemandedElts,
|
||||||
|
|
||||||
// If the first operand is non-negative or has all low bits zero, then
|
// If the first operand is non-negative or has all low bits zero, then
|
||||||
// the upper bits are all zero.
|
// the upper bits are all zero.
|
||||||
if (Known2.Zero[BitWidth-1] || ((Known2.Zero & LowBits) == LowBits))
|
if (Known2.isNonNegative() || LowBits.isSubsetOf(Known2.Zero))
|
||||||
Known.Zero |= ~LowBits;
|
Known.Zero |= ~LowBits;
|
||||||
|
|
||||||
// If the first operand is negative and not all low bits are zero, then
|
// If the first operand is negative and not all low bits are zero, then
|
||||||
// the upper bits are all one.
|
// the upper bits are all one.
|
||||||
if (Known2.One[BitWidth-1] && ((Known2.One & LowBits) != 0))
|
if (Known2.isNegative() && LowBits.intersects(Known2.One))
|
||||||
Known.One |= ~LowBits;
|
Known.One |= ~LowBits;
|
||||||
assert((Known.Zero & Known.One) == 0&&"Bits known to be one AND zero?");
|
assert((Known.Zero & Known.One) == 0&&"Bits known to be one AND zero?");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue