// RUN: %libomp-compile-and-run #include #include "omp_testsuite.h" int test_omp_critical() { int sum; int known_sum; sum=0; #pragma omp parallel { int mysum=0; int i; #pragma omp for for (i = 0; i < 1000; i++) mysum = mysum + i; #pragma omp critical sum = mysum +sum; } known_sum = 999 * 1000 / 2; return (known_sum == sum); } int main() { int i; int num_failed=0; for(i = 0; i < REPETITIONS; i++) { if(!test_omp_critical()) { num_failed++; } } return num_failed; }