mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-01 02:33:44 +00:00
InstSimplify: Simplify (X - (0 - Y)) if the second sub is NUW
If the NUW bit is set for 0 - Y, we know that all values for Y other than 0 would produce a poison value. This allows us to replace (0 - Y) with 0 in the expression (X - (0 - Y)) which will ultimately leave us with X. This partially fixes PR20189. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@214384 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
d1d53e81f6
commit
ec7ee07036
@ -676,6 +676,18 @@ static Value *SimplifySubInst(Value *Op0, Value *Op1, bool isNSW, bool isNUW,
|
|||||||
if (Op0 == Op1)
|
if (Op0 == Op1)
|
||||||
return Constant::getNullValue(Op0->getType());
|
return Constant::getNullValue(Op0->getType());
|
||||||
|
|
||||||
|
// X - (0 - Y) -> X if the second sub is NUW.
|
||||||
|
// If Y != 0, 0 - Y is a poison value.
|
||||||
|
// If Y == 0, 0 - Y simplifies to 0.
|
||||||
|
if (BinaryOperator::isNeg(Op1)) {
|
||||||
|
if (const auto *BO = dyn_cast<BinaryOperator>(Op1)) {
|
||||||
|
assert(BO->getOpcode() == Instruction::Sub &&
|
||||||
|
"Expected a subtraction operator!");
|
||||||
|
if (BO->hasNoUnsignedWrap())
|
||||||
|
return Op0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// (X + Y) - Z -> X + (Y - Z) or Y + (X - Z) if everything simplifies.
|
// (X + Y) - Z -> X + (Y - Z) or Y + (X - Z) if everything simplifies.
|
||||||
// For example, (X + Y) - Y -> X; (Y + X) - Y -> X
|
// For example, (X + Y) - Y -> X; (Y + X) - Y -> X
|
||||||
Value *X = nullptr, *Y = nullptr, *Z = Op1;
|
Value *X = nullptr, *Y = nullptr, *Z = Op1;
|
||||||
|
@ -20,3 +20,11 @@ define i64 @pow2b(i32 %x) {
|
|||||||
ret i64 %e2
|
ret i64 %e2
|
||||||
; CHECK: ret i64 %e
|
; CHECK: ret i64 %e
|
||||||
}
|
}
|
||||||
|
|
||||||
|
define i32 @sub_neg_nuw(i32 %x, i32 %y) {
|
||||||
|
; CHECK-LABEL: @sub_neg_nuw(
|
||||||
|
%neg = sub nuw i32 0, %y
|
||||||
|
%sub = sub i32 %x, %neg
|
||||||
|
ret i32 %sub
|
||||||
|
; CHECK: ret i32 %x
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user