/* { dg-do run } */ #ifndef NONMONOTONIC_TYPE #include #include #define NONMONOTONIC_TYPE int #define NONMONOTONIC_END(n) n #endif int a[73]; int main () { NONMONOTONIC_TYPE i; #pragma omp parallel for schedule(nonmonotonic: dynamic) for (i = 0; i < NONMONOTONIC_END (73); i++) a[i]++; #pragma omp parallel for schedule(nonmonotonic: dynamic, 5) for (i = 0; i < NONMONOTONIC_END (73); i++) a[i]++; #pragma omp parallel for schedule(nonmonotonic: guided) for (i = 0; i < NONMONOTONIC_END (73); i++) a[i]++; #pragma omp parallel for schedule(nonmonotonic: guided, 7) for (i = 0; i < NONMONOTONIC_END (73); i++) a[i]++; #pragma omp parallel { int cnt = omp_get_num_threads (); int thr = omp_get_thread_num (); if (thr < 73) a[thr]++; #pragma omp barrier #pragma omp for schedule(nonmonotonic: dynamic) for (i = 0; i < NONMONOTONIC_END (73); i++) a[i]++; #pragma omp for schedule(nonmonotonic: dynamic, 7) for (i = 0; i < NONMONOTONIC_END (73); i++) a[i]++; #pragma omp for schedule(nonmonotonic: guided) for (i = 0; i < NONMONOTONIC_END (73); i++) a[i]++; #pragma omp for schedule(nonmonotonic: guided, 5) for (i = 0; i < NONMONOTONIC_END (73); i++) a[i]++; #pragma omp single private (i) for (i = 0; i < 73; i++) if (a[i] != 8 + (i < cnt)) abort (); } return 0; }