2012-03-27 23:13:14 +00:00
|
|
|
/* { dg-do run } */
|
|
|
|
|
|
|
|
#include <assert.h>
|
|
|
|
int A[2][2] = { 1, 2, 3, 4 };
|
|
|
|
void
|
|
|
|
f (int n, int B[n][n], int C[])
|
|
|
|
{
|
|
|
|
int D[2][2] = { 1, 2, 3, 4 };
|
|
|
|
int E[n][n];
|
|
|
|
assert (n >= 2);
|
|
|
|
E[1][1] = 4;
|
|
|
|
#pragma omp parallel firstprivate(B, C, D, E)
|
|
|
|
{
|
2015-08-28 15:33:40 +00:00
|
|
|
assert (sizeof (B) == sizeof (int (*)[n])); /* { dg-warning "on array function parameter" } */
|
|
|
|
assert (sizeof (C) == sizeof (int *)); /* { dg-warning "on array function parameter" } */
|
2012-03-27 23:13:14 +00:00
|
|
|
assert (sizeof (D) == 4 * sizeof (int));
|
|
|
|
assert (sizeof (E) == n * n * sizeof (int));
|
|
|
|
/* Private B and C have values of original B and C. */
|
|
|
|
assert (&B[1][1] == &A[1][1]);
|
|
|
|
assert (&C[3] == &A[1][1]);
|
|
|
|
assert (D[1][1] == 4);
|
|
|
|
assert (E[1][1] == 4);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
int
|
|
|
|
main ()
|
|
|
|
{
|
|
|
|
f (2, A, A[0]);
|
|
|
|
return 0;
|
|
|
|
}
|