1// RUN: %libomp-compile
2// RUN: env OMP_SCHEDULE=nonmonotonic:dynamic,10 %libomp-run
3
4// The test checks iterations distribution for OMP 5.0 nonmonotonic OMP_SCHEDULE
5// case #threads > #chunks (fallback to monotonic dynamic)
6
7#include <stdio.h>
8#include <omp.h>
9
10#define ITERS 100
11#define CHUNK 10
12int err = 0;
13
14int main(int argc, char **argv) {
15 int i, ch, it[ITERS];
16 omp_set_num_threads(16); // #threads is bigger than #chunks
17#pragma omp parallel for schedule(runtime)
18 for (i = 0; i < ITERS; ++i) {
19 it[i] = omp_get_thread_num();
20 }
21 // check that each chunk executed by single thread
22 for (ch = 0; ch < ITERS/CHUNK; ++ch) {
23 int iter = ch * CHUNK;
24 int nt = it[iter]; // thread number
25 for (i = 1; i < CHUNK; ++i) {
26#if _DEBUG
27 printf(format: "iter %d: (%d %d)\n", iter + i, nt, it[iter + i]);
28#endif
29 if (nt != it[iter + i]) {
30 err++;
31 }
32 }
33 }
34 if (err > 0) {
35 printf(format: "Failed, err = %d\n", err);
36 return 1;
37 }
38 printf(format: "Passed\n");
39 return 0;
40}
41

source code of openmp/runtime/test/worksharing/for/omp_nonmonotonic_dynamic1.c