From cf0e3acf164bc75f06c2483433e0e584d1545bea Mon Sep 17 00:00:00 2001 From: Dan Gohman Date: Tue, 6 May 2008 00:51:48 +0000 Subject: [PATCH] Correct the value of LowBits in srem and urem handling in ComputeMaskedBits. llvm-svn: 50692 --- llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp | 6 +++--- llvm/lib/Transforms/Scalar/InstructionCombining.cpp | 12 ++++++------ .../test/Transforms/InstCombine/srem-simplify-bug.ll | 9 +++++++++ 3 files changed, 18 insertions(+), 9 deletions(-) create mode 100644 llvm/test/Transforms/InstCombine/srem-simplify-bug.ll diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp index 26d554861745..3e75f7b3056f 100644 --- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp @@ -1560,7 +1560,7 @@ void SelectionDAG::ComputeMaskedBits(SDOperand Op, const APInt &Mask, if (ConstantSDNode *Rem = dyn_cast(Op.getOperand(1))) { APInt RA = Rem->getAPIntValue(); if (RA.isPowerOf2() || (-RA).isPowerOf2()) { - APInt LowBits = RA.isStrictlyPositive() ? ((RA - 1) | RA) : ~RA; + APInt LowBits = RA.isStrictlyPositive() ? (RA - 1) : ~RA; APInt Mask2 = LowBits | APInt::getSignBit(BitWidth); ComputeMaskedBits(Op.getOperand(0), Mask2,KnownZero2,KnownOne2,Depth+1); @@ -1581,8 +1581,8 @@ void SelectionDAG::ComputeMaskedBits(SDOperand Op, const APInt &Mask, case ISD::UREM: { if (ConstantSDNode *Rem = dyn_cast(Op.getOperand(1))) { APInt RA = Rem->getAPIntValue(); - if (RA.isStrictlyPositive() && RA.isPowerOf2()) { - APInt LowBits = (RA - 1) | RA; + if (RA.isPowerOf2()) { + APInt LowBits = (RA - 1); APInt Mask2 = LowBits & Mask; KnownZero |= ~LowBits & Mask; ComputeMaskedBits(Op.getOperand(0), Mask2, KnownZero, KnownOne,Depth+1); diff --git a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp index 6b1da0d25656..461d5fc7803b 100644 --- a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp @@ -965,7 +965,7 @@ void InstCombiner::ComputeMaskedBits(Value *V, const APInt &Mask, if (ConstantInt *Rem = dyn_cast(I->getOperand(1))) { APInt RA = Rem->getValue(); if (RA.isPowerOf2() || (-RA).isPowerOf2()) { - APInt LowBits = RA.isStrictlyPositive() ? ((RA - 1) | RA) : ~RA; + APInt LowBits = RA.isStrictlyPositive() ? (RA - 1) : ~RA; APInt Mask2 = LowBits | APInt::getSignBit(BitWidth); ComputeMaskedBits(I->getOperand(0), Mask2,KnownZero2,KnownOne2,Depth+1); @@ -986,8 +986,8 @@ void InstCombiner::ComputeMaskedBits(Value *V, const APInt &Mask, case Instruction::URem: { if (ConstantInt *Rem = dyn_cast(I->getOperand(1))) { APInt RA = Rem->getValue(); - if (RA.isStrictlyPositive() && RA.isPowerOf2()) { - APInt LowBits = (RA - 1) | RA; + if (RA.isPowerOf2()) { + APInt LowBits = (RA - 1); APInt Mask2 = LowBits & Mask; KnownZero |= ~LowBits & Mask; ComputeMaskedBits(I->getOperand(0), Mask2, KnownZero, KnownOne,Depth+1); @@ -1728,7 +1728,7 @@ bool InstCombiner::SimplifyDemandedBits(Value *V, APInt DemandedMask, if (ConstantInt *Rem = dyn_cast(I->getOperand(1))) { APInt RA = Rem->getValue(); if (RA.isPowerOf2() || (-RA).isPowerOf2()) { - APInt LowBits = RA.isStrictlyPositive() ? (RA - 1) | RA : ~RA; + APInt LowBits = RA.isStrictlyPositive() ? (RA - 1) : ~RA; APInt Mask2 = LowBits | APInt::getSignBit(BitWidth); if (SimplifyDemandedBits(I->getOperand(0), Mask2, LHSKnownZero, LHSKnownOne, Depth+1)) @@ -1749,8 +1749,8 @@ bool InstCombiner::SimplifyDemandedBits(Value *V, APInt DemandedMask, case Instruction::URem: { if (ConstantInt *Rem = dyn_cast(I->getOperand(1))) { APInt RA = Rem->getValue(); - if (RA.isStrictlyPositive() && RA.isPowerOf2()) { - APInt LowBits = (RA - 1) | RA; + if (RA.isPowerOf2()) { + APInt LowBits = (RA - 1); APInt Mask2 = LowBits & DemandedMask; KnownZero |= ~LowBits & DemandedMask; if (SimplifyDemandedBits(I->getOperand(0), Mask2, diff --git a/llvm/test/Transforms/InstCombine/srem-simplify-bug.ll b/llvm/test/Transforms/InstCombine/srem-simplify-bug.ll new file mode 100644 index 000000000000..cdf520256837 --- /dev/null +++ b/llvm/test/Transforms/InstCombine/srem-simplify-bug.ll @@ -0,0 +1,9 @@ +; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep {ret i1 false} +; PR2276 + +define i1 @f(i32 %x) { + %A = or i32 %x, 1 + %B = srem i32 %A, 1 + %C = icmp ne i32 %B, 0 + ret i1 %C +}