annotate gcc/testsuite/c-c++-common/gomp/master-combined-1.c @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
1 void bar (int *);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
2
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
3 void
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
4 foo (int *a)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
5 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
6 int i, j, k, u = 0, v = 0, w = 0, x = 0, y = 0, z = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
7 #pragma omp parallel master default(none) private (k)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
8 bar (&k);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
9 #pragma omp parallel default(none) firstprivate(a) shared(x, y, z)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
10 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
11 #pragma omp master taskloop reduction (+:x) default(none) firstprivate(a)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
12 for (i = 0; i < 64; i++)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
13 x += a[i];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
14 #pragma omp master taskloop simd reduction (+:y) default(none) firstprivate(a) private (i)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
15 for (i = 0; i < 64; i++)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
16 y += a[i];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
17 #pragma omp master taskloop simd collapse(2) reduction (+:z) default(none) firstprivate(a) private (i, j)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
18 for (j = 0; j < 1; j++)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
19 for (i = 0; i < 64; ++i)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
20 z += a[i];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
21 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
22 #pragma omp parallel master taskloop reduction (+:u) default(none) firstprivate(a)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
23 for (i = 0; i < 64; i++)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
24 u += a[i];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
25 #pragma omp parallel master taskloop simd reduction (+:v) default(none) firstprivate(a)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
26 for (i = 0; i < 64; i++)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
27 v += a[i];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
28 #pragma omp parallel master taskloop simd collapse(2) reduction (+:w) default(none) firstprivate(a)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
29 for (j = 0; j < 1; j++)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
30 for (i = 0; i < 64; ++i)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
31 w += a[i];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
32 }