task-8.C 792 B

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