a.29.1.c 760 B

123456789101112131415161718192021222324252627282930
  1. /* { dg-do run } */
  2. #include <assert.h>
  3. int A[2][2] = { 1, 2, 3, 4 };
  4. void
  5. f (int n, int B[n][n], int C[])
  6. {
  7. int D[2][2] = { 1, 2, 3, 4 };
  8. int E[n][n];
  9. assert (n >= 2);
  10. E[1][1] = 4;
  11. #pragma omp parallel firstprivate(B, C, D, E)
  12. {
  13. assert (sizeof (B) == sizeof (int (*)[n])); /* { dg-warning "on array function parameter" } */
  14. assert (sizeof (C) == sizeof (int *)); /* { dg-warning "on array function parameter" } */
  15. assert (sizeof (D) == 4 * sizeof (int));
  16. assert (sizeof (E) == n * n * sizeof (int));
  17. /* Private B and C have values of original B and C. */
  18. assert (&B[1][1] == &A[1][1]);
  19. assert (&C[3] == &A[1][1]);
  20. assert (D[1][1] == 4);
  21. assert (E[1][1] == 4);
  22. }
  23. }
  24. int
  25. main ()
  26. {
  27. f (2, A, A[0]);
  28. return 0;
  29. }