Revert r83606 and add comments explaining why it isn't safe.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@83649 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Dan Gohman 2009-10-09 16:35:06 +00:00
parent 0c536bec1e
commit 7a721956f8

View File

@ -2951,20 +2951,18 @@ const SCEV *ScalarEvolution::createSCEV(Value *V) {
Operator *U = cast<Operator>(V); Operator *U = cast<Operator>(V);
switch (Opcode) { switch (Opcode) {
case Instruction::Add: { case Instruction::Add:
AddOperator *A = cast<AddOperator>(U); // Don't transfer the NSW and NUW bits from the Add instruction to the
// Add expression, because the Instruction may be guarded by control
// flow and the no-overflow bits may not be valid for the expression in
// any context.
return getAddExpr(getSCEV(U->getOperand(0)), return getAddExpr(getSCEV(U->getOperand(0)),
getSCEV(U->getOperand(1)), getSCEV(U->getOperand(1)));
A->hasNoUnsignedWrap(), case Instruction::Mul:
A->hasNoSignedWrap()); // Don't transfer the NSW and NUW bits from the Mul instruction to the
} // Mul expression, as with Add.
case Instruction::Mul: {
MulOperator *M = cast<MulOperator>(U);
return getMulExpr(getSCEV(U->getOperand(0)), return getMulExpr(getSCEV(U->getOperand(0)),
getSCEV(U->getOperand(1)), getSCEV(U->getOperand(1)));
M->hasNoUnsignedWrap(),
M->hasNoSignedWrap());
}
case Instruction::UDiv: case Instruction::UDiv:
return getUDivExpr(getSCEV(U->getOperand(0)), return getUDivExpr(getSCEV(U->getOperand(0)),
getSCEV(U->getOperand(1))); getSCEV(U->getOperand(1)));