[memprof] Upgrade a unit test to MemProf Version 3 (#117063)
[llvm-project.git] / openmp / runtime / test / worksharing / for / omp_for_nowait.c
blob95a477538f2ad3e14776d9bcbcec37359307412c
1 // RUN: %libomp-compile-and-run
2 #include <stdio.h>
3 #include "omp_testsuite.h"
5 /*
6 * This test will hang if the nowait is not working properly.
8 * It relies on a thread skipping to the second for construct to
9 * release the threads in the first for construct.
11 * Also, we use static scheduling to guarantee that one
12 * thread will make it to the second for construct.
14 volatile int release;
15 volatile int count;
17 void wait_for_release_then_increment(int rank)
19 fprintf(stderr, "Thread nr %d enters first for construct"
20 " and waits.\n", rank);
21 while (release == 0);
22 #pragma omp atomic
23 count++;
26 void release_and_increment(int rank)
28 fprintf(stderr, "Thread nr %d sets release to 1\n", rank);
29 release = 1;
30 #pragma omp atomic
31 count++;
34 int test_omp_for_nowait()
36 release = 0;
37 count = 0;
39 #pragma omp parallel num_threads(4)
41 int rank;
42 int i;
44 rank = omp_get_thread_num();
46 #pragma omp for schedule(static) nowait
47 for (i = 0; i < 4; i++) {
48 if (i < 3)
49 wait_for_release_then_increment(rank);
50 else {
51 fprintf(stderr, "Thread nr %d enters first for and goes "
52 "immediately to the next for construct to release.\n", rank);
53 #pragma omp atomic
54 count++;
58 #pragma omp for schedule(static)
59 for (i = 0; i < 4; i++) {
60 release_and_increment(rank);
63 return (count==8);
66 int main()
68 int i;
69 int num_failed=0;
71 for(i = 0; i < REPETITIONS; i++) {
72 if(!test_omp_for_nowait()) {
73 num_failed++;
76 return num_failed;