cancel-parallel-2.C 951 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. // { dg-do run }
  2. // { dg-set-target-env-var OMP_CANCELLATION "true" }
  3. #include <unistd.h>
  4. #include <omp.h>
  5. #include "cancel-test.h"
  6. static void
  7. foo (int *x)
  8. {
  9. S a, b, c;
  10. #pragma omp parallel firstprivate(x, c) num_threads (32) private (b)
  11. {
  12. S d;
  13. b.bump ();
  14. c.bump ();
  15. int thr = omp_get_thread_num ();
  16. switch (x[thr])
  17. {
  18. case 4:;
  19. #pragma omp cancel parallel
  20. break;
  21. case 3:
  22. #pragma omp task
  23. usleep (1000);
  24. #pragma omp task
  25. usleep (2000);
  26. #pragma omp task
  27. usleep (4000);
  28. break;
  29. case 2:
  30. usleep (1000);
  31. /* FALLTHRU */
  32. case 1:;
  33. #pragma omp cancellation point parallel
  34. break;
  35. }
  36. #pragma omp barrier
  37. if (omp_get_cancellation ())
  38. abort ();
  39. }
  40. }
  41. int
  42. main ()
  43. {
  44. int i, j, x[32] = { 0, 1, 2, 4, 2, 2, 1, 0 };
  45. foo (x);
  46. for (i = 0; i < 32; i++)
  47. {
  48. for (j = 0; j < 32; j++)
  49. x[j] = rand () & 3;
  50. x[rand () & 31] = 4;
  51. foo (x);
  52. }
  53. S::verify ();
  54. }