mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-04 05:31:06 +00:00
Don't try to preserve pointer types in SCEVConstants; the old code
was over-complicated. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@106760 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
473e63512a
commit
eaf6cf28dd
@ -863,12 +863,10 @@ const SCEV *ScalarEvolution::getZeroExtendExpr(const SCEV *Op,
|
|||||||
Ty = getEffectiveSCEVType(Ty);
|
Ty = getEffectiveSCEVType(Ty);
|
||||||
|
|
||||||
// Fold if the operand is constant.
|
// Fold if the operand is constant.
|
||||||
if (const SCEVConstant *SC = dyn_cast<SCEVConstant>(Op)) {
|
if (const SCEVConstant *SC = dyn_cast<SCEVConstant>(Op))
|
||||||
const Type *IntTy = getEffectiveSCEVType(Ty);
|
return getConstant(
|
||||||
Constant *C = ConstantExpr::getZExt(SC->getValue(), IntTy);
|
cast<ConstantInt>(ConstantExpr::getZExt(SC->getValue(),
|
||||||
if (IntTy != Ty) C = ConstantExpr::getIntToPtr(C, Ty);
|
getEffectiveSCEVType(Ty))));
|
||||||
return getConstant(cast<ConstantInt>(C));
|
|
||||||
}
|
|
||||||
|
|
||||||
// zext(zext(x)) --> zext(x)
|
// zext(zext(x)) --> zext(x)
|
||||||
if (const SCEVZeroExtendExpr *SZ = dyn_cast<SCEVZeroExtendExpr>(Op))
|
if (const SCEVZeroExtendExpr *SZ = dyn_cast<SCEVZeroExtendExpr>(Op))
|
||||||
@ -998,12 +996,10 @@ const SCEV *ScalarEvolution::getSignExtendExpr(const SCEV *Op,
|
|||||||
Ty = getEffectiveSCEVType(Ty);
|
Ty = getEffectiveSCEVType(Ty);
|
||||||
|
|
||||||
// Fold if the operand is constant.
|
// Fold if the operand is constant.
|
||||||
if (const SCEVConstant *SC = dyn_cast<SCEVConstant>(Op)) {
|
if (const SCEVConstant *SC = dyn_cast<SCEVConstant>(Op))
|
||||||
const Type *IntTy = getEffectiveSCEVType(Ty);
|
return getConstant(
|
||||||
Constant *C = ConstantExpr::getSExt(SC->getValue(), IntTy);
|
cast<ConstantInt>(ConstantExpr::getSExt(SC->getValue(),
|
||||||
if (IntTy != Ty) C = ConstantExpr::getIntToPtr(C, Ty);
|
getEffectiveSCEVType(Ty))));
|
||||||
return getConstant(cast<ConstantInt>(C));
|
|
||||||
}
|
|
||||||
|
|
||||||
// sext(sext(x)) --> sext(x)
|
// sext(sext(x)) --> sext(x)
|
||||||
if (const SCEVSignExtendExpr *SS = dyn_cast<SCEVSignExtendExpr>(Op))
|
if (const SCEVSignExtendExpr *SS = dyn_cast<SCEVSignExtendExpr>(Op))
|
||||||
|
Loading…
Reference in New Issue
Block a user