1 /* { dg-do run } */
2 
3 #include <omp.h>
4 #include <stdlib.h>
5 #include <string.h>
6 
7 int e;
8 
9 void __attribute__((noinline))
baz(int i,int * p,int j,int * q)10 baz (int i, int *p, int j, int *q)
11 {
12   if (p[0] != 1 || p[i] != 3 || q[0] != 2 || q[j] != 4)
13     #pragma omp atomic
14       e++;
15 }
16 
17 void __attribute__((noinline))
foo(int i,int j)18 foo (int i, int j)
19 {
20   int p[i + 1];
21   int q[j + 1];
22   memset (p, 0, sizeof (p));
23   memset (q, 0, sizeof (q));
24   p[0] = 1;
25   p[i] = 3;
26   q[0] = 2;
27   q[j] = 4;
28   #pragma omp task firstprivate (p, q)
29     baz (i, p, j, q);
30 }
31 
32 int
main(void)33 main (void)
34 {
35   #pragma omp parallel num_threads (4)
36     foo (5 + omp_get_thread_num (), 7 + omp_get_thread_num ());
37   if (e)
38     abort ();
39   return 0;
40 }
41