depobj-1.C 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. #include <stdlib.h>
  2. #include <omp.h>
  3. void
  4. dep (omp_depend_t &d1, omp_depend_t *d2)
  5. {
  6. int x = 1;
  7. #pragma omp depobj (d1) depend(in: x)
  8. #pragma omp depobj (*d2) depend(in: x)
  9. #pragma omp depobj (d2[0]) update(out)
  10. #pragma omp parallel
  11. #pragma omp single
  12. {
  13. #pragma omp task shared (x) depend(depobj:*d2)
  14. x = 2;
  15. #pragma omp task shared (x) depend(depobj : d1)
  16. if (x != 2)
  17. abort ();
  18. }
  19. #pragma omp depobj (d2[0]) destroy
  20. #pragma omp depobj (d1) destroy
  21. }
  22. template <typename T>
  23. void
  24. dep2 (T &d2)
  25. {
  26. T d1;
  27. #pragma omp parallel
  28. #pragma omp single
  29. {
  30. int x = 1;
  31. #pragma omp depobj (d1) depend(out: x)
  32. #pragma omp depobj (*&d2) depend (in:x)
  33. #pragma omp depobj(d2)update(in)
  34. #pragma omp task shared (x) depend(depobj :d1)
  35. x = 2;
  36. #pragma omp task shared (x) depend(depobj: d2)
  37. if (x != 2)
  38. abort ();
  39. #pragma omp taskwait
  40. #pragma omp depobj(d1)destroy
  41. #pragma omp depobj((&d2)[0]) destroy
  42. }
  43. }
  44. template <typename T>
  45. void
  46. dep3 (void)
  47. {
  48. T d[2];
  49. #pragma omp parallel
  50. {
  51. int x = 1;
  52. #pragma omp single
  53. {
  54. #pragma omp depobj(d[0]) depend(out:x)
  55. #pragma omp depobj(d[1]) depend(in: x)
  56. #pragma omp task shared (x) depend(depobj:*d)
  57. x = 2;
  58. #pragma omp task shared (x) depend(depobj:*(d + 1))
  59. if (x != 2)
  60. abort ();
  61. }
  62. }
  63. #pragma omp depobj(d[0]) destroy
  64. #pragma omp depobj(d[1]) destroy
  65. }
  66. int xx;
  67. omp_depend_t dd1, dd2;
  68. template <int N>
  69. void
  70. antidep (void)
  71. {
  72. xx = 1;
  73. #pragma omp parallel
  74. #pragma omp single
  75. {
  76. #pragma omp task shared(xx) depend(depobj:dd2)
  77. if (xx != 1)
  78. abort ();
  79. #pragma omp task shared(xx) depend(depobj:dd1)
  80. xx = 2;
  81. }
  82. }
  83. int
  84. main ()
  85. {
  86. omp_depend_t d1, d2, d3;
  87. dep (d1, &d2);
  88. dep2 <omp_depend_t> (d3);
  89. dep3 <omp_depend_t> ();
  90. #pragma omp depobj (dd1) depend (inout: xx)
  91. #pragma omp depobj (dd2) depend (in : xx)
  92. antidep <0> ();
  93. #pragma omp depobj (dd2) destroy
  94. #pragma omp depobj (dd1) destroy
  95. return 0;
  96. }