Don't (unconditionally) use getSCEVAtScope to simplify the step
authorDan Gohman <gohman@apple.com>
Fri, 19 Jun 2009 17:33:15 +0000 (17:33 +0000)
committerDan Gohman <gohman@apple.com>
Fri, 19 Jun 2009 17:33:15 +0000 (17:33 +0000)
expression in IVUsers, because in the case of a use of a non-linear
addrec outside of a loop, this causes the addrec to be evaluated as
a linear addrec.

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

lib/Analysis/IVUsers.cpp
test/Transforms/LoopStrengthReduce/quadradic-exit-value.ll [new file with mode: 0644]

index 0bacc3944365be1e1ffff0432fc84d289d6fb6e0..6a53a83665c2da4118b2e2a24c502d774dca0f4e 100644 (file)
@@ -112,7 +112,6 @@ static bool getSCEVStartAndStride(const SCEVHandle &SH, Loop *L, Loop *UseLoop,
   SCEVHandle AddRecStart = AddRec->getStart();
   AddRecStart = SE->getSCEVAtScope(AddRecStart, UseLoop);
   SCEVHandle AddRecStride = AddRec->getStepRecurrence(*SE);
-  AddRecStride = SE->getSCEVAtScope(AddRecStride, UseLoop);
 
   // FIXME: If Start contains an SCEVAddRecExpr from a different loop, other
   // than an outer loop of the current loop, reject it.  LSR has no concept of
diff --git a/test/Transforms/LoopStrengthReduce/quadradic-exit-value.ll b/test/Transforms/LoopStrengthReduce/quadradic-exit-value.ll
new file mode 100644 (file)
index 0000000..d15c2dc
--- /dev/null
@@ -0,0 +1,18 @@
+; RUN: llvm-as < %s | opt -analyze -iv-users -disable-output | grep {Stride i64 {1,+,2}<loop>:}
+
+; The value of %r is dependent on a polynomial iteration expression.
+
+define i64 @foo(i64 %n) {
+entry:
+  br label %loop
+
+loop:
+  %indvar = phi i64 [ 0, %entry ], [ %indvar.next, %loop ]
+  %indvar.next = add i64 %indvar, 1
+  %c = icmp eq i64 %indvar.next, %n
+  br i1 %c, label %exit, label %loop
+
+exit:
+  %r = mul i64 %indvar, %indvar
+  ret i64 %r
+}