mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 20:34:38 +00:00
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:
parent
0c536bec1e
commit
7a721956f8
@ -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)));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user