2018-11-09 Jakub Jelinek <jakub@redhat.com>
[official-gcc.git] / gcc / testsuite / gcc.dg / gomp / workshare-reduction-58.c
blob7907aba5ee0c8c35ea9b2a6b0e4a98a1b9818564
1 /* { dg-do compile } */
2 /* { dg-options "-O2 -fopenmp -fdump-tree-optimized" } */
3 /* { dg-final { scan-tree-dump-times "__builtin_GOMP_loop_doacross_start \[^\n\r]*, (?:2147483651|-2147483645), 1, " 1 "optimized" } } */
4 /* { dg-final { scan-tree-dump-times "__builtin_GOMP_loop_end " 1 "optimized" } } */
5 /* { dg-final { scan-tree-dump-times "__builtin_GOMP_doacross_post " 1 "optimized" } } */
6 /* { dg-final { scan-tree-dump-times "__builtin_GOMP_doacross_wait " 1 "optimized" } } */
7 /* { dg-final { scan-tree-dump-times "__builtin_GOMP_loop_guided_next " 1 "optimized" } } */
8 /* { dg-final { scan-tree-dump-times "__builtin_GOMP_workshare_task_reduction_unregister \\(0\\)" 1 "optimized" } } */
9 /* { dg-final { scan-tree-dump-times "__builtin_GOMP_parallel " 1 "optimized" } } */
11 int j;
12 void bar (int *);
14 void
15 foo (int a, int b, int c)
17 int i;
18 #pragma omp parallel
19 #pragma omp for ordered(1) reduction (task, *: j) schedule (guided)
20 for (i = a; i < b; i += c)
22 bar (&j);
23 #pragma omp ordered depend(sink: i - 1)
24 j++;
25 #pragma omp ordered depend(source)