1/* { dg-do compile } */
2/* { dg-options "-O -fopenmp -fdump-tree-ompexp" } */
3
4void
5foo (int *a, int i)
6{
7  int j, k = 1, l = 30, m = 4;
8#pragma omp parallel for num_threads (3 * i) schedule (dynamic, i * 4)
9  for (j = 0; j <= l; j++)
10    a[j] = 1;
11#pragma omp parallel for num_threads (3 * i) schedule (dynamic, i * 4)
12  for (j = k; j <= l; j += (m - 1))
13    a[j] = 2;
14#pragma omp parallel for num_threads (3 * i) schedule (dynamic, 4)
15  for (j = 0; j <= l; j++)
16    a[j] = 3;
17#pragma omp parallel for num_threads (3 * i) schedule (dynamic, 4)
18  for (j = k; j <= l; j += (m - 1))
19    a[j] = 4;
20}
21
22void
23bar (int *a, int i)
24{
25  int j, k = 1, l = 30, m = 4;
26#pragma omp parallel for num_threads (3 * i) schedule (guided, i * 4)
27  for (j = 0; j <= l; j++)
28    a[j] = 1;
29#pragma omp parallel for num_threads (3 * i) schedule (guided, i * 4)
30  for (j = k; j <= l; j += (m - 1))
31    a[j] = 2;
32#pragma omp parallel for num_threads (3 * i) schedule (guided, 4)
33  for (j = 0; j <= l; j++)
34    a[j] = 3;
35#pragma omp parallel for num_threads (3 * i) schedule (guided, 4)
36  for (j = k; j <= l; j += (m - 1))
37    a[j] = 4;
38}
39
40/* { dg-final { scan-tree-dump-times "GOMP_parallel_loop_dynamic_start" 4 "ompexp" { xfail *-*-* } } } */
41/* { dg-final { scan-tree-dump-times "GOMP_parallel_loop_guided_start" 4 "ompexp" { xfail *-*-* } } } */
42/* { dg-final { cleanup-tree-dump "ompexp" } } */
43