xref: /llvm-project/llvm/test/Analysis/ScalarEvolution/huge-trip-multiple.ll (revision 0d38f21e4ab7fe7cebe76a9d7c218ec54dba1e98)
1d36efa96SJoshua Cao; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 2
2d36efa96SJoshua Cao; RUN: opt < %s -disable-output "-passes=print<scalar-evolution>" 2>&1 | FileCheck %s
3d36efa96SJoshua Cao
4898a9ca5SJoshua Cao; Tests loops with huge trip counts. Trip count of >=2^32 are huge. Huge trip counts have a trip multiple
5898a9ca5SJoshua Cao; of the greatest power of 2 less than 2^32.
6d36efa96SJoshua Cao
7d36efa96SJoshua Caodeclare void @foo(...)
8d36efa96SJoshua Cao
9d36efa96SJoshua Caodefine void @trip_count_4294967295() {
10d36efa96SJoshua Cao; CHECK-LABEL: 'trip_count_4294967295'
11d36efa96SJoshua Cao; CHECK-NEXT:  Classifying expressions for: @trip_count_4294967295
12d36efa96SJoshua Cao; CHECK-NEXT:    %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ]
13d36efa96SJoshua Cao; CHECK-NEXT:    --> {0,+,1}<nuw><nsw><%for.body> U: [0,4294967295) S: [0,4294967295) Exits: 4294967294 LoopDispositions: { %for.body: Computable }
14d36efa96SJoshua Cao; CHECK-NEXT:    %add = add nuw nsw i64 %i.02, 1
15d36efa96SJoshua Cao; CHECK-NEXT:    --> {1,+,1}<nuw><nsw><%for.body> U: [1,4294967296) S: [1,4294967296) Exits: 4294967295 LoopDispositions: { %for.body: Computable }
16d36efa96SJoshua Cao; CHECK-NEXT:  Determining loop execution counts for: @trip_count_4294967295
17*0d38f21eSPhilip Reames; CHECK-NEXT:  Loop %for.body: backedge-taken count is i64 4294967294
187755c261SPhilip Reames; CHECK-NEXT:  Loop %for.body: constant max backedge-taken count is i64 4294967294
19*0d38f21eSPhilip Reames; CHECK-NEXT:  Loop %for.body: symbolic max backedge-taken count is i64 4294967294
2088f7dc17SNikita Popov; CHECK-NEXT:  Loop %for.body: Trip multiple is 4294967295
21d36efa96SJoshua Cao;
22d36efa96SJoshua Caoentry:
23d36efa96SJoshua Cao  br label %for.body
24d36efa96SJoshua Cao
25d36efa96SJoshua Caofor.cond.cleanup:                                 ; preds = %for.body
26d36efa96SJoshua Cao  ret void
27d36efa96SJoshua Cao
28d36efa96SJoshua Caofor.body:                                         ; preds = %entry, %for.body
29d36efa96SJoshua Cao  %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ]
30d36efa96SJoshua Cao  tail call void (...) @foo() #2
31d36efa96SJoshua Cao  %add = add nuw nsw i64 %i.02, 1
32d36efa96SJoshua Cao  %exitcond.not = icmp eq i64 %add, 4294967295
33d36efa96SJoshua Cao  br i1 %exitcond.not, label %for.cond.cleanup, label %for.body
34d36efa96SJoshua Cao}
35d36efa96SJoshua Cao
36d36efa96SJoshua Caodefine void @trip_count_4294967296() {
37d36efa96SJoshua Cao; CHECK-LABEL: 'trip_count_4294967296'
38d36efa96SJoshua Cao; CHECK-NEXT:  Classifying expressions for: @trip_count_4294967296
39d36efa96SJoshua Cao; CHECK-NEXT:    %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ]
40d36efa96SJoshua Cao; CHECK-NEXT:    --> {0,+,1}<nuw><nsw><%for.body> U: [0,4294967296) S: [0,4294967296) Exits: 4294967295 LoopDispositions: { %for.body: Computable }
41d36efa96SJoshua Cao; CHECK-NEXT:    %add = add nuw nsw i64 %i.02, 1
42d36efa96SJoshua Cao; CHECK-NEXT:    --> {1,+,1}<nuw><nsw><%for.body> U: [1,4294967297) S: [1,4294967297) Exits: 4294967296 LoopDispositions: { %for.body: Computable }
43d36efa96SJoshua Cao; CHECK-NEXT:  Determining loop execution counts for: @trip_count_4294967296
44*0d38f21eSPhilip Reames; CHECK-NEXT:  Loop %for.body: backedge-taken count is i64 4294967295
457755c261SPhilip Reames; CHECK-NEXT:  Loop %for.body: constant max backedge-taken count is i64 4294967295
46*0d38f21eSPhilip Reames; CHECK-NEXT:  Loop %for.body: symbolic max backedge-taken count is i64 4294967295
4788f7dc17SNikita Popov; CHECK-NEXT:  Loop %for.body: Trip multiple is 2147483648
48d36efa96SJoshua Cao;
49d36efa96SJoshua Caoentry:
50d36efa96SJoshua Cao  br label %for.body
51d36efa96SJoshua Cao
52d36efa96SJoshua Caofor.cond.cleanup:                                 ; preds = %for.body
53d36efa96SJoshua Cao  ret void
54d36efa96SJoshua Cao
55d36efa96SJoshua Caofor.body:                                         ; preds = %entry, %for.body
56d36efa96SJoshua Cao  %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ]
57d36efa96SJoshua Cao  tail call void (...) @foo() #2
58d36efa96SJoshua Cao  %add = add nuw nsw i64 %i.02, 1
59d36efa96SJoshua Cao  %exitcond.not = icmp eq i64 %add, 4294967296
60d36efa96SJoshua Cao  br i1 %exitcond.not, label %for.cond.cleanup, label %for.body
61d36efa96SJoshua Cao}
62d36efa96SJoshua Cao
63d36efa96SJoshua Caodefine void @trip_count_8589935692() {
64d36efa96SJoshua Cao; CHECK-LABEL: 'trip_count_8589935692'
65d36efa96SJoshua Cao; CHECK-NEXT:  Classifying expressions for: @trip_count_8589935692
66d36efa96SJoshua Cao; CHECK-NEXT:    %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ]
67d36efa96SJoshua Cao; CHECK-NEXT:    --> {0,+,1}<nuw><nsw><%for.body> U: [0,8589934592) S: [0,8589934592) Exits: 8589934591 LoopDispositions: { %for.body: Computable }
68d36efa96SJoshua Cao; CHECK-NEXT:    %add = add nuw nsw i64 %i.02, 1
69d36efa96SJoshua Cao; CHECK-NEXT:    --> {1,+,1}<nuw><nsw><%for.body> U: [1,8589934593) S: [1,8589934593) Exits: 8589934592 LoopDispositions: { %for.body: Computable }
70d36efa96SJoshua Cao; CHECK-NEXT:  Determining loop execution counts for: @trip_count_8589935692
71*0d38f21eSPhilip Reames; CHECK-NEXT:  Loop %for.body: backedge-taken count is i64 8589934591
727755c261SPhilip Reames; CHECK-NEXT:  Loop %for.body: constant max backedge-taken count is i64 8589934591
73*0d38f21eSPhilip Reames; CHECK-NEXT:  Loop %for.body: symbolic max backedge-taken count is i64 8589934591
7488f7dc17SNikita Popov; CHECK-NEXT:  Loop %for.body: Trip multiple is 2147483648
75d36efa96SJoshua Cao;
76d36efa96SJoshua Caoentry:
77d36efa96SJoshua Cao  br label %for.body
78d36efa96SJoshua Cao
79d36efa96SJoshua Caofor.cond.cleanup:                                 ; preds = %for.body
80d36efa96SJoshua Cao  ret void
81d36efa96SJoshua Cao
82d36efa96SJoshua Caofor.body:                                         ; preds = %entry, %for.body
83d36efa96SJoshua Cao  %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ]
84d36efa96SJoshua Cao  tail call void (...) @foo() #2
85d36efa96SJoshua Cao  %add = add nuw nsw i64 %i.02, 1
86d36efa96SJoshua Cao  %exitcond.not = icmp eq i64 %add, 8589934592
87d36efa96SJoshua Cao  br i1 %exitcond.not, label %for.cond.cleanup, label %for.body
88d36efa96SJoshua Cao}
89d36efa96SJoshua Cao
90d36efa96SJoshua Caodefine void @trip_count_9223372036854775808() {
91d36efa96SJoshua Cao; CHECK-LABEL: 'trip_count_9223372036854775808'
92d36efa96SJoshua Cao; CHECK-NEXT:  Classifying expressions for: @trip_count_9223372036854775808
93d36efa96SJoshua Cao; CHECK-NEXT:    %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ]
94d36efa96SJoshua Cao; CHECK-NEXT:    --> {0,+,1}<nuw><nsw><%for.body> U: [0,-9223372036854775808) S: [0,-9223372036854775808) Exits: 9223372036854775807 LoopDispositions: { %for.body: Computable }
95d36efa96SJoshua Cao; CHECK-NEXT:    %add = add nuw nsw i64 %i.02, 1
96d36efa96SJoshua Cao; CHECK-NEXT:    --> {1,+,1}<nuw><%for.body> U: [1,-9223372036854775807) S: [1,-9223372036854775807) Exits: -9223372036854775808 LoopDispositions: { %for.body: Computable }
97d36efa96SJoshua Cao; CHECK-NEXT:  Determining loop execution counts for: @trip_count_9223372036854775808
98*0d38f21eSPhilip Reames; CHECK-NEXT:  Loop %for.body: backedge-taken count is i64 9223372036854775807
997755c261SPhilip Reames; CHECK-NEXT:  Loop %for.body: constant max backedge-taken count is i64 9223372036854775807
100*0d38f21eSPhilip Reames; CHECK-NEXT:  Loop %for.body: symbolic max backedge-taken count is i64 9223372036854775807
10188f7dc17SNikita Popov; CHECK-NEXT:  Loop %for.body: Trip multiple is 2147483648
102d36efa96SJoshua Cao;
103d36efa96SJoshua Caoentry:
104d36efa96SJoshua Cao  br label %for.body
105d36efa96SJoshua Cao
106d36efa96SJoshua Caofor.cond.cleanup:                                 ; preds = %for.body
107d36efa96SJoshua Cao  ret void
108d36efa96SJoshua Cao
109d36efa96SJoshua Caofor.body:                                         ; preds = %entry, %for.body
110d36efa96SJoshua Cao  %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ]
111d36efa96SJoshua Cao  tail call void (...) @foo() #2
112d36efa96SJoshua Cao  %add = add nuw nsw i64 %i.02, 1
113d36efa96SJoshua Cao  %exitcond.not = icmp eq i64 %add, 9223372036854775808
114d36efa96SJoshua Cao  br i1 %exitcond.not, label %for.cond.cleanup, label %for.body
115d36efa96SJoshua Cao}
116d36efa96SJoshua Cao
117d36efa96SJoshua Caodefine void @trip_count_18446744073709551615() {
118d36efa96SJoshua Cao; CHECK-LABEL: 'trip_count_18446744073709551615'
119d36efa96SJoshua Cao; CHECK-NEXT:  Classifying expressions for: @trip_count_18446744073709551615
120d36efa96SJoshua Cao; CHECK-NEXT:    %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ]
121d36efa96SJoshua Cao; CHECK-NEXT:    --> {0,+,1}<nuw><nsw><%for.body> U: [0,-9223372036854775808) S: [0,-9223372036854775808) Exits: -2 LoopDispositions: { %for.body: Computable }
122d36efa96SJoshua Cao; CHECK-NEXT:    %add = add nuw nsw i64 %i.02, 1
123d36efa96SJoshua Cao; CHECK-NEXT:    --> {1,+,1}<nuw><%for.body> U: [1,0) S: [1,0) Exits: -1 LoopDispositions: { %for.body: Computable }
124d36efa96SJoshua Cao; CHECK-NEXT:  Determining loop execution counts for: @trip_count_18446744073709551615
125*0d38f21eSPhilip Reames; CHECK-NEXT:  Loop %for.body: backedge-taken count is i64 -2
1267755c261SPhilip Reames; CHECK-NEXT:  Loop %for.body: constant max backedge-taken count is i64 -2
127*0d38f21eSPhilip Reames; CHECK-NEXT:  Loop %for.body: symbolic max backedge-taken count is i64 -2
12888f7dc17SNikita Popov; CHECK-NEXT:  Loop %for.body: Trip multiple is 1
129d36efa96SJoshua Cao;
130d36efa96SJoshua Caoentry:
131d36efa96SJoshua Cao  br label %for.body
132d36efa96SJoshua Cao
133d36efa96SJoshua Caofor.cond.cleanup:                                 ; preds = %for.body
134d36efa96SJoshua Cao  ret void
135d36efa96SJoshua Cao
136d36efa96SJoshua Caofor.body:                                         ; preds = %entry, %for.body
137d36efa96SJoshua Cao  %i.02 = phi i64 [ 0, %entry ], [ %add, %for.body ]
138d36efa96SJoshua Cao  tail call void (...) @foo() #2
139d36efa96SJoshua Cao  %add = add nuw nsw i64 %i.02, 1
140d36efa96SJoshua Cao  %exitcond.not = icmp eq i64 %add, 18446744073709551615
141d36efa96SJoshua Cao  br i1 %exitcond.not, label %for.cond.cleanup, label %for.body
142d36efa96SJoshua Cao}
143