Land the long talked about "type system rewrite" patch. This
[llvm/stm8.git] / test / Transforms / LoopDeletion / multiple-exit-conditions.ll
blob87f8f461050d8aabf347150e1eabf7e5a560f73e
1 ; RUN: opt < %s -loop-deletion -S | FileCheck %s
3 ; ScalarEvolution can prove the loop iteration is finite, even though
4 ; it can't represent the exact trip count as an expression. That's
5 ; good enough to let the loop be deleted.
7 ; CHECK:      entry:
8 ; CHECK-NEXT:   br label %return
10 ; CHECK:      return:
11 ; CHECK-NEXT:   ret void
13 define void @foo(i64 %n, i64 %m) nounwind {
14 entry:
15   br label %bb
17 bb:
18   %x.0 = phi i64 [ 0, %entry ], [ %t0, %bb ]
19   %t0 = add i64 %x.0, 1
20   %t1 = icmp slt i64 %x.0, %n
21   %t3 = icmp sgt i64 %x.0, %m
22   %t4 = and i1 %t1, %t3
23   br i1 %t4, label %bb, label %return
25 return:
26   ret void