diff options
author | Chris Lattner <sabre@nondot.org> | 2010-01-11 02:43:35 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2010-01-11 02:43:35 +0000 |
commit | 8cf4f6f3ddd868116ea958870fa6f6a344028a60 (patch) | |
tree | 91a011b6f3d760bd21b9439a3d50811ea1545593 | |
parent | 11ea81242473027c67395e9e94396f4e2a282dda (diff) | |
download | external_llvm-8cf4f6f3ddd868116ea958870fa6f6a344028a60.zip external_llvm-8cf4f6f3ddd868116ea958870fa6f6a344028a60.tar.gz external_llvm-8cf4f6f3ddd868116ea958870fa6f6a344028a60.tar.bz2 |
improve comments, remove dead TD argument to CanEvaluateSExtd.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@93143 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Transforms/InstCombine/InstCombineCasts.cpp | 23 |
1 files changed, 12 insertions, 11 deletions
diff --git a/lib/Transforms/InstCombine/InstCombineCasts.cpp b/lib/Transforms/InstCombine/InstCombineCasts.cpp index 49b2e22..c467886 100644 --- a/lib/Transforms/InstCombine/InstCombineCasts.cpp +++ b/lib/Transforms/InstCombine/InstCombineCasts.cpp @@ -313,6 +313,8 @@ Instruction *InstCombiner::commonCastTransforms(CastInst &CI) { /// then trunc(inst(x,y)) can be computed as inst(trunc(x),trunc(y)), which only /// makes sense if x and y can be efficiently truncated. /// +/// This function works on both vectors and scalars. +/// static bool CanEvaluateTruncated(Value *V, const Type *Ty) { // We can always evaluate constants in another type. if (isa<Constant>(V)) @@ -578,9 +580,9 @@ Instruction *InstCombiner::transformZExtICmp(ICmpInst *ICI, Instruction &CI, } /// CanEvaluateZExtd - Determine if the specified value can be computed in the -/// specified wider type and produce the same low bits. If not, return -1. If -/// it is possible, return the number of high bits that are known to be zero in -/// the promoted value. +/// specified wider type and produce the same low bits. If not, return false. +/// +/// This function works on both vectors and scalars. static bool CanEvaluateZExtd(Value *V, const Type *Ty, const TargetData *TD) { if (isa<Constant>(V)) return true; @@ -780,7 +782,7 @@ Instruction *InstCombiner::visitZExt(ZExtInst &CI) { /// /// This function works on both vectors and scalars. /// -static bool CanEvaluateSExtd(Value *V, const Type *Ty, TargetData *TD) { +static bool CanEvaluateSExtd(Value *V, const Type *Ty) { assert(V->getType()->getScalarSizeInBits() < Ty->getScalarSizeInBits() && "Can't sign extend type to a smaller type"); // If this is a constant, it can be trivially promoted. @@ -810,16 +812,15 @@ static bool CanEvaluateSExtd(Value *V, const Type *Ty, TargetData *TD) { case Instruction::Sub: case Instruction::Mul: // These operators can all arbitrarily be extended if their inputs can. - return CanEvaluateSExtd(I->getOperand(0), Ty, TD) && - CanEvaluateSExtd(I->getOperand(1), Ty, TD); + return CanEvaluateSExtd(I->getOperand(0), Ty) && + CanEvaluateSExtd(I->getOperand(1), Ty); //case Instruction::Shl: TODO //case Instruction::LShr: TODO - //case Instruction::Trunc: TODO case Instruction::Select: - return CanEvaluateSExtd(I->getOperand(1), Ty, TD) && - CanEvaluateSExtd(I->getOperand(2), Ty, TD); + return CanEvaluateSExtd(I->getOperand(1), Ty) && + CanEvaluateSExtd(I->getOperand(2), Ty); case Instruction::PHI: { // We can change a phi if we can change all operands. Note that we never @@ -827,7 +828,7 @@ static bool CanEvaluateSExtd(Value *V, const Type *Ty, TargetData *TD) { // instructions with a single use. PHINode *PN = cast<PHINode>(I); for (unsigned i = 0, e = PN->getNumIncomingValues(); i != e; ++i) - if (!CanEvaluateSExtd(PN->getIncomingValue(i), Ty, TD)) return false; + if (!CanEvaluateSExtd(PN->getIncomingValue(i), Ty)) return false; return true; } default: @@ -866,7 +867,7 @@ Instruction *InstCombiner::visitSExt(SExtInst &CI) { // expression tree to something weird like i93 unless the source is also // strange. if ((isa<VectorType>(DestTy) || ShouldChangeType(SrcTy, DestTy)) && - CanEvaluateSExtd(Src, DestTy, TD)) { + CanEvaluateSExtd(Src, DestTy)) { // Okay, we can transform this! Insert the new expression now. DEBUG(dbgs() << "ICE: EvaluateInDifferentType converting expression type" " to avoid sign extend: " << CI); |