forked from OSchip/llvm-project
InstCombine: Fix a potential bug in 0 - (X sdiv C) -> (X sdiv -C)
While *most* (X sdiv 1) operations will get caught by InstSimplify, it is still possible for a sdiv to appear in the worklist which hasn't been simplified yet. This means that it is possible for 0 - (X sdiv 1) to get transformed into (X sdiv -1); dividing by -1 can make the transform produce undef values instead of the proper result. Sorry for the lack of testcase, it's a bit problematic because it relies on the exact order of operations in the worklist. llvm-svn: 215818
This commit is contained in:
parent
2873594709
commit
1a0bbc8a5c
|
@ -53,6 +53,9 @@ public:
|
|||
/// getNullValue.
|
||||
bool isNullValue() const;
|
||||
|
||||
/// \brief Returns true if the value is one.
|
||||
bool isOneValue() const;
|
||||
|
||||
/// isAllOnesValue - Return true if this is the value that would be returned by
|
||||
/// getAllOnesValue.
|
||||
bool isAllOnesValue() const;
|
||||
|
|
|
@ -107,6 +107,28 @@ bool Constant::isAllOnesValue() const {
|
|||
return false;
|
||||
}
|
||||
|
||||
bool Constant::isOneValue() const {
|
||||
// Check for 1 integers
|
||||
if (const ConstantInt *CI = dyn_cast<ConstantInt>(this))
|
||||
return CI->isOne();
|
||||
|
||||
// Check for FP which are bitcasted from 1 integers
|
||||
if (const ConstantFP *CFP = dyn_cast<ConstantFP>(this))
|
||||
return CFP->getValueAPF().bitcastToAPInt() == 1;
|
||||
|
||||
// Check for constant vectors which are splats of 1 values.
|
||||
if (const ConstantVector *CV = dyn_cast<ConstantVector>(this))
|
||||
if (Constant *Splat = CV->getSplatValue())
|
||||
return Splat->isOneValue();
|
||||
|
||||
// Check for constant vectors which are splats of 1 values.
|
||||
if (const ConstantDataVector *CV = dyn_cast<ConstantDataVector>(this))
|
||||
if (Constant *Splat = CV->getSplatValue())
|
||||
return Splat->isOneValue();
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
bool Constant::isMinSignedValue() const {
|
||||
// Check for INT_MIN integers
|
||||
if (const ConstantInt *CI = dyn_cast<ConstantInt>(this))
|
||||
|
|
|
@ -1583,7 +1583,7 @@ Instruction *InstCombiner::visitSub(BinaryOperator &I) {
|
|||
|
||||
// 0 - (X sdiv C) -> (X sdiv -C) provided the negation doesn't overflow.
|
||||
if (match(Op1, m_SDiv(m_Value(X), m_Constant(C))) && match(Op0, m_Zero()) &&
|
||||
!C->isMinSignedValue())
|
||||
!C->isMinSignedValue() && !C->isOneValue())
|
||||
return BinaryOperator::CreateSDiv(X, ConstantExpr::getNeg(C));
|
||||
|
||||
// 0 - (X << Y) -> (-X << Y) when X is freely negatable.
|
||||
|
|
Loading…
Reference in New Issue