task-1.c 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. extern void abort (void);
  2. int a = 18;
  3. void
  4. f1 (int i, int j, int k)
  5. {
  6. int l = 6, m = 7, n = 8;
  7. #pragma omp task private(j, m) shared(k, n)
  8. {
  9. j = 6;
  10. m = 5;
  11. if (++a != 19 || ++i != 9 || j != 6 || ++l != 7 || m != 5 || ++n != 9)
  12. #pragma omp atomic
  13. k++;
  14. }
  15. #pragma omp taskwait
  16. if (a != 19 || i != 8 || j != 26 || k != 0 || l != 6 || m != 7 || n != 9)
  17. abort ();
  18. }
  19. int v1 = 1, v2 = 2, v5 = 5;
  20. int e;
  21. void
  22. f2 (void)
  23. {
  24. int v3 = 3;
  25. #pragma omp sections private (v1) firstprivate (v2)
  26. {
  27. #pragma omp section
  28. {
  29. int v4 = 4;
  30. v1 = 7;
  31. #pragma omp task
  32. {
  33. if (++v1 != 8 || ++v2 != 3 || ++v3 != 4 || ++v4 != 5 || ++v5 != 6)
  34. e = 1;
  35. }
  36. #pragma omp taskwait
  37. if (v1 != 7 || v2 != 2 || v3 != 3 || v4 != 4 || v5 != 6)
  38. abort ();
  39. if (e)
  40. abort ();
  41. }
  42. }
  43. }
  44. void
  45. f3 (int i, int j, int k)
  46. {
  47. int l = 6, m = 7, n = 8;
  48. #pragma omp task private(j, m) shared(k, n) untied
  49. {
  50. j = 6;
  51. m = 5;
  52. if (++a != 19 || ++i != 9 || j != 6 || ++l != 7 || m != 5 || ++n != 9)
  53. #pragma omp atomic
  54. k++;
  55. }
  56. #pragma omp taskwait
  57. if (a != 19 || i != 8 || j != 26 || k != 0 || l != 6 || m != 7 || n != 9)
  58. abort ();
  59. }
  60. int
  61. main (void)
  62. {
  63. f1 (8, 26, 0);
  64. f2 ();
  65. a = 18;
  66. f3 (8, 26, 0);
  67. a = 18;
  68. #pragma omp parallel num_threads(4)
  69. {
  70. #pragma omp master
  71. {
  72. f1 (8, 26, 0);
  73. a = 18;
  74. f3 (8, 26, 0);
  75. }
  76. }
  77. return 0;
  78. }