atomic-16.c 1.1 KB

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