[llvm-commits] [llvm] r137199	-	/llvm/trunk/lib/Transforms/Utils/SimplifyIndVar.cpp
    Nick Lewycky 
    nicholas at mxc.ca
       
    Tue Aug  9 22:18:46 PDT 2011
    
    
  
Andrew Trick wrote:
> Author: atrick
> Date: Tue Aug  9 23:01:31 2011
> New Revision: 137199
>
> URL: http://llvm.org/viewvc/llvm-project?rev=137199&view=rev
> Log:
> SimplifyIndVar: make foldIVUser iterative to fold a chain of operands.
>
> Modified:
>      llvm/trunk/lib/Transforms/Utils/SimplifyIndVar.cpp
>
> Modified: llvm/trunk/lib/Transforms/Utils/SimplifyIndVar.cpp
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Utils/SimplifyIndVar.cpp?rev=137199&r1=137198&r2=137199&view=diff
> ==============================================================================
> --- llvm/trunk/lib/Transforms/Utils/SimplifyIndVar.cpp (original)
> +++ llvm/trunk/lib/Transforms/Utils/SimplifyIndVar.cpp Tue Aug  9 23:01:31 2011
> @@ -73,7 +73,7 @@
>       /// all simplicitions to users of an IV.
>       void simplifyUsers(PHINode *CurrIV, IVVisitor *V = NULL);
>
> -    bool foldIVUser(Instruction *UseInst, Instruction *IVOperand);
> +    Value *foldIVUser(Instruction *UseInst, Instruction *IVOperand);
>
>       bool eliminateIVUser(Instruction *UseInst, Instruction *IVOperand);
>       void eliminateIVComparison(ICmpInst *ICmp, Value *IVOperand);
> @@ -84,26 +84,30 @@
>
>   /// foldIVUser - Fold an IV operand into its use.  This removes increments of an
>   /// aligned IV when used by a instruction that ignores the low bits.
> -bool SimplifyIndvar::foldIVUser(Instruction *UseInst, Instruction *IVOperand) {
> +///
> +/// Return the operand of IVOperand for this induction variable if IVOperand can
> +/// be folded (in case more folding opportunity has been exposed).
"folding opportunity has" --> "folding opportunities have"?
> +/// Otherwise return null.
> +Value *SimplifyIndvar::foldIVUser(Instruction *UseInst, Instruction *IVOperand) {
>     Value *IVSrc = 0;
>     unsigned OperIdx = 0;
>     const SCEV *FoldedExpr = 0;
>     switch (UseInst->getOpcode()) {
>     default:
> -    return false;
> +    return 0;
>     case Instruction::UDiv:
>     case Instruction::LShr:
>       // We're only interested in the case where we know something about
>       // the numerator and have a constant denominator.
>       if (IVOperand != UseInst->getOperand(OperIdx) ||
>           !isa<ConstantInt>(UseInst->getOperand(1)))
> -      return false;
> +      return 0;
>
>       // Attempt to fold a binary operator with constant operand.
>       // e.g. ((I + 1)>>  2) =>  I>>  2
>       if (IVOperand->getNumOperands() != 2 ||
>           !isa<ConstantInt>(IVOperand->getOperand(1)))
> -      return false;
> +      return 0;
>
>       IVSrc = IVOperand->getOperand(0);
>       // IVSrc must be the (SCEVable) IV, since the other operand is const.
> @@ -114,7 +118,7 @@
>         // Get a constant for the divisor. See createSCEV.
>         uint32_t BitWidth = cast<IntegerType>(UseInst->getType())->getBitWidth();
>         if (D->getValue().uge(BitWidth))
> -        return false;
> +        return 0;
>
>         D = ConstantInt::get(UseInst->getContext(),
>                              APInt(BitWidth, 1).shl(D->getZExtValue()));
> @@ -123,11 +127,11 @@
>     }
>     // We have something that might fold it's operand. Compare SCEVs.
>     if (!SE->isSCEVable(UseInst->getType()))
> -    return false;
> +    return 0;
>
>     // Bypass the operand if SCEV can prove it has no effect.
>     if (SE->getSCEV(UseInst) != FoldedExpr)
> -    return false;
> +    return 0;
>
>     DEBUG(dbgs()<<  "INDVARS: Eliminated IV operand: "<<  *IVOperand
>           <<  " ->  "<<  *UseInst<<  '\n');
> @@ -139,7 +143,7 @@
>     Changed = true;
>     if (IVOperand->use_empty())
>       DeadInsts.push_back(IVOperand);
> -  return true;
> +  return IVSrc;
>   }
>
>   /// eliminateIVComparison - SimplifyIVUsers helper for eliminating useless
> @@ -337,10 +341,20 @@
>       // Bypass back edges to avoid extra work.
>       if (UseOper.first == CurrIV) continue;
>
> -    foldIVUser(UseOper.first, UseOper.second);
> +    Instruction *IVOperand = UseOper.second;
> +    for (unsigned N = 0; IVOperand; ++N) {
> +      assert(N<= Simplified.size()&&  "runaway iteration");
> +
> +      Value *NewOper = foldIVUser(UseOper.first, IVOperand);
> +      if (!NewOper)
> +        break; // done folding
> +      IVOperand = dyn_cast<Instruction>(NewOper);
> +    }
> +    if (!IVOperand)
> +      continue;
>
> -    if (eliminateIVUser(UseOper.first, UseOper.second)) {
> -      pushIVUsers(UseOper.second, Simplified, SimpleIVUsers);
> +    if (eliminateIVUser(UseOper.first, IVOperand)) {
> +      pushIVUsers(IVOperand, Simplified, SimpleIVUsers);
>         continue;
>       }
>       CastInst *Cast = dyn_cast<CastInst>(UseOper.first);
>
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
>
    
    
More information about the llvm-commits
mailing list