1 // RUN: %clang_cc1 -verify -fopenmp -std=c++11 -ast-print %s | FileCheck %s
2 // RUN: %clang_cc1 -fopenmp -x c++ -std=c++11 -emit-pch -o %t %s
3 // RUN: %clang_cc1 -fopenmp -std=c++11 -include-pch %t -fsyntax-only -verify %s -ast-print | FileCheck %s
5 // RUN: %clang_cc1 -verify -fopenmp-simd -std=c++11 -ast-print %s | FileCheck %s
6 // RUN: %clang_cc1 -fopenmp-simd -x c++ -std=c++11 -emit-pch -o %t %s
7 // RUN: %clang_cc1 -fopenmp-simd -std=c++11 -include-pch %t -fsyntax-only -verify %s -ast-print | FileCheck %s
8 // expected-no-diagnostics
18 const int da[5] = { 0 };
28 #pragma omp target teams distribute parallel for simd is_device_ptr(k)
29 for (int i=0; i<100; i++)
31 #pragma omp target teams distribute parallel for simd is_device_ptr(z)
32 for (int i=0; i<100; i++)
34 #pragma omp target teams distribute parallel for simd is_device_ptr(aa) // OK
35 for (int i=0; i<100; i++)
37 #pragma omp target teams distribute parallel for simd is_device_ptr(raa) // OK
38 for (int i=0; i<100; i++)
40 #pragma omp target teams distribute parallel for simd is_device_ptr(g) // OK
41 for (int i=0; i<100; i++)
43 #pragma omp target teams distribute parallel for simd is_device_ptr(rg) // OK
44 for (int i=0; i<100; i++)
46 #pragma omp target teams distribute parallel for simd is_device_ptr(da) // OK
47 for (int i=0; i<100; i++)
53 // CHECK-NEXT: const int da[5] = {0};
54 // CHECK-NEXT: ST g[10];
55 // CHECK-NEXT: STarr &rg = this->g;
57 // CHECK-NEXT: int &j = this->i;
58 // CHECK-NEXT: int *k = &this->j;
59 // CHECK-NEXT: int *&z = this->k;
60 // CHECK-NEXT: int aa[10];
61 // CHECK-NEXT: arr &raa = this->aa;
63 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(this->k){{$}}
64 // CHECK-NEXT: for (int i = 0; i < 100; i++)
66 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(this->z)
67 // CHECK-NEXT: for (int i = 0; i < 100; i++)
69 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(this->aa)
70 // CHECK-NEXT: for (int i = 0; i < 100; i++)
72 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(this->raa)
73 // CHECK-NEXT: for (int i = 0; i < 100; i++)
75 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(this->g)
76 // CHECK-NEXT: for (int i = 0; i < 100; i++)
78 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(this->rg)
79 // CHECK-NEXT: for (int i = 0; i < 100; i++)
81 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(this->da)
82 // CHECK-NEXT: for (int i = 0; i < 100; i++)
107 SC(SB *&_RPtrS) : RPtrS(_RPtrS) {}
121 S2(S2 &s2):a(s2.a) { }
123 static const float S2sc;
125 const float S2::S2sc = 0;
132 S3(S3 &s3):a(s3.a) { }
147 S5(const S5 &s5):a(s5.a) { }
153 #pragma omp threadprivate(h)
159 template <typename T>
161 const T da[5] = { 0 };
170 #pragma omp target teams distribute parallel for simd is_device_ptr(k)
171 for (int i=0; i<100; i++)
173 #pragma omp target teams distribute parallel for simd is_device_ptr(z)
174 for (int i=0; i<100; i++)
176 #pragma omp target teams distribute parallel for simd is_device_ptr(aa)
177 for (int i=0; i<100; i++)
179 #pragma omp target teams distribute parallel for simd is_device_ptr(raa)
180 for (int i=0; i<100; i++)
182 #pragma omp target teams distribute parallel for simd is_device_ptr(h)
183 for (int i=0; i<100; i++)
185 #pragma omp target teams distribute parallel for simd is_device_ptr(rh)
186 for (int i=0; i<100; i++)
188 #pragma omp target teams distribute parallel for simd is_device_ptr(da)
189 for (int i=0; i<100; i++)
194 // CHECK: template<> int tmain<int>(int argc) {
195 // CHECK-NEXT: const int da[5] = {0};
196 // CHECK-NEXT: S6 h[10];
197 // CHECK-NEXT: auto &rh = h;
198 // CHECK-NEXT: int i;
199 // CHECK-NEXT: int &j = i;
200 // CHECK-NEXT: int *k = &j;
201 // CHECK-NEXT: int *&z = k;
202 // CHECK-NEXT: int aa[10];
203 // CHECK-NEXT: auto &raa = aa;
204 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(k)
205 // CHECK-NEXT: for (int i = 0; i < 100; i++)
207 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(z)
208 // CHECK-NEXT: for (int i = 0; i < 100; i++)
210 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(aa)
211 // CHECK-NEXT: for (int i = 0; i < 100; i++)
213 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(raa)
214 // CHECK-NEXT: for (int i = 0; i < 100; i++)
216 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(h)
217 // CHECK-NEXT: for (int i = 0; i < 100; i++)
219 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(rh)
220 // CHECK-NEXT: for (int i = 0; i < 100; i++)
222 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(da)
223 // CHECK-NEXT: for (int i = 0; i < 100; i++)
226 // CHECK: template<> int *tmain<int *>(int *argc) {
227 // CHECK-NEXT: int *const da[5] = {0};
228 // CHECK-NEXT: S6 h[10];
229 // CHECK-NEXT: auto &rh = h;
230 // CHECK-NEXT: int *i;
231 // CHECK-NEXT: int *&j = i;
232 // CHECK-NEXT: int **k = &j;
233 // CHECK-NEXT: int **&z = k;
234 // CHECK-NEXT: int *aa[10];
235 // CHECK-NEXT: auto &raa = aa;
236 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(k)
237 // CHECK-NEXT: for (int i = 0; i < 100; i++)
239 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(z)
240 // CHECK-NEXT: for (int i = 0; i < 100; i++)
242 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(aa)
243 // CHECK-NEXT: for (int i = 0; i < 100; i++)
245 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(raa)
246 // CHECK-NEXT: for (int i = 0; i < 100; i++)
248 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(h)
249 // CHECK-NEXT: for (int i = 0; i < 100; i++)
251 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(rh)
252 // CHECK-NEXT: for (int i = 0; i < 100; i++)
254 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(da)
255 // CHECK-NEXT: for (int i = 0; i < 100; i++)
258 // CHECK-LABEL: int main(int argc, char **argv) {
259 int main(int argc, char **argv) {
260 const int da[5] = { 0 };
269 // CHECK-NEXT: const int da[5] = {0};
270 // CHECK-NEXT: S6 h[10];
271 // CHECK-NEXT: auto &rh = h;
272 // CHECK-NEXT: int i;
273 // CHECK-NEXT: int &j = i;
274 // CHECK-NEXT: int *k = &j;
275 // CHECK-NEXT: int *&z = k;
276 // CHECK-NEXT: int aa[10];
277 // CHECK-NEXT: auto &raa = aa;
278 #pragma omp target teams distribute parallel for simd is_device_ptr(k)
279 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(k)
280 for (int i=0; i<100; i++)
282 // CHECK-NEXT: for (int i = 0; i < 100; i++)
284 #pragma omp target teams distribute parallel for simd is_device_ptr(z)
285 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(z)
286 for (int i=0; i<100; i++)
288 // CHECK-NEXT: for (int i = 0; i < 100; i++)
290 #pragma omp target teams distribute parallel for simd is_device_ptr(aa)
291 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(aa)
292 for (int i=0; i<100; i++)
294 // CHECK-NEXT: for (int i = 0; i < 100; i++)
296 #pragma omp target teams distribute parallel for simd is_device_ptr(raa)
297 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(raa)
298 for (int i=0; i<100; i++)
300 // CHECK-NEXT: for (int i = 0; i < 100; i++)
302 #pragma omp target teams distribute parallel for simd is_device_ptr(h)
303 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(h)
304 for (int i=0; i<100; i++)
306 // CHECK-NEXT: for (int i = 0; i < 100; i++)
308 #pragma omp target teams distribute parallel for simd is_device_ptr(rh)
309 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(rh)
310 for (int i=0; i<100; i++)
312 // CHECK-NEXT: for (int i = 0; i < 100; i++)
314 #pragma omp target teams distribute parallel for simd is_device_ptr(da)
315 // CHECK-NEXT: #pragma omp target teams distribute parallel for simd is_device_ptr(da)
316 for (int i=0; i<100; i++)
318 // CHECK-NEXT: for (int i = 0; i < 100; i++)
320 return tmain<int>(argc) + *tmain<int *>(&argc);