task-5.c 784 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. /* { dg-do run } */
  2. #include <omp.h>
  3. #include <stdlib.h>
  4. int serr;
  5. int
  6. main ()
  7. {
  8. int e;
  9. #pragma omp parallel shared(serr)
  10. {
  11. if (omp_in_final ())
  12. #pragma omp atomic write
  13. serr = 1;
  14. #pragma omp task if (0) shared(serr)
  15. {
  16. if (omp_in_final ())
  17. #pragma omp atomic write
  18. serr = 1;
  19. #pragma omp task if (0) shared(serr)
  20. if (omp_in_final ())
  21. #pragma omp atomic write
  22. serr = 1;
  23. }
  24. #pragma omp task final (1) shared(serr)
  25. {
  26. if (!omp_in_final ())
  27. #pragma omp atomic write
  28. serr = 1;
  29. #pragma omp taskyield
  30. #pragma omp taskwait
  31. #pragma omp task shared(serr)
  32. if (!omp_in_final ())
  33. #pragma omp atomic write
  34. serr = 1;
  35. }
  36. }
  37. #pragma omp atomic read
  38. e = serr;
  39. if (e)
  40. abort ();
  41. return 0;
  42. }