xref: /aosp_15_r20/external/llvm/test/Analysis/DependenceAnalysis/SymbolicRDIV.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -analyze -basicaa -da | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker; ModuleID = 'SymbolicRDIV.bc'
4*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-n8:16:32:64-S128"
5*9880d681SAndroid Build Coastguard Workertarget triple = "x86_64-apple-macosx10.6.0"
6*9880d681SAndroid Build Coastguard Worker
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker;;  for (long int i = 0; i < n1; i++)
9*9880d681SAndroid Build Coastguard Worker;;    A[2*i + n1] = i;
10*9880d681SAndroid Build Coastguard Worker;;  for (long int j = 0; j < n2; j++)
11*9880d681SAndroid Build Coastguard Worker;;    *B++ = A[3*j + 3*n1];
12*9880d681SAndroid Build Coastguard Worker
13*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv0(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp {
14*9880d681SAndroid Build Coastguard Workerentry:
15*9880d681SAndroid Build Coastguard Worker  %cmp4 = icmp eq i64 %n1, 0
16*9880d681SAndroid Build Coastguard Worker  br i1 %cmp4, label %for.cond1.preheader, label %for.body.preheader
17*9880d681SAndroid Build Coastguard Worker
18*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv0'
19*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
20*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
21*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
22*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
23*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
24*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
25*9880d681SAndroid Build Coastguard Worker
26*9880d681SAndroid Build Coastguard Workerfor.body.preheader:                               ; preds = %entry
27*9880d681SAndroid Build Coastguard Worker  br label %for.body
28*9880d681SAndroid Build Coastguard Worker
29*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader.loopexit:                     ; preds = %for.body
30*9880d681SAndroid Build Coastguard Worker  br label %for.cond1.preheader
31*9880d681SAndroid Build Coastguard Worker
32*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader:                              ; preds = %for.cond1.preheader.loopexit, %entry
33*9880d681SAndroid Build Coastguard Worker  %cmp21 = icmp eq i64 %n2, 0
34*9880d681SAndroid Build Coastguard Worker  br i1 %cmp21, label %for.end11, label %for.body4.preheader
35*9880d681SAndroid Build Coastguard Worker
36*9880d681SAndroid Build Coastguard Workerfor.body4.preheader:                              ; preds = %for.cond1.preheader
37*9880d681SAndroid Build Coastguard Worker  br label %for.body4
38*9880d681SAndroid Build Coastguard Worker
39*9880d681SAndroid Build Coastguard Workerfor.body:                                         ; preds = %for.body.preheader, %for.body
40*9880d681SAndroid Build Coastguard Worker  %i.05 = phi i64 [ %inc, %for.body ], [ 0, %for.body.preheader ]
41*9880d681SAndroid Build Coastguard Worker  %conv = trunc i64 %i.05 to i32
42*9880d681SAndroid Build Coastguard Worker  %mul = shl nsw i64 %i.05, 1
43*9880d681SAndroid Build Coastguard Worker  %add = add i64 %mul, %n1
44*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds i32, i32* %A, i64 %add
45*9880d681SAndroid Build Coastguard Worker  store i32 %conv, i32* %arrayidx, align 4
46*9880d681SAndroid Build Coastguard Worker  %inc = add nsw i64 %i.05, 1
47*9880d681SAndroid Build Coastguard Worker  %exitcond = icmp ne i64 %inc, %n1
48*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond, label %for.body, label %for.cond1.preheader.loopexit
49*9880d681SAndroid Build Coastguard Worker
50*9880d681SAndroid Build Coastguard Workerfor.body4:                                        ; preds = %for.body4.preheader, %for.body4
51*9880d681SAndroid Build Coastguard Worker  %j.03 = phi i64 [ %inc10, %for.body4 ], [ 0, %for.body4.preheader ]
52*9880d681SAndroid Build Coastguard Worker  %B.addr.02 = phi i32* [ %incdec.ptr, %for.body4 ], [ %B, %for.body4.preheader ]
53*9880d681SAndroid Build Coastguard Worker  %mul56 = add i64 %j.03, %n1
54*9880d681SAndroid Build Coastguard Worker  %add7 = mul i64 %mul56, 3
55*9880d681SAndroid Build Coastguard Worker  %arrayidx8 = getelementptr inbounds i32, i32* %A, i64 %add7
56*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* %arrayidx8, align 4
57*9880d681SAndroid Build Coastguard Worker  %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.02, i64 1
58*9880d681SAndroid Build Coastguard Worker  store i32 %0, i32* %B.addr.02, align 4
59*9880d681SAndroid Build Coastguard Worker  %inc10 = add nsw i64 %j.03, 1
60*9880d681SAndroid Build Coastguard Worker  %exitcond7 = icmp ne i64 %inc10, %n2
61*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond7, label %for.body4, label %for.end11.loopexit
62*9880d681SAndroid Build Coastguard Worker
63*9880d681SAndroid Build Coastguard Workerfor.end11.loopexit:                               ; preds = %for.body4
64*9880d681SAndroid Build Coastguard Worker  br label %for.end11
65*9880d681SAndroid Build Coastguard Worker
66*9880d681SAndroid Build Coastguard Workerfor.end11:                                        ; preds = %for.end11.loopexit, %for.cond1.preheader
67*9880d681SAndroid Build Coastguard Worker  ret void
68*9880d681SAndroid Build Coastguard Worker}
69*9880d681SAndroid Build Coastguard Worker
70*9880d681SAndroid Build Coastguard Worker
71*9880d681SAndroid Build Coastguard Worker;;  for (long int i = 0; i < n1; i++)
72*9880d681SAndroid Build Coastguard Worker;;    A[2*i + 5*n2] = i;
73*9880d681SAndroid Build Coastguard Worker;;  for (long int j = 0; j < n2; j++)
74*9880d681SAndroid Build Coastguard Worker;;    *B++ = A[3*j + 2*n2];
75*9880d681SAndroid Build Coastguard Worker
76*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv1(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp {
77*9880d681SAndroid Build Coastguard Workerentry:
78*9880d681SAndroid Build Coastguard Worker  %cmp4 = icmp eq i64 %n1, 0
79*9880d681SAndroid Build Coastguard Worker  br i1 %cmp4, label %for.cond2.preheader, label %for.body.preheader
80*9880d681SAndroid Build Coastguard Worker
81*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv1'
82*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
83*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
84*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
85*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
86*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
87*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
88*9880d681SAndroid Build Coastguard Worker
89*9880d681SAndroid Build Coastguard Workerfor.body.preheader:                               ; preds = %entry
90*9880d681SAndroid Build Coastguard Worker  br label %for.body
91*9880d681SAndroid Build Coastguard Worker
92*9880d681SAndroid Build Coastguard Workerfor.cond2.preheader.loopexit:                     ; preds = %for.body
93*9880d681SAndroid Build Coastguard Worker  br label %for.cond2.preheader
94*9880d681SAndroid Build Coastguard Worker
95*9880d681SAndroid Build Coastguard Workerfor.cond2.preheader:                              ; preds = %for.cond2.preheader.loopexit, %entry
96*9880d681SAndroid Build Coastguard Worker  %cmp31 = icmp eq i64 %n2, 0
97*9880d681SAndroid Build Coastguard Worker  br i1 %cmp31, label %for.end12, label %for.body5.preheader
98*9880d681SAndroid Build Coastguard Worker
99*9880d681SAndroid Build Coastguard Workerfor.body5.preheader:                              ; preds = %for.cond2.preheader
100*9880d681SAndroid Build Coastguard Worker  br label %for.body5
101*9880d681SAndroid Build Coastguard Worker
102*9880d681SAndroid Build Coastguard Workerfor.body:                                         ; preds = %for.body.preheader, %for.body
103*9880d681SAndroid Build Coastguard Worker  %i.05 = phi i64 [ %inc, %for.body ], [ 0, %for.body.preheader ]
104*9880d681SAndroid Build Coastguard Worker  %conv = trunc i64 %i.05 to i32
105*9880d681SAndroid Build Coastguard Worker  %mul = shl nsw i64 %i.05, 1
106*9880d681SAndroid Build Coastguard Worker  %mul1 = mul i64 %n2, 5
107*9880d681SAndroid Build Coastguard Worker  %add = add i64 %mul, %mul1
108*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds i32, i32* %A, i64 %add
109*9880d681SAndroid Build Coastguard Worker  store i32 %conv, i32* %arrayidx, align 4
110*9880d681SAndroid Build Coastguard Worker  %inc = add nsw i64 %i.05, 1
111*9880d681SAndroid Build Coastguard Worker  %exitcond = icmp ne i64 %inc, %n1
112*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond, label %for.body, label %for.cond2.preheader.loopexit
113*9880d681SAndroid Build Coastguard Worker
114*9880d681SAndroid Build Coastguard Workerfor.body5:                                        ; preds = %for.body5.preheader, %for.body5
115*9880d681SAndroid Build Coastguard Worker  %j.03 = phi i64 [ %inc11, %for.body5 ], [ 0, %for.body5.preheader ]
116*9880d681SAndroid Build Coastguard Worker  %B.addr.02 = phi i32* [ %incdec.ptr, %for.body5 ], [ %B, %for.body5.preheader ]
117*9880d681SAndroid Build Coastguard Worker  %mul6 = mul nsw i64 %j.03, 3
118*9880d681SAndroid Build Coastguard Worker  %mul7 = shl i64 %n2, 1
119*9880d681SAndroid Build Coastguard Worker  %add8 = add i64 %mul6, %mul7
120*9880d681SAndroid Build Coastguard Worker  %arrayidx9 = getelementptr inbounds i32, i32* %A, i64 %add8
121*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* %arrayidx9, align 4
122*9880d681SAndroid Build Coastguard Worker  %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.02, i64 1
123*9880d681SAndroid Build Coastguard Worker  store i32 %0, i32* %B.addr.02, align 4
124*9880d681SAndroid Build Coastguard Worker  %inc11 = add nsw i64 %j.03, 1
125*9880d681SAndroid Build Coastguard Worker  %exitcond6 = icmp ne i64 %inc11, %n2
126*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond6, label %for.body5, label %for.end12.loopexit
127*9880d681SAndroid Build Coastguard Worker
128*9880d681SAndroid Build Coastguard Workerfor.end12.loopexit:                               ; preds = %for.body5
129*9880d681SAndroid Build Coastguard Worker  br label %for.end12
130*9880d681SAndroid Build Coastguard Worker
131*9880d681SAndroid Build Coastguard Workerfor.end12:                                        ; preds = %for.end12.loopexit, %for.cond2.preheader
132*9880d681SAndroid Build Coastguard Worker  ret void
133*9880d681SAndroid Build Coastguard Worker}
134*9880d681SAndroid Build Coastguard Worker
135*9880d681SAndroid Build Coastguard Worker
136*9880d681SAndroid Build Coastguard Worker;;  for (long int i = 0; i < n1; i++)
137*9880d681SAndroid Build Coastguard Worker;;    A[2*i - n2] = i;
138*9880d681SAndroid Build Coastguard Worker;;  for (long int j = 0; j < n2; j++)
139*9880d681SAndroid Build Coastguard Worker;;    *B++ = A[-j + 2*n1];
140*9880d681SAndroid Build Coastguard Worker
141*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv2(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp {
142*9880d681SAndroid Build Coastguard Workerentry:
143*9880d681SAndroid Build Coastguard Worker  %cmp4 = icmp eq i64 %n1, 0
144*9880d681SAndroid Build Coastguard Worker  br i1 %cmp4, label %for.cond1.preheader, label %for.body.preheader
145*9880d681SAndroid Build Coastguard Worker
146*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv2'
147*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
148*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
149*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
150*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
151*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
152*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
153*9880d681SAndroid Build Coastguard Worker
154*9880d681SAndroid Build Coastguard Workerfor.body.preheader:                               ; preds = %entry
155*9880d681SAndroid Build Coastguard Worker  br label %for.body
156*9880d681SAndroid Build Coastguard Worker
157*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader.loopexit:                     ; preds = %for.body
158*9880d681SAndroid Build Coastguard Worker  br label %for.cond1.preheader
159*9880d681SAndroid Build Coastguard Worker
160*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader:                              ; preds = %for.cond1.preheader.loopexit, %entry
161*9880d681SAndroid Build Coastguard Worker  %cmp21 = icmp eq i64 %n2, 0
162*9880d681SAndroid Build Coastguard Worker  br i1 %cmp21, label %for.end10, label %for.body4.preheader
163*9880d681SAndroid Build Coastguard Worker
164*9880d681SAndroid Build Coastguard Workerfor.body4.preheader:                              ; preds = %for.cond1.preheader
165*9880d681SAndroid Build Coastguard Worker  br label %for.body4
166*9880d681SAndroid Build Coastguard Worker
167*9880d681SAndroid Build Coastguard Workerfor.body:                                         ; preds = %for.body.preheader, %for.body
168*9880d681SAndroid Build Coastguard Worker  %i.05 = phi i64 [ %inc, %for.body ], [ 0, %for.body.preheader ]
169*9880d681SAndroid Build Coastguard Worker  %conv = trunc i64 %i.05 to i32
170*9880d681SAndroid Build Coastguard Worker  %mul = shl nsw i64 %i.05, 1
171*9880d681SAndroid Build Coastguard Worker  %sub = sub i64 %mul, %n2
172*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds i32, i32* %A, i64 %sub
173*9880d681SAndroid Build Coastguard Worker  store i32 %conv, i32* %arrayidx, align 4
174*9880d681SAndroid Build Coastguard Worker  %inc = add nsw i64 %i.05, 1
175*9880d681SAndroid Build Coastguard Worker  %exitcond = icmp ne i64 %inc, %n1
176*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond, label %for.body, label %for.cond1.preheader.loopexit
177*9880d681SAndroid Build Coastguard Worker
178*9880d681SAndroid Build Coastguard Workerfor.body4:                                        ; preds = %for.body4.preheader, %for.body4
179*9880d681SAndroid Build Coastguard Worker  %j.03 = phi i64 [ %inc9, %for.body4 ], [ 0, %for.body4.preheader ]
180*9880d681SAndroid Build Coastguard Worker  %B.addr.02 = phi i32* [ %incdec.ptr, %for.body4 ], [ %B, %for.body4.preheader ]
181*9880d681SAndroid Build Coastguard Worker  %mul6 = shl i64 %n1, 1
182*9880d681SAndroid Build Coastguard Worker  %add = sub i64 %mul6, %j.03
183*9880d681SAndroid Build Coastguard Worker  %arrayidx7 = getelementptr inbounds i32, i32* %A, i64 %add
184*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* %arrayidx7, align 4
185*9880d681SAndroid Build Coastguard Worker  %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.02, i64 1
186*9880d681SAndroid Build Coastguard Worker  store i32 %0, i32* %B.addr.02, align 4
187*9880d681SAndroid Build Coastguard Worker  %inc9 = add nsw i64 %j.03, 1
188*9880d681SAndroid Build Coastguard Worker  %exitcond6 = icmp ne i64 %inc9, %n2
189*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond6, label %for.body4, label %for.end10.loopexit
190*9880d681SAndroid Build Coastguard Worker
191*9880d681SAndroid Build Coastguard Workerfor.end10.loopexit:                               ; preds = %for.body4
192*9880d681SAndroid Build Coastguard Worker  br label %for.end10
193*9880d681SAndroid Build Coastguard Worker
194*9880d681SAndroid Build Coastguard Workerfor.end10:                                        ; preds = %for.end10.loopexit, %for.cond1.preheader
195*9880d681SAndroid Build Coastguard Worker  ret void
196*9880d681SAndroid Build Coastguard Worker}
197*9880d681SAndroid Build Coastguard Worker
198*9880d681SAndroid Build Coastguard Worker
199*9880d681SAndroid Build Coastguard Worker;;  for (long int i = 0; i < n1; i++)
200*9880d681SAndroid Build Coastguard Worker;;    A[-i + n2] = i;
201*9880d681SAndroid Build Coastguard Worker;;  for (long int j = 0; j < n2; j++)
202*9880d681SAndroid Build Coastguard Worker;;    *B++ = A[j - n1];
203*9880d681SAndroid Build Coastguard Worker
204*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv3(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp {
205*9880d681SAndroid Build Coastguard Workerentry:
206*9880d681SAndroid Build Coastguard Worker  %cmp4 = icmp eq i64 %n1, 0
207*9880d681SAndroid Build Coastguard Worker  br i1 %cmp4, label %for.cond1.preheader, label %for.body.preheader
208*9880d681SAndroid Build Coastguard Worker
209*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv3'
210*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
211*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
212*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
213*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
214*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
215*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
216*9880d681SAndroid Build Coastguard Worker
217*9880d681SAndroid Build Coastguard Workerfor.body.preheader:                               ; preds = %entry
218*9880d681SAndroid Build Coastguard Worker  br label %for.body
219*9880d681SAndroid Build Coastguard Worker
220*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader.loopexit:                     ; preds = %for.body
221*9880d681SAndroid Build Coastguard Worker  br label %for.cond1.preheader
222*9880d681SAndroid Build Coastguard Worker
223*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader:                              ; preds = %for.cond1.preheader.loopexit, %entry
224*9880d681SAndroid Build Coastguard Worker  %cmp21 = icmp eq i64 %n2, 0
225*9880d681SAndroid Build Coastguard Worker  br i1 %cmp21, label %for.end9, label %for.body4.preheader
226*9880d681SAndroid Build Coastguard Worker
227*9880d681SAndroid Build Coastguard Workerfor.body4.preheader:                              ; preds = %for.cond1.preheader
228*9880d681SAndroid Build Coastguard Worker  br label %for.body4
229*9880d681SAndroid Build Coastguard Worker
230*9880d681SAndroid Build Coastguard Workerfor.body:                                         ; preds = %for.body.preheader, %for.body
231*9880d681SAndroid Build Coastguard Worker  %i.05 = phi i64 [ %inc, %for.body ], [ 0, %for.body.preheader ]
232*9880d681SAndroid Build Coastguard Worker  %conv = trunc i64 %i.05 to i32
233*9880d681SAndroid Build Coastguard Worker  %add = sub i64 %n2, %i.05
234*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds i32, i32* %A, i64 %add
235*9880d681SAndroid Build Coastguard Worker  store i32 %conv, i32* %arrayidx, align 4
236*9880d681SAndroid Build Coastguard Worker  %inc = add nsw i64 %i.05, 1
237*9880d681SAndroid Build Coastguard Worker  %exitcond = icmp ne i64 %inc, %n1
238*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond, label %for.body, label %for.cond1.preheader.loopexit
239*9880d681SAndroid Build Coastguard Worker
240*9880d681SAndroid Build Coastguard Workerfor.body4:                                        ; preds = %for.body4.preheader, %for.body4
241*9880d681SAndroid Build Coastguard Worker  %j.03 = phi i64 [ %inc8, %for.body4 ], [ 0, %for.body4.preheader ]
242*9880d681SAndroid Build Coastguard Worker  %B.addr.02 = phi i32* [ %incdec.ptr, %for.body4 ], [ %B, %for.body4.preheader ]
243*9880d681SAndroid Build Coastguard Worker  %sub5 = sub i64 %j.03, %n1
244*9880d681SAndroid Build Coastguard Worker  %arrayidx6 = getelementptr inbounds i32, i32* %A, i64 %sub5
245*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* %arrayidx6, align 4
246*9880d681SAndroid Build Coastguard Worker  %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.02, i64 1
247*9880d681SAndroid Build Coastguard Worker  store i32 %0, i32* %B.addr.02, align 4
248*9880d681SAndroid Build Coastguard Worker  %inc8 = add nsw i64 %j.03, 1
249*9880d681SAndroid Build Coastguard Worker  %exitcond6 = icmp ne i64 %inc8, %n2
250*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond6, label %for.body4, label %for.end9.loopexit
251*9880d681SAndroid Build Coastguard Worker
252*9880d681SAndroid Build Coastguard Workerfor.end9.loopexit:                                ; preds = %for.body4
253*9880d681SAndroid Build Coastguard Worker  br label %for.end9
254*9880d681SAndroid Build Coastguard Worker
255*9880d681SAndroid Build Coastguard Workerfor.end9:                                         ; preds = %for.end9.loopexit, %for.cond1.preheader
256*9880d681SAndroid Build Coastguard Worker  ret void
257*9880d681SAndroid Build Coastguard Worker}
258*9880d681SAndroid Build Coastguard Worker
259*9880d681SAndroid Build Coastguard Worker
260*9880d681SAndroid Build Coastguard Worker;;  for (long int i = 0; i < n1; i++)
261*9880d681SAndroid Build Coastguard Worker;;    A[-i + 2*n1] = i;
262*9880d681SAndroid Build Coastguard Worker;;  for (long int j = 0; j < n2; j++)
263*9880d681SAndroid Build Coastguard Worker;;    *B++ = A[-j + n1];
264*9880d681SAndroid Build Coastguard Worker
265*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv4(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp {
266*9880d681SAndroid Build Coastguard Workerentry:
267*9880d681SAndroid Build Coastguard Worker  %cmp4 = icmp eq i64 %n1, 0
268*9880d681SAndroid Build Coastguard Worker  br i1 %cmp4, label %for.cond1.preheader, label %for.body.preheader
269*9880d681SAndroid Build Coastguard Worker
270*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv4'
271*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
272*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
273*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
274*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
275*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
276*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
277*9880d681SAndroid Build Coastguard Worker
278*9880d681SAndroid Build Coastguard Workerfor.body.preheader:                               ; preds = %entry
279*9880d681SAndroid Build Coastguard Worker  br label %for.body
280*9880d681SAndroid Build Coastguard Worker
281*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader.loopexit:                     ; preds = %for.body
282*9880d681SAndroid Build Coastguard Worker  br label %for.cond1.preheader
283*9880d681SAndroid Build Coastguard Worker
284*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader:                              ; preds = %for.cond1.preheader.loopexit, %entry
285*9880d681SAndroid Build Coastguard Worker  %cmp21 = icmp eq i64 %n2, 0
286*9880d681SAndroid Build Coastguard Worker  br i1 %cmp21, label %for.end10, label %for.body4.preheader
287*9880d681SAndroid Build Coastguard Worker
288*9880d681SAndroid Build Coastguard Workerfor.body4.preheader:                              ; preds = %for.cond1.preheader
289*9880d681SAndroid Build Coastguard Worker  br label %for.body4
290*9880d681SAndroid Build Coastguard Worker
291*9880d681SAndroid Build Coastguard Workerfor.body:                                         ; preds = %for.body.preheader, %for.body
292*9880d681SAndroid Build Coastguard Worker  %i.05 = phi i64 [ %inc, %for.body ], [ 0, %for.body.preheader ]
293*9880d681SAndroid Build Coastguard Worker  %conv = trunc i64 %i.05 to i32
294*9880d681SAndroid Build Coastguard Worker  %mul = shl i64 %n1, 1
295*9880d681SAndroid Build Coastguard Worker  %add = sub i64 %mul, %i.05
296*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds i32, i32* %A, i64 %add
297*9880d681SAndroid Build Coastguard Worker  store i32 %conv, i32* %arrayidx, align 4
298*9880d681SAndroid Build Coastguard Worker  %inc = add nsw i64 %i.05, 1
299*9880d681SAndroid Build Coastguard Worker  %exitcond = icmp ne i64 %inc, %n1
300*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond, label %for.body, label %for.cond1.preheader.loopexit
301*9880d681SAndroid Build Coastguard Worker
302*9880d681SAndroid Build Coastguard Workerfor.body4:                                        ; preds = %for.body4.preheader, %for.body4
303*9880d681SAndroid Build Coastguard Worker  %j.03 = phi i64 [ %inc9, %for.body4 ], [ 0, %for.body4.preheader ]
304*9880d681SAndroid Build Coastguard Worker  %B.addr.02 = phi i32* [ %incdec.ptr, %for.body4 ], [ %B, %for.body4.preheader ]
305*9880d681SAndroid Build Coastguard Worker  %add6 = sub i64 %n1, %j.03
306*9880d681SAndroid Build Coastguard Worker  %arrayidx7 = getelementptr inbounds i32, i32* %A, i64 %add6
307*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* %arrayidx7, align 4
308*9880d681SAndroid Build Coastguard Worker  %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.02, i64 1
309*9880d681SAndroid Build Coastguard Worker  store i32 %0, i32* %B.addr.02, align 4
310*9880d681SAndroid Build Coastguard Worker  %inc9 = add nsw i64 %j.03, 1
311*9880d681SAndroid Build Coastguard Worker  %exitcond6 = icmp ne i64 %inc9, %n2
312*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond6, label %for.body4, label %for.end10.loopexit
313*9880d681SAndroid Build Coastguard Worker
314*9880d681SAndroid Build Coastguard Workerfor.end10.loopexit:                               ; preds = %for.body4
315*9880d681SAndroid Build Coastguard Worker  br label %for.end10
316*9880d681SAndroid Build Coastguard Worker
317*9880d681SAndroid Build Coastguard Workerfor.end10:                                        ; preds = %for.end10.loopexit, %for.cond1.preheader
318*9880d681SAndroid Build Coastguard Worker  ret void
319*9880d681SAndroid Build Coastguard Worker}
320*9880d681SAndroid Build Coastguard Worker
321*9880d681SAndroid Build Coastguard Worker
322*9880d681SAndroid Build Coastguard Worker;;  for (long int i = 0; i < n1; i++)
323*9880d681SAndroid Build Coastguard Worker;;    A[-i + n2] = i;
324*9880d681SAndroid Build Coastguard Worker;;  for (long int j = 0; j < n2; j++)
325*9880d681SAndroid Build Coastguard Worker;;    *B++ = A[-j + 2*n2];
326*9880d681SAndroid Build Coastguard Worker
327*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv5(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp {
328*9880d681SAndroid Build Coastguard Workerentry:
329*9880d681SAndroid Build Coastguard Worker  %cmp4 = icmp eq i64 %n1, 0
330*9880d681SAndroid Build Coastguard Worker  br i1 %cmp4, label %for.cond1.preheader, label %for.body.preheader
331*9880d681SAndroid Build Coastguard Worker
332*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv5'
333*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
334*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
335*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
336*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
337*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
338*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
339*9880d681SAndroid Build Coastguard Worker
340*9880d681SAndroid Build Coastguard Workerfor.body.preheader:                               ; preds = %entry
341*9880d681SAndroid Build Coastguard Worker  br label %for.body
342*9880d681SAndroid Build Coastguard Worker
343*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader.loopexit:                     ; preds = %for.body
344*9880d681SAndroid Build Coastguard Worker  br label %for.cond1.preheader
345*9880d681SAndroid Build Coastguard Worker
346*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader:                              ; preds = %for.cond1.preheader.loopexit, %entry
347*9880d681SAndroid Build Coastguard Worker  %cmp21 = icmp eq i64 %n2, 0
348*9880d681SAndroid Build Coastguard Worker  br i1 %cmp21, label %for.end10, label %for.body4.preheader
349*9880d681SAndroid Build Coastguard Worker
350*9880d681SAndroid Build Coastguard Workerfor.body4.preheader:                              ; preds = %for.cond1.preheader
351*9880d681SAndroid Build Coastguard Worker  br label %for.body4
352*9880d681SAndroid Build Coastguard Worker
353*9880d681SAndroid Build Coastguard Workerfor.body:                                         ; preds = %for.body.preheader, %for.body
354*9880d681SAndroid Build Coastguard Worker  %i.05 = phi i64 [ %inc, %for.body ], [ 0, %for.body.preheader ]
355*9880d681SAndroid Build Coastguard Worker  %conv = trunc i64 %i.05 to i32
356*9880d681SAndroid Build Coastguard Worker  %add = sub i64 %n2, %i.05
357*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds i32, i32* %A, i64 %add
358*9880d681SAndroid Build Coastguard Worker  store i32 %conv, i32* %arrayidx, align 4
359*9880d681SAndroid Build Coastguard Worker  %inc = add nsw i64 %i.05, 1
360*9880d681SAndroid Build Coastguard Worker  %exitcond = icmp ne i64 %inc, %n1
361*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond, label %for.body, label %for.cond1.preheader.loopexit
362*9880d681SAndroid Build Coastguard Worker
363*9880d681SAndroid Build Coastguard Workerfor.body4:                                        ; preds = %for.body4.preheader, %for.body4
364*9880d681SAndroid Build Coastguard Worker  %j.03 = phi i64 [ %inc9, %for.body4 ], [ 0, %for.body4.preheader ]
365*9880d681SAndroid Build Coastguard Worker  %B.addr.02 = phi i32* [ %incdec.ptr, %for.body4 ], [ %B, %for.body4.preheader ]
366*9880d681SAndroid Build Coastguard Worker  %mul = shl i64 %n2, 1
367*9880d681SAndroid Build Coastguard Worker  %add6 = sub i64 %mul, %j.03
368*9880d681SAndroid Build Coastguard Worker  %arrayidx7 = getelementptr inbounds i32, i32* %A, i64 %add6
369*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* %arrayidx7, align 4
370*9880d681SAndroid Build Coastguard Worker  %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.02, i64 1
371*9880d681SAndroid Build Coastguard Worker  store i32 %0, i32* %B.addr.02, align 4
372*9880d681SAndroid Build Coastguard Worker  %inc9 = add nsw i64 %j.03, 1
373*9880d681SAndroid Build Coastguard Worker  %exitcond6 = icmp ne i64 %inc9, %n2
374*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond6, label %for.body4, label %for.end10.loopexit
375*9880d681SAndroid Build Coastguard Worker
376*9880d681SAndroid Build Coastguard Workerfor.end10.loopexit:                               ; preds = %for.body4
377*9880d681SAndroid Build Coastguard Worker  br label %for.end10
378*9880d681SAndroid Build Coastguard Worker
379*9880d681SAndroid Build Coastguard Workerfor.end10:                                        ; preds = %for.end10.loopexit, %for.cond1.preheader
380*9880d681SAndroid Build Coastguard Worker  ret void
381*9880d681SAndroid Build Coastguard Worker}
382*9880d681SAndroid Build Coastguard Worker
383*9880d681SAndroid Build Coastguard Worker
384*9880d681SAndroid Build Coastguard Worker;;  for (long int i = 0; i < n1; i++)
385*9880d681SAndroid Build Coastguard Worker;;    for (long int j = 0; j < n2; j++) {
386*9880d681SAndroid Build Coastguard Worker;;      A[j -i + n2] = i;
387*9880d681SAndroid Build Coastguard Worker;;      *B++ = A[2*n2];
388*9880d681SAndroid Build Coastguard Worker
389*9880d681SAndroid Build Coastguard Workerdefine void @symbolicrdiv6(i32* %A, i32* %B, i64 %n1, i64 %n2) nounwind uwtable ssp {
390*9880d681SAndroid Build Coastguard Workerentry:
391*9880d681SAndroid Build Coastguard Worker  %cmp4 = icmp eq i64 %n1, 0
392*9880d681SAndroid Build Coastguard Worker  br i1 %cmp4, label %for.end7, label %for.cond1.preheader.preheader
393*9880d681SAndroid Build Coastguard Worker
394*9880d681SAndroid Build Coastguard Worker; CHECK: 'Dependence Analysis' for function 'symbolicrdiv6'
395*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - output [* *]!
396*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - none!
397*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
398*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - consistent input [S S]!
399*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - confused!
400*9880d681SAndroid Build Coastguard Worker; CHECK: da analyze - output [* *]!
401*9880d681SAndroid Build Coastguard Worker
402*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader.preheader:                    ; preds = %entry
403*9880d681SAndroid Build Coastguard Worker  br label %for.cond1.preheader
404*9880d681SAndroid Build Coastguard Worker
405*9880d681SAndroid Build Coastguard Workerfor.cond1.preheader:                              ; preds = %for.cond1.preheader.preheader, %for.inc5
406*9880d681SAndroid Build Coastguard Worker  %B.addr.06 = phi i32* [ %B.addr.1.lcssa, %for.inc5 ], [ %B, %for.cond1.preheader.preheader ]
407*9880d681SAndroid Build Coastguard Worker  %i.05 = phi i64 [ %inc6, %for.inc5 ], [ 0, %for.cond1.preheader.preheader ]
408*9880d681SAndroid Build Coastguard Worker  %cmp21 = icmp eq i64 %n2, 0
409*9880d681SAndroid Build Coastguard Worker  br i1 %cmp21, label %for.inc5, label %for.body3.preheader
410*9880d681SAndroid Build Coastguard Worker
411*9880d681SAndroid Build Coastguard Workerfor.body3.preheader:                              ; preds = %for.cond1.preheader
412*9880d681SAndroid Build Coastguard Worker  br label %for.body3
413*9880d681SAndroid Build Coastguard Worker
414*9880d681SAndroid Build Coastguard Workerfor.body3:                                        ; preds = %for.body3.preheader, %for.body3
415*9880d681SAndroid Build Coastguard Worker  %j.03 = phi i64 [ %inc, %for.body3 ], [ 0, %for.body3.preheader ]
416*9880d681SAndroid Build Coastguard Worker  %B.addr.12 = phi i32* [ %incdec.ptr, %for.body3 ], [ %B.addr.06, %for.body3.preheader ]
417*9880d681SAndroid Build Coastguard Worker  %conv = trunc i64 %i.05 to i32
418*9880d681SAndroid Build Coastguard Worker  %sub = sub nsw i64 %j.03, %i.05
419*9880d681SAndroid Build Coastguard Worker  %add = add i64 %sub, %n2
420*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds i32, i32* %A, i64 %add
421*9880d681SAndroid Build Coastguard Worker  store i32 %conv, i32* %arrayidx, align 4
422*9880d681SAndroid Build Coastguard Worker  %mul = shl i64 %n2, 1
423*9880d681SAndroid Build Coastguard Worker  %arrayidx4 = getelementptr inbounds i32, i32* %A, i64 %mul
424*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* %arrayidx4, align 4
425*9880d681SAndroid Build Coastguard Worker  %incdec.ptr = getelementptr inbounds i32, i32* %B.addr.12, i64 1
426*9880d681SAndroid Build Coastguard Worker  store i32 %0, i32* %B.addr.12, align 4
427*9880d681SAndroid Build Coastguard Worker  %inc = add nsw i64 %j.03, 1
428*9880d681SAndroid Build Coastguard Worker  %exitcond = icmp ne i64 %inc, %n2
429*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond, label %for.body3, label %for.inc5.loopexit
430*9880d681SAndroid Build Coastguard Worker
431*9880d681SAndroid Build Coastguard Workerfor.inc5.loopexit:                                ; preds = %for.body3
432*9880d681SAndroid Build Coastguard Worker  %scevgep = getelementptr i32, i32* %B.addr.06, i64 %n2
433*9880d681SAndroid Build Coastguard Worker  br label %for.inc5
434*9880d681SAndroid Build Coastguard Worker
435*9880d681SAndroid Build Coastguard Workerfor.inc5:                                         ; preds = %for.inc5.loopexit, %for.cond1.preheader
436*9880d681SAndroid Build Coastguard Worker  %B.addr.1.lcssa = phi i32* [ %B.addr.06, %for.cond1.preheader ], [ %scevgep, %for.inc5.loopexit ]
437*9880d681SAndroid Build Coastguard Worker  %inc6 = add nsw i64 %i.05, 1
438*9880d681SAndroid Build Coastguard Worker  %exitcond7 = icmp ne i64 %inc6, %n1
439*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond7, label %for.cond1.preheader, label %for.end7.loopexit
440*9880d681SAndroid Build Coastguard Worker
441*9880d681SAndroid Build Coastguard Workerfor.end7.loopexit:                                ; preds = %for.inc5
442*9880d681SAndroid Build Coastguard Worker  br label %for.end7
443*9880d681SAndroid Build Coastguard Worker
444*9880d681SAndroid Build Coastguard Workerfor.end7:                                         ; preds = %for.end7.loopexit, %entry
445*9880d681SAndroid Build Coastguard Worker  ret void
446*9880d681SAndroid Build Coastguard Worker}
447