4 extern int omp_set_dynamic (int);
5 extern void omp_set_nested (int);
6 extern int omp_get_thread_num (void);
7 extern void abort (void);
8 extern void GOMP_barrier (void);
10 int a
= 8, b
= 12, c
= 16, d
= 20, j
= 0, l
= 0;
11 char e
[10] = "a", f
[10] = "b", g
[10] = "c", h
[10] = "d";
20 #pragma omp parallel num_threads (2) reduction (+:l) \
21 firstprivate (a, b, c, d, e, f, g, h, j)
22 if (k
== omp_get_thread_num ())
24 #pragma omp parallel for shared (a, e) firstprivate (b, f) \
25 lastprivate (c, g) private (d, h) \
26 schedule (static, 1) num_threads (4) \
28 for (i
= 0; i
< 4; i
++)
30 if (a
!= 8 || b
!= 12 || e
[0] != 'a' || f
[0] != 'b')
44 if (a
!= 8 + 6 || b
!= 12 + i
|| c
!= i
|| d
!= i
)
46 if (e
[0] != 'a' + 6 || f
[0] != 'b' + i
|| g
[0] != 'g' + i
)
51 if (j
|| a
!= 8 + 6 || b
!= 12 || c
!= 3 || d
!= 20)
53 if (e
[0] != 'a' + 6 || f
[0] != 'b' || g
[0] != 'g' + 3 || h
[0] != 'd')
58 if (a
!= 8 || b
!= 12 || c
!= 16 || d
!= 20)
60 if (e
[0] != 'a' || f
[0] != 'b' || g
[0] != 'c' || h
[0] != 'd')