Two fixes. First, stop using the ugly shouldSubstituteIndVar method.
authorChris Lattner <sabre@nondot.org>
Thu, 24 Jun 2004 06:49:18 +0000 (06:49 +0000)
committerChris Lattner <sabre@nondot.org>
Thu, 24 Jun 2004 06:49:18 +0000 (06:49 +0000)
Second, disable substitution of quadratic addrec expressions to avoid putting
multiplies in loops!

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@14358 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/Scalar/IndVarSimplify.cpp

index 56f021334b52a03ede5032aacbf56c433e14371c..5c4c63be5ba166d4de757c49a63a02348f6b86fd 100644 (file)
@@ -602,7 +602,13 @@ void IndVarSimplify::runOnLoop(Loop *L) {
     if (PN->getType()->isInteger()) {  // FIXME: when we have fast-math, enable!
       SCEVHandle SCEV = SE->getSCEV(PN);
       if (SCEV->hasComputableLoopEvolution(L))
-        if (SE->shouldSubstituteIndVar(SCEV))  // HACK!
+        // FIXME: Without a strength reduction pass, it is an extremely bad idea
+        // to indvar substitute anything more complex than a linear induction
+        // variable.  Doing so will put expensive multiply instructions inside
+        // of the loop.  For now just disable indvar subst on anything more
+        // complex than a linear addrec.
+        if (!isa<SCEVAddRecExpr>(SCEV) || 
+            cast<SCEVAddRecExpr>(SCEV)->getNumOperands() < 3)
           IndVars.push_back(std::make_pair(PN, SCEV));
     }