aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2008-09-16 18:52:57 +0000
committerDan Gohman <gohman@apple.com>2008-09-16 18:52:57 +0000
commit70ff4cf1baf8cce04b38752ea485425782fb07b8 (patch)
tree8c577c8b629c215ae200ce2e0505518be0681a14
parent81b28ceab6bd0ed6a784b7dc952ddb0b03fc6de7 (diff)
downloadexternal_llvm-70ff4cf1baf8cce04b38752ea485425782fb07b8.zip
external_llvm-70ff4cf1baf8cce04b38752ea485425782fb07b8.tar.gz
external_llvm-70ff4cf1baf8cce04b38752ea485425782fb07b8.tar.bz2
Finally re-apply r46959. This is made feasible by the combination
of r56230, r56232, and r56246. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@56247 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Analysis/ScalarEvolution.cpp4
-rw-r--r--test/Analysis/ScalarEvolution/2008-02-11-ReversedCondition.ll1
-rw-r--r--test/Analysis/ScalarEvolution/avoid-smax-1.ll6
3 files changed, 6 insertions, 5 deletions
diff --git a/lib/Analysis/ScalarEvolution.cpp b/lib/Analysis/ScalarEvolution.cpp
index 4e85e90..5125804 100644
--- a/lib/Analysis/ScalarEvolution.cpp
+++ b/lib/Analysis/ScalarEvolution.cpp
@@ -1981,8 +1981,8 @@ SCEVHandle ScalarEvolutionsImpl::ComputeIterationCount(const Loop *L) {
// At this point, we would like to compute how many iterations of the
// loop the predicate will return true for these inputs.
- if (isa<SCEVConstant>(LHS) && !isa<SCEVConstant>(RHS)) {
- // If there is a constant, force it into the RHS.
+ if (LHS->isLoopInvariant(L) && !RHS->isLoopInvariant(L)) {
+ // If there is a loop-invariant, force it into the RHS.
std::swap(LHS, RHS);
Cond = ICmpInst::getSwappedPredicate(Cond);
}
diff --git a/test/Analysis/ScalarEvolution/2008-02-11-ReversedCondition.ll b/test/Analysis/ScalarEvolution/2008-02-11-ReversedCondition.ll
index 119e165..a01007d 100644
--- a/test/Analysis/ScalarEvolution/2008-02-11-ReversedCondition.ll
+++ b/test/Analysis/ScalarEvolution/2008-02-11-ReversedCondition.ll
@@ -1,5 +1,4 @@
; RUN: llvm-as < %s | opt -scalar-evolution -analyze | grep {Loop header: (0 smax %n) iterations!}
-; XFAIL: *
define void @foo(i32 %n) {
entry:
diff --git a/test/Analysis/ScalarEvolution/avoid-smax-1.ll b/test/Analysis/ScalarEvolution/avoid-smax-1.ll
index 5fcbf62..b2d0ba0 100644
--- a/test/Analysis/ScalarEvolution/avoid-smax-1.ll
+++ b/test/Analysis/ScalarEvolution/avoid-smax-1.ll
@@ -1,11 +1,13 @@
; RUN: llvm-as < %s | opt -indvars | llvm-dis > %t
-; RUN: not grep select %t
+; RUN: grep select %t | count 2
; RUN: grep {icmp ne i32.\* %w } %t
; Indvars should be able to insert a canonical induction variable
; for the bb6 loop without using a maximum calculation (icmp, select)
; because it should be able to prove that the comparison is guarded
-; by an appropriate conditional branch.
+; by an appropriate conditional branch. Unfortunately, indvars is
+; not yet able to find the comparison for the other too loops in
+; this testcase.
target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128"
target triple = "i386-apple-darwin9"