fix a crash on CodeGen/X86/vector-rem.ll

llvm-svn: 46422
This commit is contained in:
Chris Lattner 2008-01-27 23:21:58 +00:00
parent d329270854
commit d0496d0433
1 changed files with 6 additions and 4 deletions

View File

@ -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.