mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 00:32:55 +00:00
Get even more accurate on the casting.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@32478 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
daa8e3c263
commit
b6ba3e6d85
@ -1567,8 +1567,7 @@ SCEVHandle ScalarEvolutionsImpl::ComputeIterationCount(const Loop *L) {
|
||||
ConstantInt *CompVal = RHSC->getValue();
|
||||
const Type *RealTy = ExitCond->getOperand(0)->getType();
|
||||
CompVal = dyn_cast<ConstantInt>(
|
||||
ConstantExpr::getIntegerCast(CompVal, RealTy,
|
||||
CompVal->getType()->isSigned()));
|
||||
ConstantExpr::getBitCast(CompVal, RealTy));
|
||||
if (CompVal) {
|
||||
// Form the constant range.
|
||||
ConstantRange CompRange(Cond, CompVal);
|
||||
@ -1577,12 +1576,10 @@ SCEVHandle ScalarEvolutionsImpl::ComputeIterationCount(const Loop *L) {
|
||||
// range.
|
||||
if (CompRange.getLower()->getType()->isSigned()) {
|
||||
const Type *NewTy = RHSC->getValue()->getType();
|
||||
Constant *NewL =
|
||||
ConstantExpr::getIntegerCast(CompRange.getLower(), NewTy,
|
||||
CompRange.getLower()->getType()->isSigned());
|
||||
Constant *NewU =
|
||||
ConstantExpr::getIntegerCast(CompRange.getUpper(), NewTy,
|
||||
CompRange.getUpper()->getType()->isSigned());
|
||||
Constant *NewL = ConstantExpr::getBitCast(CompRange.getLower(),
|
||||
NewTy);
|
||||
Constant *NewU = ConstantExpr::getBitCast(CompRange.getUpper(),
|
||||
NewTy);
|
||||
CompRange = ConstantRange(NewL, NewU);
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user