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 if (k
== omp_get_thread_num ())
23 #pragma omp parallel for shared (a, e) firstprivate (b, f) \
24 lastprivate (c, g) private (d, h) \
25 schedule (static, 1) num_threads (4) \
27 for (i
= 0; i
< 4; i
++)
29 if (a
!= 8 || b
!= 12 || e
[0] != 'a' || f
[0] != 'b')
43 if (a
!= 8 + 6 || b
!= 12 + i
|| c
!= i
|| d
!= i
)
45 if (e
[0] != 'a' + 6 || f
[0] != 'b' + i
|| g
[0] != 'g' + i
)
50 if (j
|| a
!= 8 + 6 || b
!= 12 || c
!= 3 || d
!= 20)
52 if (e
[0] != 'a' + 6 || f
[0] != 'b' || g
[0] != 'g' + 3 || h
[0] != 'd')