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