111
|
1 #define THE_LOOP \
|
|
2 for (i = j + 1; i < n; i += 3) \
|
|
3 a[i] = i
|
|
4
|
|
5 void __attribute__((noinline, noclone))
|
|
6 foo (int j, int n, int *a)
|
|
7 {
|
|
8 #pragma omp parallel
|
|
9 {
|
|
10 #pragma omp single
|
|
11 {
|
|
12 int i;
|
|
13 #pragma omp target
|
|
14 #pragma omp teams
|
|
15 #pragma omp distribute parallel for shared(a) firstprivate(n) private(i) firstprivate(j)
|
|
16 THE_LOOP;
|
|
17 }
|
|
18 }
|
|
19 }
|
|
20
|
|
21 void __attribute__((noinline, noclone))
|
|
22 bar (int j, int n, int *a)
|
|
23 {
|
|
24 int i;
|
|
25 THE_LOOP;
|
|
26 }
|
|
27
|
|
28 int main (int argc, char **argv)
|
|
29 {
|
|
30 int n = 32;
|
|
31 int *a = __builtin_malloc (sizeof (int) * n);
|
|
32 int *ref = __builtin_malloc (sizeof (int) * n);
|
|
33 int i, j = 4;
|
|
34
|
|
35 __builtin_memset (a, 0, sizeof (int) * n);
|
|
36 __builtin_memset (ref, 0, sizeof (int) * n);
|
|
37 bar (j, n, ref);
|
|
38 foo (j, n, a);
|
|
39 for (i = 0; i < n; i ++)
|
|
40 {
|
|
41 if (a[i] != ref[i])
|
|
42 __builtin_abort ();
|
|
43 }
|
|
44 return 0;
|
|
45 }
|