private-1.c 928 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  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 parallel private(j, m) shared(k, n) firstprivate(i, l) \
  8. num_threads(1)
  9. {
  10. j = 6;
  11. m = 5;
  12. if (++a != 19 || ++i != 9 || j != 6 || ++l != 7 || m != 5 || ++n != 9)
  13. #pragma omp atomic
  14. k++;
  15. }
  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 parallel num_threads(1) firstprivate(v1, v2, v3, v4)
  32. {
  33. if (++v1 != 8 || ++v2 != 3 || ++v3 != 4 || ++v4 != 5 || ++v5 != 6)
  34. e = 1;
  35. }
  36. if (v1 != 7 || v2 != 2 || v3 != 3 || v4 != 4 || v5 != 6)
  37. abort ();
  38. if (e)
  39. abort ();
  40. }
  41. }
  42. }
  43. int
  44. main (void)
  45. {
  46. f1 (8, 26, 0);
  47. f2 ();
  48. return 0;
  49. }