1*614c7ef8SJonathan Peyton // RUN: %libomp-compile-and-run 2*614c7ef8SJonathan Peyton #include <stdio.h> 3*614c7ef8SJonathan Peyton #include "omp_testsuite.h" 4*614c7ef8SJonathan Peyton test_omp_critical()5*614c7ef8SJonathan Peytonint test_omp_critical() 6*614c7ef8SJonathan Peyton { 7*614c7ef8SJonathan Peyton int sum; 8*614c7ef8SJonathan Peyton int known_sum; 9*614c7ef8SJonathan Peyton 10*614c7ef8SJonathan Peyton sum=0; 11*614c7ef8SJonathan Peyton #pragma omp parallel 12*614c7ef8SJonathan Peyton { 13*614c7ef8SJonathan Peyton int mysum=0; 14*614c7ef8SJonathan Peyton int i; 15*614c7ef8SJonathan Peyton #pragma omp for 16*614c7ef8SJonathan Peyton for (i = 0; i < 1000; i++) 17*614c7ef8SJonathan Peyton mysum = mysum + i; 18*614c7ef8SJonathan Peyton 19*614c7ef8SJonathan Peyton #pragma omp critical 20*614c7ef8SJonathan Peyton sum = mysum +sum; 21*614c7ef8SJonathan Peyton } 22*614c7ef8SJonathan Peyton known_sum = 999 * 1000 / 2; 23*614c7ef8SJonathan Peyton return (known_sum == sum); 24*614c7ef8SJonathan Peyton } 25*614c7ef8SJonathan Peyton main()26*614c7ef8SJonathan Peytonint main() 27*614c7ef8SJonathan Peyton { 28*614c7ef8SJonathan Peyton int i; 29*614c7ef8SJonathan Peyton int num_failed=0; 30*614c7ef8SJonathan Peyton 31*614c7ef8SJonathan Peyton for(i = 0; i < REPETITIONS; i++) { 32*614c7ef8SJonathan Peyton if(!test_omp_critical()) { 33*614c7ef8SJonathan Peyton num_failed++; 34*614c7ef8SJonathan Peyton } 35*614c7ef8SJonathan Peyton } 36*614c7ef8SJonathan Peyton return num_failed; 37*614c7ef8SJonathan Peyton } 38