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:
Dan Gohman 2010-06-24 16:47:03 +00:00
parent 473e63512a
commit eaf6cf28dd

View File

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