forked from OSchip/llvm-project
parent
d329270854
commit
d0496d0433
|
@ -1306,10 +1306,12 @@ SDOperand DAGCombiner::visitSREM(SDNode *N) {
|
||||||
return DAG.getNode(ISD::SREM, VT, N0, N1);
|
return DAG.getNode(ISD::SREM, VT, N0, N1);
|
||||||
// If we know the sign bits of both operands are zero, strength reduce to a
|
// If we know the sign bits of both operands are zero, strength reduce to a
|
||||||
// urem instead. Handles (X & 0x0FFFFFFF) %s 16 -> X&15
|
// urem instead. Handles (X & 0x0FFFFFFF) %s 16 -> X&15
|
||||||
|
if (!MVT::isVector(VT)) {
|
||||||
uint64_t SignBit = MVT::getIntVTSignBit(VT);
|
uint64_t SignBit = MVT::getIntVTSignBit(VT);
|
||||||
if (DAG.MaskedValueIsZero(N1, SignBit) &&
|
if (DAG.MaskedValueIsZero(N1, SignBit) &&
|
||||||
DAG.MaskedValueIsZero(N0, SignBit))
|
DAG.MaskedValueIsZero(N0, SignBit))
|
||||||
return DAG.getNode(ISD::UREM, VT, N0, N1);
|
return DAG.getNode(ISD::UREM, VT, N0, N1);
|
||||||
|
}
|
||||||
|
|
||||||
// If X/C can be simplified by the division-by-constant logic, lower
|
// If X/C can be simplified by the division-by-constant logic, lower
|
||||||
// X%C to the equivalent of X-X/C*C.
|
// X%C to the equivalent of X-X/C*C.
|
||||||
|
|
Loading…
Reference in New Issue