atomic-13.C 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. // { dg-do run }
  2. extern "C" void abort ();
  3. int cnt;
  4. int
  5. foo ()
  6. {
  7. return cnt++;
  8. }
  9. template <typename T>
  10. void
  11. bar ()
  12. {
  13. extern T x;
  14. T v, *p;
  15. p = &x;
  16. #pragma omp atomic update
  17. p[foo (), 0] = 16 + 6 - p[foo (), 0];
  18. #pragma omp atomic read
  19. v = x;
  20. if (cnt != 2 || v != 16)
  21. abort ();
  22. #pragma omp atomic capture
  23. v = p[foo () + foo (), 0] = p[foo () + foo (), 0] + 3;
  24. if (cnt != 6 || v != 19)
  25. abort ();
  26. #pragma omp atomic capture
  27. v = p[foo (), 0] = 12 * 1 / 2 + (foo (), 0) + p[foo (), 0];
  28. if (cnt != 9 || v != 25)
  29. abort ();
  30. #pragma omp atomic capture
  31. {
  32. v = p[foo () & 0]; p[foo () & 0] = (foo (), 1) * 9 - p[foo () & 0];
  33. }
  34. if (cnt != 13 || v != 25)
  35. abort ();
  36. #pragma omp atomic read
  37. v = x;
  38. if (v != -16)
  39. abort ();
  40. #pragma omp atomic capture
  41. {
  42. p[0 & foo ()] = 16 - 2 + 3 + p[0 & foo ()]; v = p[0 & foo ()];
  43. }
  44. if (cnt != 16 || v != 1)
  45. abort ();
  46. #pragma omp atomic capture
  47. {
  48. v = p[foo (), 0]; p[foo (), 0] = (foo (), 7) ? 13 : foo () + 6;
  49. }
  50. if (cnt != 19 || v != 1)
  51. abort ();
  52. #pragma omp atomic read
  53. v = x;
  54. if (v != 13)
  55. abort ();
  56. }
  57. int x = 6;
  58. int
  59. main ()
  60. {
  61. bar <int> ();
  62. return 0;
  63. }