[llvm-commits] [llvm] r61589 - in /llvm/trunk: lib/Analysis/ScalarEvolution.cpp test/Analysis/ScalarEvolution/2009-01-02-SignedNegativeStride.ll
Nick Lewycky
nicholas at mxc.ca
Fri Jan 2 10:54:17 PST 2009
Author: nicholas
Date: Fri Jan 2 12:54:17 2009
New Revision: 61589
URL: http://llvm.org/viewvc/llvm-project?rev=61589&view=rev
Log:
Don't try to analyze this "backward" case. This is overly conservative
pending a correct solution.
Added:
llvm/trunk/test/Analysis/ScalarEvolution/2009-01-02-SignedNegativeStride.ll
Modified:
llvm/trunk/lib/Analysis/ScalarEvolution.cpp
Modified: llvm/trunk/lib/Analysis/ScalarEvolution.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Analysis/ScalarEvolution.cpp?rev=61589&r1=61588&r2=61589&view=diff
==============================================================================
--- llvm/trunk/lib/Analysis/ScalarEvolution.cpp (original)
+++ llvm/trunk/lib/Analysis/ScalarEvolution.cpp Fri Jan 2 12:54:17 2009
@@ -2905,6 +2905,11 @@
return false;
}
+static bool isNegative(SCEVHandle X) {
+ if (SCEVConstant *C = dyn_cast<SCEVConstant>(X))
+ return C->getValue()->getValue().isNegative();
+}
+
/// potentialInfiniteLoop - Test whether the loop might jump over the exit value
/// due to wrapping around 2^n.
bool ScalarEvolutionsImpl::potentialInfiniteLoop(SCEV *Stride, SCEV *RHS,
@@ -2958,6 +2963,13 @@
if (potentialInfiniteLoop(Stride, RHS, isSigned, trueWhenEqual))
return UnknownValue;
+ // We don't handle this correctly at the moment. The problem is that when
+ // the stride is negative, we're not counting how many times 'less-than' is
+ // true as we approach it, we're counting how far away we are from wrapping
+ // around the backside.
+ if (isSigned && isNegative(Stride))
+ return UnknownValue;
+
// We know the LHS is of the form {n,+,s} and the RHS is some loop-invariant
// m. So, we count the number of iterations in which {n,+,s} < m is true.
// Note that we cannot simply return max(m-n,0)/s because it's not safe to
Added: llvm/trunk/test/Analysis/ScalarEvolution/2009-01-02-SignedNegativeStride.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Analysis/ScalarEvolution/2009-01-02-SignedNegativeStride.ll?rev=61589&view=auto
==============================================================================
--- llvm/trunk/test/Analysis/ScalarEvolution/2009-01-02-SignedNegativeStride.ll (added)
+++ llvm/trunk/test/Analysis/ScalarEvolution/2009-01-02-SignedNegativeStride.ll Fri Jan 2 12:54:17 2009
@@ -0,0 +1,40 @@
+; RUN: llvm-as < %s | opt -analyze -scalar-evolution | not grep {/u -1}
+; PR3275
+
+ at g_16 = external global i16 ; <i16*> [#uses=3]
+ at .str = external constant [4 x i8] ; <[4 x i8]*> [#uses=0]
+
+define void @func_15() nounwind {
+entry:
+ %0 = load i16* @g_16, align 2 ; <i16> [#uses=1]
+ %1 = icmp sgt i16 %0, 0 ; <i1> [#uses=1]
+ br i1 %1, label %bb2, label %bb.nph
+
+bb.nph: ; preds = %entry
+ %g_16.promoted = load i16* @g_16 ; <i16> [#uses=1]
+ br label %bb
+
+bb: ; preds = %bb1, %bb.nph
+ %g_16.tmp.0 = phi i16 [ %g_16.promoted, %bb.nph ], [ %2, %bb1 ] ; <i16> [#uses=1]
+ %2 = add i16 %g_16.tmp.0, -1 ; <i16> [#uses=3]
+ br label %bb1
+
+bb1: ; preds = %bb
+ %3 = icmp sgt i16 %2, 0 ; <i1> [#uses=1]
+ br i1 %3, label %bb1.bb2_crit_edge, label %bb
+
+bb1.bb2_crit_edge: ; preds = %bb1
+ store i16 %2, i16* @g_16
+ br label %bb2
+
+bb2: ; preds = %bb1.bb2_crit_edge, %entry
+ br label %return
+
+return: ; preds = %bb2
+ ret void
+}
+
+declare i32 @main() nounwind
+
+declare i32 @printf(i8*, ...) nounwind
+
More information about the llvm-commits
mailing list