xref: /aosp_15_r20/external/llvm/test/Analysis/ScalarEvolution/trip-count7.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -analyze -scalar-evolution | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Worker; CHECK: Loop %bb7.i: Unpredictable backedge-taken count.
6*9880d681SAndroid Build Coastguard Worker
7*9880d681SAndroid Build Coastguard Worker	%struct.complex = type { float, float }
8*9880d681SAndroid Build Coastguard Worker	%struct.element = type { i32, i32 }
9*9880d681SAndroid Build Coastguard Worker	%struct.node = type { %struct.node*, %struct.node*, i32 }
10*9880d681SAndroid Build Coastguard Worker@seed = external global i64		; <i64*> [#uses=0]
11*9880d681SAndroid Build Coastguard Worker@_2E_str = external constant [18 x i8], align 1		; <[18 x i8]*> [#uses=0]
12*9880d681SAndroid Build Coastguard Worker@_2E_str1 = external constant [4 x i8], align 1		; <[4 x i8]*> [#uses=0]
13*9880d681SAndroid Build Coastguard Worker@value = external global float		; <float*> [#uses=0]
14*9880d681SAndroid Build Coastguard Worker@fixed = external global float		; <float*> [#uses=0]
15*9880d681SAndroid Build Coastguard Worker@floated = external global float		; <float*> [#uses=0]
16*9880d681SAndroid Build Coastguard Worker@permarray = external global [11 x i32], align 32		; <[11 x i32]*> [#uses=0]
17*9880d681SAndroid Build Coastguard Worker@pctr = external global i32		; <i32*> [#uses=0]
18*9880d681SAndroid Build Coastguard Worker@tree = external global %struct.node*		; <%struct.node**> [#uses=0]
19*9880d681SAndroid Build Coastguard Worker@stack = external global [4 x i32], align 16		; <[4 x i32]*> [#uses=0]
20*9880d681SAndroid Build Coastguard Worker@cellspace = external global [19 x %struct.element], align 32		; <[19 x %struct.element]*> [#uses=0]
21*9880d681SAndroid Build Coastguard Worker@freelist = external global i32		; <i32*> [#uses=0]
22*9880d681SAndroid Build Coastguard Worker@movesdone = external global i32		; <i32*> [#uses=0]
23*9880d681SAndroid Build Coastguard Worker@ima = external global [41 x [41 x i32]], align 32		; <[41 x [41 x i32]]*> [#uses=0]
24*9880d681SAndroid Build Coastguard Worker@imb = external global [41 x [41 x i32]], align 32		; <[41 x [41 x i32]]*> [#uses=0]
25*9880d681SAndroid Build Coastguard Worker@imr = external global [41 x [41 x i32]], align 32		; <[41 x [41 x i32]]*> [#uses=0]
26*9880d681SAndroid Build Coastguard Worker@rma = external global [41 x [41 x float]], align 32		; <[41 x [41 x float]]*> [#uses=0]
27*9880d681SAndroid Build Coastguard Worker@rmb = external global [41 x [41 x float]], align 32		; <[41 x [41 x float]]*> [#uses=0]
28*9880d681SAndroid Build Coastguard Worker@rmr = external global [41 x [41 x float]], align 32		; <[41 x [41 x float]]*> [#uses=0]
29*9880d681SAndroid Build Coastguard Worker@piececount = external global [4 x i32], align 16		; <[4 x i32]*> [#uses=0]
30*9880d681SAndroid Build Coastguard Worker@class = external global [13 x i32], align 32		; <[13 x i32]*> [#uses=0]
31*9880d681SAndroid Build Coastguard Worker@piecemax = external global [13 x i32], align 32		; <[13 x i32]*> [#uses=0]
32*9880d681SAndroid Build Coastguard Worker@puzzl = external global [512 x i32], align 32		; <[512 x i32]*> [#uses=0]
33*9880d681SAndroid Build Coastguard Worker@p = external global [13 x [512 x i32]], align 32		; <[13 x [512 x i32]]*> [#uses=0]
34*9880d681SAndroid Build Coastguard Worker@n = external global i32		; <i32*> [#uses=0]
35*9880d681SAndroid Build Coastguard Worker@kount = external global i32		; <i32*> [#uses=0]
36*9880d681SAndroid Build Coastguard Worker@sortlist = external global [5001 x i32], align 32		; <[5001 x i32]*> [#uses=0]
37*9880d681SAndroid Build Coastguard Worker@biggest = external global i32		; <i32*> [#uses=0]
38*9880d681SAndroid Build Coastguard Worker@littlest = external global i32		; <i32*> [#uses=0]
39*9880d681SAndroid Build Coastguard Worker@top = external global i32		; <i32*> [#uses=0]
40*9880d681SAndroid Build Coastguard Worker@z = external global [257 x %struct.complex], align 32		; <[257 x %struct.complex]*> [#uses=0]
41*9880d681SAndroid Build Coastguard Worker@w = external global [257 x %struct.complex], align 32		; <[257 x %struct.complex]*> [#uses=0]
42*9880d681SAndroid Build Coastguard Worker@e = external global [130 x %struct.complex], align 32		; <[130 x %struct.complex]*> [#uses=0]
43*9880d681SAndroid Build Coastguard Worker@zr = external global float		; <float*> [#uses=0]
44*9880d681SAndroid Build Coastguard Worker@zi = external global float		; <float*> [#uses=0]
45*9880d681SAndroid Build Coastguard Worker
46*9880d681SAndroid Build Coastguard Workerdeclare void @Initrand() nounwind
47*9880d681SAndroid Build Coastguard Worker
48*9880d681SAndroid Build Coastguard Workerdeclare i32 @Rand() nounwind
49*9880d681SAndroid Build Coastguard Worker
50*9880d681SAndroid Build Coastguard Workerdeclare void @Try(i32, i32*, i32*, i32*, i32*, i32*) nounwind
51*9880d681SAndroid Build Coastguard Worker
52*9880d681SAndroid Build Coastguard Workerdeclare i32 @puts(i8* nocapture) nounwind
53*9880d681SAndroid Build Coastguard Worker
54*9880d681SAndroid Build Coastguard Workerdeclare void @Queens(i32) nounwind
55*9880d681SAndroid Build Coastguard Worker
56*9880d681SAndroid Build Coastguard Workerdeclare i32 @printf(i8* nocapture, ...) nounwind
57*9880d681SAndroid Build Coastguard Worker
58*9880d681SAndroid Build Coastguard Workerdeclare i32 @main() nounwind
59*9880d681SAndroid Build Coastguard Worker
60*9880d681SAndroid Build Coastguard Workerdeclare void @Doit() nounwind
61*9880d681SAndroid Build Coastguard Worker
62*9880d681SAndroid Build Coastguard Workerdeclare void @Doit_bb7([15 x i32]*, [17 x i32]*, [9 x i32]*) nounwind
63*9880d681SAndroid Build Coastguard Worker
64*9880d681SAndroid Build Coastguard Workerdefine void @Doit_bb7_2E_i([9 x i32]* %x1, [15 x i32]* %c, [17 x i32]* %b, [9 x i32]* %a, i32* %q, i32* %x1.sub, i32* %b9, i32* %a10, i32* %c11) nounwind {
65*9880d681SAndroid Build Coastguard WorkernewFuncRoot:
66*9880d681SAndroid Build Coastguard Worker	br label %bb7.i
67*9880d681SAndroid Build Coastguard Worker
68*9880d681SAndroid Build Coastguard WorkerTry.exit.exitStub:		; preds = %bb7.i
69*9880d681SAndroid Build Coastguard Worker	ret void
70*9880d681SAndroid Build Coastguard Worker
71*9880d681SAndroid Build Coastguard Workerbb.i:		; preds = %bb7.i
72*9880d681SAndroid Build Coastguard Worker	%tmp = add i32 %j.0.i, 1		; <i32> [#uses=5]
73*9880d681SAndroid Build Coastguard Worker	store i32 0, i32* %q, align 4
74*9880d681SAndroid Build Coastguard Worker	%tmp1 = sext i32 %tmp to i64		; <i64> [#uses=1]
75*9880d681SAndroid Build Coastguard Worker	%tmp2 = getelementptr [9 x i32], [9 x i32]* %a, i64 0, i64 %tmp1		; <i32*> [#uses=1]
76*9880d681SAndroid Build Coastguard Worker	%tmp3 = load i32, i32* %tmp2, align 4		; <i32> [#uses=1]
77*9880d681SAndroid Build Coastguard Worker	%tmp4 = icmp eq i32 %tmp3, 0		; <i1> [#uses=1]
78*9880d681SAndroid Build Coastguard Worker	br i1 %tmp4, label %bb.i.bb7.i.backedge_crit_edge, label %bb1.i
79*9880d681SAndroid Build Coastguard Worker
80*9880d681SAndroid Build Coastguard Workerbb1.i:		; preds = %bb.i
81*9880d681SAndroid Build Coastguard Worker	%tmp5 = add i32 %j.0.i, 2		; <i32> [#uses=1]
82*9880d681SAndroid Build Coastguard Worker	%tmp6 = sext i32 %tmp5 to i64		; <i64> [#uses=1]
83*9880d681SAndroid Build Coastguard Worker	%tmp7 = getelementptr [17 x i32], [17 x i32]* %b, i64 0, i64 %tmp6		; <i32*> [#uses=1]
84*9880d681SAndroid Build Coastguard Worker	%tmp8 = load i32, i32* %tmp7, align 4		; <i32> [#uses=1]
85*9880d681SAndroid Build Coastguard Worker	%tmp9 = icmp eq i32 %tmp8, 0		; <i1> [#uses=1]
86*9880d681SAndroid Build Coastguard Worker	br i1 %tmp9, label %bb1.i.bb7.i.backedge_crit_edge, label %bb2.i
87*9880d681SAndroid Build Coastguard Worker
88*9880d681SAndroid Build Coastguard Workerbb2.i:		; preds = %bb1.i
89*9880d681SAndroid Build Coastguard Worker	%tmp10 = sub i32 7, %j.0.i		; <i32> [#uses=1]
90*9880d681SAndroid Build Coastguard Worker	%tmp11 = sext i32 %tmp10 to i64		; <i64> [#uses=1]
91*9880d681SAndroid Build Coastguard Worker	%tmp12 = getelementptr [15 x i32], [15 x i32]* %c, i64 0, i64 %tmp11		; <i32*> [#uses=1]
92*9880d681SAndroid Build Coastguard Worker	%tmp13 = load i32, i32* %tmp12, align 4		; <i32> [#uses=1]
93*9880d681SAndroid Build Coastguard Worker	%tmp14 = icmp eq i32 %tmp13, 0		; <i1> [#uses=1]
94*9880d681SAndroid Build Coastguard Worker	br i1 %tmp14, label %bb2.i.bb7.i.backedge_crit_edge, label %bb3.i
95*9880d681SAndroid Build Coastguard Worker
96*9880d681SAndroid Build Coastguard Workerbb3.i:		; preds = %bb2.i
97*9880d681SAndroid Build Coastguard Worker	%tmp15 = getelementptr [9 x i32], [9 x i32]* %x1, i64 0, i64 1		; <i32*> [#uses=1]
98*9880d681SAndroid Build Coastguard Worker	store i32 %tmp, i32* %tmp15, align 4
99*9880d681SAndroid Build Coastguard Worker	%tmp16 = sext i32 %tmp to i64		; <i64> [#uses=1]
100*9880d681SAndroid Build Coastguard Worker	%tmp17 = getelementptr [9 x i32], [9 x i32]* %a, i64 0, i64 %tmp16		; <i32*> [#uses=1]
101*9880d681SAndroid Build Coastguard Worker	store i32 0, i32* %tmp17, align 4
102*9880d681SAndroid Build Coastguard Worker	%tmp18 = add i32 %j.0.i, 2		; <i32> [#uses=1]
103*9880d681SAndroid Build Coastguard Worker	%tmp19 = sext i32 %tmp18 to i64		; <i64> [#uses=1]
104*9880d681SAndroid Build Coastguard Worker	%tmp20 = getelementptr [17 x i32], [17 x i32]* %b, i64 0, i64 %tmp19		; <i32*> [#uses=1]
105*9880d681SAndroid Build Coastguard Worker	store i32 0, i32* %tmp20, align 4
106*9880d681SAndroid Build Coastguard Worker	%tmp21 = sub i32 7, %j.0.i		; <i32> [#uses=1]
107*9880d681SAndroid Build Coastguard Worker	%tmp22 = sext i32 %tmp21 to i64		; <i64> [#uses=1]
108*9880d681SAndroid Build Coastguard Worker	%tmp23 = getelementptr [15 x i32], [15 x i32]* %c, i64 0, i64 %tmp22		; <i32*> [#uses=1]
109*9880d681SAndroid Build Coastguard Worker	store i32 0, i32* %tmp23, align 4
110*9880d681SAndroid Build Coastguard Worker	call void @Try(i32 2, i32* %q, i32* %b9, i32* %a10, i32* %c11, i32* %x1.sub) nounwind
111*9880d681SAndroid Build Coastguard Worker	%tmp24 = load i32, i32* %q, align 4		; <i32> [#uses=1]
112*9880d681SAndroid Build Coastguard Worker	%tmp25 = icmp eq i32 %tmp24, 0		; <i1> [#uses=1]
113*9880d681SAndroid Build Coastguard Worker	br i1 %tmp25, label %bb5.i, label %bb3.i.bb7.i.backedge_crit_edge
114*9880d681SAndroid Build Coastguard Worker
115*9880d681SAndroid Build Coastguard Workerbb5.i:		; preds = %bb3.i
116*9880d681SAndroid Build Coastguard Worker	%tmp26 = sext i32 %tmp to i64		; <i64> [#uses=1]
117*9880d681SAndroid Build Coastguard Worker	%tmp27 = getelementptr [9 x i32], [9 x i32]* %a, i64 0, i64 %tmp26		; <i32*> [#uses=1]
118*9880d681SAndroid Build Coastguard Worker	store i32 1, i32* %tmp27, align 4
119*9880d681SAndroid Build Coastguard Worker	%tmp28 = add i32 %j.0.i, 2		; <i32> [#uses=1]
120*9880d681SAndroid Build Coastguard Worker	%tmp29 = sext i32 %tmp28 to i64		; <i64> [#uses=1]
121*9880d681SAndroid Build Coastguard Worker	%tmp30 = getelementptr [17 x i32], [17 x i32]* %b, i64 0, i64 %tmp29		; <i32*> [#uses=1]
122*9880d681SAndroid Build Coastguard Worker	store i32 1, i32* %tmp30, align 4
123*9880d681SAndroid Build Coastguard Worker	%tmp31 = sub i32 7, %j.0.i		; <i32> [#uses=1]
124*9880d681SAndroid Build Coastguard Worker	%tmp32 = sext i32 %tmp31 to i64		; <i64> [#uses=1]
125*9880d681SAndroid Build Coastguard Worker	%tmp33 = getelementptr [15 x i32], [15 x i32]* %c, i64 0, i64 %tmp32		; <i32*> [#uses=1]
126*9880d681SAndroid Build Coastguard Worker	store i32 1, i32* %tmp33, align 4
127*9880d681SAndroid Build Coastguard Worker	br label %bb7.i.backedge
128*9880d681SAndroid Build Coastguard Worker
129*9880d681SAndroid Build Coastguard Workerbb7.i.backedge:		; preds = %bb3.i.bb7.i.backedge_crit_edge, %bb2.i.bb7.i.backedge_crit_edge, %bb1.i.bb7.i.backedge_crit_edge, %bb.i.bb7.i.backedge_crit_edge, %bb5.i
130*9880d681SAndroid Build Coastguard Worker	br label %bb7.i
131*9880d681SAndroid Build Coastguard Worker
132*9880d681SAndroid Build Coastguard Workerbb7.i:		; preds = %bb7.i.backedge, %newFuncRoot
133*9880d681SAndroid Build Coastguard Worker	%j.0.i = phi i32 [ 0, %newFuncRoot ], [ %tmp, %bb7.i.backedge ]		; <i32> [#uses=8]
134*9880d681SAndroid Build Coastguard Worker	%tmp34 = load i32, i32* %q, align 4		; <i32> [#uses=1]
135*9880d681SAndroid Build Coastguard Worker	%tmp35 = icmp eq i32 %tmp34, 0		; <i1> [#uses=1]
136*9880d681SAndroid Build Coastguard Worker	%tmp36 = icmp ne i32 %j.0.i, 8		; <i1> [#uses=1]
137*9880d681SAndroid Build Coastguard Worker	%tmp37 = and i1 %tmp35, %tmp36		; <i1> [#uses=1]
138*9880d681SAndroid Build Coastguard Worker	br i1 %tmp37, label %bb.i, label %Try.exit.exitStub
139*9880d681SAndroid Build Coastguard Worker
140*9880d681SAndroid Build Coastguard Workerbb.i.bb7.i.backedge_crit_edge:		; preds = %bb.i
141*9880d681SAndroid Build Coastguard Worker	br label %bb7.i.backedge
142*9880d681SAndroid Build Coastguard Worker
143*9880d681SAndroid Build Coastguard Workerbb1.i.bb7.i.backedge_crit_edge:		; preds = %bb1.i
144*9880d681SAndroid Build Coastguard Worker	br label %bb7.i.backedge
145*9880d681SAndroid Build Coastguard Worker
146*9880d681SAndroid Build Coastguard Workerbb2.i.bb7.i.backedge_crit_edge:		; preds = %bb2.i
147*9880d681SAndroid Build Coastguard Worker	br label %bb7.i.backedge
148*9880d681SAndroid Build Coastguard Worker
149*9880d681SAndroid Build Coastguard Workerbb3.i.bb7.i.backedge_crit_edge:		; preds = %bb3.i
150*9880d681SAndroid Build Coastguard Worker	br label %bb7.i.backedge
151*9880d681SAndroid Build Coastguard Worker}
152