Update Polly tests to handle explicitly typed gep changes in LLVM
[polly-mirror.git] / test / Dependences / sequential_loops.ll
blobbefec3eb1779a69e62b623a92845c128f7e90918
1 ; RUN: opt -S %loadPolly -polly-detect-unprofitable -basicaa -polly-dependences -analyze -polly-dependences-analysis-type=value-based < %s | FileCheck %s -check-prefix=VALUE
2 ; RUN: opt -S %loadPolly -polly-detect-unprofitable -basicaa -polly-dependences -analyze -polly-dependences-analysis-type=memory-based < %s | FileCheck %s -check-prefix=MEMORY
3 target 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"
4 target triple = "x86_64-pc-linux-gnu"
6 ;     for(i = 0; i < 100; i++ )
7 ; S1:   A[i] = 2;
9 ;     for (i = 0; i < 10; i++ )
10 ; S2:   A[i]  = 5;
12 ;     for (i = 0; i < 200; i++ )
13 ; S3:   A[i] = 5;
15 define void @sequential_writes() {
16 entry:
17   %A = alloca [200 x i32]
18   br label %S1
20 S1:
21   %indvar.1 = phi i64 [ 0, %entry ], [ %indvar.next.1, %S1 ]
22   %arrayidx.1 = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.1
23   store i32 2, i32* %arrayidx.1
24   %indvar.next.1 = add i64 %indvar.1, 1
25   %exitcond.1 = icmp ne i64 %indvar.next.1, 100
26   br i1 %exitcond.1, label %S1, label %exit.1
28 exit.1:
29   br label %S2
31 S2:
32   %indvar.2 = phi i64 [ 0, %exit.1 ], [ %indvar.next.2, %S2 ]
33   %arrayidx.2 = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.2
34   store i32 5, i32* %arrayidx.2
35   %indvar.next.2 = add i64 %indvar.2, 1
36   %exitcond.2 = icmp ne i64 %indvar.next.2, 10
37   br i1 %exitcond.2, label %S2, label %exit.2
39 exit.2:
40   br label %S3
42 S3:
43   %indvar.3 = phi i64 [ 0, %exit.2 ], [ %indvar.next.3, %S3 ]
44   %arrayidx.3 = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.3
45   store i32 7, i32* %arrayidx.3
46   %indvar.next.3 = add i64 %indvar.3, 1
47   %exitcond.3 = icmp ne i64 %indvar.next.3, 200
48   br i1 %exitcond.3, label %S3 , label %exit.3
50 exit.3:
51   ret void
54 ; VALUE: region: 'S1 => exit.3' in function 'sequential_writes':
55 ; VALUE:   RAW dependences:
56 ; VALUE:     {  }
57 ; VALUE:   WAR dependences:
58 ; VALUE:     {  }
59 ; VALUE:   WAW dependences:
60 ; VALUE:     {
61 ; VALUE:       Stmt_S1[i0] -> Stmt_S2[i0] : i0 >= 0 and i0 <= 9;
62 ; VALUE:       Stmt_S2[i0] -> Stmt_S3[i0] : i0 >= 0 and i0 <= 9;
63 ; VALUE:       Stmt_S1[i0] -> Stmt_S3[i0] : i0 >= 10 and i0 <= 99
64 ; VALUE:     }
66 ; MEMORY: region: 'S1 => exit.3' in function 'sequential_writes':
67 ; MEMORY:   RAW dependences:
68 ; MEMORY:     {  }
69 ; MEMORY:   WAR dependences:
70 ; MEMORY:     {  }
71 ; MEMORY:   WAW dependences:
72 ; MEMORY:     {
73 ; MEMORY:       Stmt_S1[i0] -> Stmt_S2[i0] : i0 <= 9 and i0 >= 0;
74 ; MEMORY:       Stmt_S2[i0] -> Stmt_S3[i0] : i0 <= 9 and i0 >= 0;
75 ; MEMORY:       Stmt_S1[i0] -> Stmt_S3[i0] : i0 <= 99 and i0 >= 0
76 ; MEMORY:     }
78 ;     for(i = 0; i < 100; i++ )
79 ; S1:   A[i] = 2;
81 ;     for (i = 0; i < 10; i++ )
82 ; S2:   A[i]  = 5;
84 ;     for (i = 0; i < 200; i++ )
85 ; S3:   B[i] = A[i];
87 define void @read_after_writes() {
88 entry:
89   %A = alloca [200 x i32]
90   %B = alloca [200 x i32]
91   br label %S1
93 S1:
94   %indvar.1 = phi i64 [ 0, %entry ], [ %indvar.next.1, %S1 ]
95   %arrayidx.1 = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.1
96   store i32 2, i32* %arrayidx.1
97   %indvar.next.1 = add i64 %indvar.1, 1
98   %exitcond.1 = icmp ne i64 %indvar.next.1, 100
99   br i1 %exitcond.1, label %S1, label %exit.1
101 exit.1:
102   br label %S2
105   %indvar.2 = phi i64 [ 0, %exit.1 ], [ %indvar.next.2, %S2 ]
106   %arrayidx.2 = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.2
107   store i32 5, i32* %arrayidx.2
108   %indvar.next.2 = add i64 %indvar.2, 1
109   %exitcond.2 = icmp ne i64 %indvar.next.2, 10
110   br i1 %exitcond.2, label %S2, label %exit.2
112 exit.2:
113   br label %S3
116   %indvar.3 = phi i64 [ 0, %exit.2 ], [ %indvar.next.3, %S3 ]
117   %arrayidx.3.a = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.3
118   %arrayidx.3.b = getelementptr [200 x i32], [200 x i32]* %B, i64 0, i64 %indvar.3
119   %val = load i32* %arrayidx.3.a
120   store i32 %val, i32* %arrayidx.3.b
121   %indvar.next.3 = add i64 %indvar.3, 1
122   %exitcond.3 = icmp ne i64 %indvar.next.3, 200
123   br i1 %exitcond.3, label %S3 , label %exit.3
125 exit.3:
126   ret void
129 ; VALUE: region: 'S1 => exit.3' in function 'read_after_writes':
130 ; VALUE:   RAW dependences:
131 ; VALUE:     {
132 ; VALUE:       Stmt_S2[i0] -> Stmt_S3[i0] : i0 >= 0 and i0 <= 9;
133 ; VALUE:       Stmt_S1[i0] -> Stmt_S3[i0] : i0 >= 10 and i0 <= 99
134 ; VALUE:     }
135 ; VALUE:   WAR dependences:
136 ; VALUE:     {  }
137 ; VALUE:   WAW dependences:
138 ; VALUE:     {
139 ; VALUE:       Stmt_S1[i0] -> Stmt_S2[i0] : i0 >= 0 and i0 <= 9
140 ; VALUE:     }
142 ; MEMORY: region: 'S1 => exit.3' in function 'read_after_writes':
143 ; MEMORY:   RAW dependences:
144 ; MEMORY:     {
145 ; MEMORY:       Stmt_S2[i0] -> Stmt_S3[i0] : i0 <= 9 and i0 >= 0;
146 ; MEMORY:       Stmt_S1[i0] -> Stmt_S3[i0] : i0 <= 99 and i0 >= 0
147 ; MEMORY:     }
148 ; MEMORY:   WAR dependences:
149 ; MEMORY:     {  }
150 ; MEMORY:   WAW dependences:
151 ; MEMORY:     {
152 ; MEMORY:       Stmt_S1[i0] -> Stmt_S2[i0] : i0 <= 9 and i0 >= 0
153 ; MEMORY:     }
155 ;     for(i = 0; i < 100; i++ )
156 ; S1:   B[i] = A[i];
158 ;     for (i = 0; i < 10; i++ )
159 ; S2:   A[i]  = 5;
161 ;     for (i = 0; i < 200; i++ )
162 ; S3:   A[i]  = 10;
164 define void @write_after_read() {
165 entry:
166   %A = alloca [200 x i32]
167   %B = alloca [200 x i32]
168   br label %S1
171   %indvar.1 = phi i64 [ 0, %entry ], [ %indvar.next.1, %S1 ]
172   %arrayidx.1.a = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.1
173   %arrayidx.1.b = getelementptr [200 x i32], [200 x i32]* %B, i64 0, i64 %indvar.1
174   %val = load i32* %arrayidx.1.a
175   store i32 %val, i32* %arrayidx.1.b
176   %indvar.next.1 = add i64 %indvar.1, 1
177   %exitcond.1 = icmp ne i64 %indvar.next.1, 100
178   br i1 %exitcond.1, label %S1, label %exit.1
180 exit.1:
181   br label %S2
184   %indvar.2 = phi i64 [ 0, %exit.1 ], [ %indvar.next.2, %S2 ]
185   %arrayidx.2 = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.2
186   store i32 5, i32* %arrayidx.2
187   %indvar.next.2 = add i64 %indvar.2, 1
188   %exitcond.2 = icmp ne i64 %indvar.next.2, 10
189   br i1 %exitcond.2, label %S2, label %exit.2
191 exit.2:
192   br label %S3
195   %indvar.3 = phi i64 [ 0, %exit.2 ], [ %indvar.next.3, %S3 ]
196   %arrayidx.3 = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.3
197   store i32 10, i32* %arrayidx.3
198   %indvar.next.3 = add i64 %indvar.3, 1
199   %exitcond.3 = icmp ne i64 %indvar.next.3, 200
200   br i1 %exitcond.3, label %S3 , label %exit.3
202 exit.3:
203   ret void
206 ; VALUE: region: 'S1 => exit.3' in function 'write_after_read':
207 ; VALUE:   RAW dependences:
208 ; VALUE:     {
209 ; VALUE:     }
210 ; VALUE:   WAR dependences:
211 ; VALUE:     {
212 ; VALUE:       Stmt_S1[i0] -> Stmt_S2[i0] : i0 <= 9 and i0 >= 0;
213 ; VALUE:       Stmt_S1[i0] -> Stmt_S3[i0] : i0 <= 99 and i0 >= 10
214 ; VALUE:     }
215 ; VALUE:   WAW dependences:
216 ; VALUE:     {
217 ; VALUE:       Stmt_S2[i0] -> Stmt_S3[i0] : i0 >= 0 and i0 <= 9
218 ; VALUE:     }
220 ; MEMORY: region: 'S1 => exit.3' in function 'write_after_read':
221 ; MEMORY:   RAW dependences:
222 ; MEMORY:     {
223 ; MEMORY:     }
224 ; MEMORY:   WAR dependences:
225 ; MEMORY:     {
226 ; MEMORY:        Stmt_S1[i0] -> Stmt_S2[i0] : i0 <= 9 and i0 >= 0;
227 ; MEMORY:        Stmt_S1[i0] -> Stmt_S3[i0] : i0 <= 99 and i0 >= 0
228 ; MEMORY:     }
229 ; MEMORY:   WAW dependences:
230 ; MEMORY:     {
231 ; MEMORY:        Stmt_S2[i0] -> Stmt_S3[i0] : i0 <= 9 and i0 >= 0
232 ; MEMORY:     }
234 ;     for(i = 0; i < 100; i++ )
235 ; S1:   A[i] = 10
237 ;     for(i = 0; i < 100; i++ )
238 ; S2:   B[i] = A[i + p];
240 define void @parametric_offset(i64 %p) {
241 entry:
242   %A = alloca [200 x i32]
243   %B = alloca [200 x i32]
244   br label %S1
247   %indvar.1 = phi i64 [ 0, %entry ], [ %indvar.next.1, %S1 ]
248   %arrayidx.1 = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.1
249   store i32 10, i32* %arrayidx.1
250   %indvar.next.1 = add i64 %indvar.1, 1
251   %exitcond.1 = icmp ne i64 %indvar.next.1, 100
252   br i1 %exitcond.1, label %S1, label %exit.1
254 exit.1:
255   br label %S2
258   %indvar.2 = phi i64 [ 0, %exit.1 ], [ %indvar.next.2, %S2 ]
259   %sum = add i64 %indvar.2, %p
260   %arrayidx.2.a = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %sum
261   %arrayidx.2.b = getelementptr [200 x i32], [200 x i32]* %B, i64 0, i64 %indvar.2
262   %val = load i32* %arrayidx.2.a
263   store i32 %val, i32* %arrayidx.2.b
264   %indvar.next.2 = add i64 %indvar.2, 1
265   %exitcond.2 = icmp ne i64 %indvar.next.2, 10
266   br i1 %exitcond.2, label %S2, label %exit.2
268 exit.2:
269   ret void
272 ; VALUE: region: 'S1 => exit.2' in function 'parametric_offset':
273 ; VALUE:   RAW dependences:
274 ; VALUE:     [p] -> {
275 ; VALUE:       Stmt_S1[i0] -> Stmt_S2[-p + i0] :
276 ; VALUE:           p <= 190 and i0 >= p and i0 <= 9 + p and i0 >= 0 and i0 <= 99
277 ; VALUE:     }
278 ; VALUE:   WAR dependences:
279 ; VALUE:     [p] -> {
280 ; VALUE:     }
281 ; VALUE:   WAW dependences:
282 ; VALUE:     [p] -> {
283 ; VALUE:     }
285 ; MEMORY: region: 'S1 => exit.2' in function 'parametric_offset':
286 ; MEMORY:   RAW dependences:
287 ; MEMORY:     [p] -> {
288 ; MEMORY:       Stmt_S1[i0] -> Stmt_S2[-p + i0] :
289 ; MEMORY:           i0 >= p and i0 <= 99 and i0 >= 0 and i0 <= 9 + p
290 ; MEMORY:     }
291 ; MEMORY:   WAR dependences:
292 ; MEMORY:     [p] -> {
293 ; MEMORY:     }
294 ; MEMORY:   WAW dependences:
295 ; MEMORY:     [p] -> {
296 ; MEMORY:     }