Merge from mainline
[official-gcc.git] / gcc / testsuite / gcc.dg / gomp / for-18.c
blob545f271c80b79f761a52565f544fee3d7b9c2649
1 /* { dg-do compile } */
2 /* { dg-options "-O -fopenmp -fdump-tree-ompexp" } */
4 void
5 foo (int *a, int i)
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;
22 void
23 bar (int *a, int i)
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;
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" } } */