Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / Analysis / ScalarEvolution / trip-count-pow2.ll
blobfb225376d38b37d98a50f67fa969f29151288edf
1 ; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 4
2 ; RUN: opt < %s "-passes=print<scalar-evolution>" -scalar-evolution-classify-expressions=0 -disable-output 2>&1 | FileCheck %s
4 define void @test1(i32 %n) {
5 ; CHECK-LABEL: 'test1'
6 ; CHECK-NEXT:  Determining loop execution counts for: @test1
7 ; CHECK-NEXT:  Loop %loop: backedge-taken count is ((-32 + (96 * %n)) /u 32)
8 ; CHECK-NEXT:  Loop %loop: constant max backedge-taken count is i32 134217727
9 ; CHECK-NEXT:  Loop %loop: symbolic max backedge-taken count is ((-32 + (96 * %n)) /u 32)
10 ; CHECK-NEXT:  Loop %loop: Trip multiple is 1
12 entry:
13   %s = mul i32 %n, 96
14   br label %loop
15 loop:
16   %i = phi i32 [ 0, %entry ], [ %i.next, %loop ]
17   %i.next = add i32 %i, 32
18   %t = icmp ne i32 %i.next, %s
19   br i1 %t, label %loop, label %exit
20 exit:
21   ret void
25 ; PR19183
26 define i32 @test2(i32 %n) {
27 ; CHECK-LABEL: 'test2'
28 ; CHECK-NEXT:  Determining loop execution counts for: @test2
29 ; CHECK-NEXT:  Loop %loop: backedge-taken count is ((-32 + (32 * (%n /u 32))<nuw>) /u 32)
30 ; CHECK-NEXT:  Loop %loop: constant max backedge-taken count is i32 134217727
31 ; CHECK-NEXT:  Loop %loop: symbolic max backedge-taken count is ((-32 + (32 * (%n /u 32))<nuw>) /u 32)
32 ; CHECK-NEXT:  Loop %loop: Trip multiple is 1
34 entry:
35   %s = and i32 %n, -32
36   br label %loop
37 loop:
38   %i = phi i32 [ 0, %entry ], [ %i.next, %loop ]
39   %i.next = add i32 %i, 32
40   %t = icmp ne i32 %i.next, %s
41   br i1 %t, label %loop, label %exit
42 exit:
43   ret i32 %i
47 define void @test3(i32 %n) {
48 ; CHECK-LABEL: 'test3'
49 ; CHECK-NEXT:  Determining loop execution counts for: @test3
50 ; CHECK-NEXT:  Loop %loop: backedge-taken count is ((-32 + (32 * %n)) /u 32)
51 ; CHECK-NEXT:  Loop %loop: constant max backedge-taken count is i32 134217727
52 ; CHECK-NEXT:  Loop %loop: symbolic max backedge-taken count is ((-32 + (32 * %n)) /u 32)
53 ; CHECK-NEXT:  Loop %loop: Trip multiple is 1
55 entry:
56   %s = mul i32 %n, 96
57   br label %loop
58 loop:
59   %i = phi i32 [ 0, %entry ], [ %i.next, %loop ]
60   %i.next = add i32 %i, 96
61   %t = icmp ne i32 %i.next, %s
62   br i1 %t, label %loop, label %exit
63 exit:
64   ret void
68 define void @test4(i32 %n) {
69 ; CHECK-LABEL: 'test4'
70 ; CHECK-NEXT:  Determining loop execution counts for: @test4
71 ; CHECK-NEXT:  Loop %loop: backedge-taken count is ((-4 + (-1431655764 * %n)) /u 4)
72 ; CHECK-NEXT:  Loop %loop: constant max backedge-taken count is i32 1073741823
73 ; CHECK-NEXT:  Loop %loop: symbolic max backedge-taken count is ((-4 + (-1431655764 * %n)) /u 4)
74 ; CHECK-NEXT:  Loop %loop: Trip multiple is 1
76 entry:
77   %s = mul i32 %n, 4
78   br label %loop
79 loop:
80   %i = phi i32 [ 0, %entry ], [ %i.next, %loop ]
81   %i.next = add i32 %i, 12
82   %t = icmp ne i32 %i.next, %s
83   br i1 %t, label %loop, label %exit
84 exit:
85   ret void
89 define void @test5(i32 %n) {
90 ; CHECK-LABEL: 'test5'
91 ; CHECK-NEXT:  Determining loop execution counts for: @test5
92 ; CHECK-NEXT:  Loop %loop: backedge-taken count is ((-4 + (4 * %n)) /u 4)
93 ; CHECK-NEXT:  Loop %loop: constant max backedge-taken count is i32 1073741823
94 ; CHECK-NEXT:  Loop %loop: symbolic max backedge-taken count is ((-4 + (4 * %n)) /u 4)
95 ; CHECK-NEXT:  Loop %loop: Trip multiple is 1
97 entry:
98   %s = mul i32 %n, 4
99   br label %loop
100 loop:
101   %i = phi i32 [ %s, %entry ], [ %i.next, %loop ]
102   %i.next = add i32 %i, -4
103   %t = icmp ne i32 %i.next, 0
104   br i1 %t, label %loop, label %exit
105 exit:
106   ret void