Teach ComputeMaskedBits about nsw on add. I don't think there's anything we can

do with nuw here, but sub and mul should be given similar treatment.
Fixes PR9343 #15!


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@127463 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Nick Lewycky 2011-03-11 09:00:19 +00:00
parent 6fd2472b1b
commit b69050a94c
2 changed files with 24 additions and 0 deletions

View File

@ -429,6 +429,20 @@ void llvm::ComputeMaskedBits(Value *V, const APInt &Mask,
KnownZero |= LHSKnownZero & Mask; KnownZero |= LHSKnownZero & Mask;
KnownOne |= LHSKnownOne & Mask; KnownOne |= LHSKnownOne & Mask;
} }
// Are we still trying to solve for the sign bit?
if (Mask.isNegative() && !KnownZero.isNegative() && !KnownOne.isNegative()){
OverflowingBinaryOperator *OBO = cast<OverflowingBinaryOperator>(I);
if (OBO->hasNoSignedWrap()) {
// Adding two positive numbers can't wrap into negative ...
if (LHSKnownZero.isNegative() && KnownZero2.isNegative())
KnownZero |= APInt::getSignBit(BitWidth);
// and adding two negative numbers can't wrap into positive.
else if (LHSKnownOne.isNegative() && KnownOne2.isNegative())
KnownOne |= APInt::getSignBit(BitWidth);
}
}
return; return;
} }
case Instruction::SRem: case Instruction::SRem:

View File

@ -261,6 +261,16 @@ define i1 @srem1(i32 %X) {
; CHECK: ret i1 false ; CHECK: ret i1 false
} }
; PR9343 #15
; CHECK: @srem2
; CHECK: ret i1 false
define i1 @srem2(i16 %X, i32 %Y) {
%A = zext i16 %X to i32
%B = add nsw i32 %A, 1
%C = srem i32 %B, %Y
%D = icmp slt i32 %C, 0
ret i1 %D
}
define i1 @udiv1(i32 %X) { define i1 @udiv1(i32 %X) {
; CHECK: @udiv1 ; CHECK: @udiv1
%A = udiv i32 %X, 1000000 %A = udiv i32 %X, 1000000