c2eb021fd2
libgomp/ * testsuite/libgomp.oacc-c-c++-common/deep-copy-1.c: New test. * testsuite/libgomp.oacc-c-c++-common/deep-copy-2.c: New test. * testsuite/libgomp.oacc-c-c++-common/deep-copy-4.c: New test. * testsuite/libgomp.oacc-c-c++-common/deep-copy-6.c: New test. * testsuite/libgomp.oacc-c-c++-common/deep-copy-7.c: New test. * testsuite/libgomp.oacc-c-c++-common/deep-copy-8.c: New test. * testsuite/libgomp.oacc-c-c++-common/deep-copy-9.c: New test. * testsuite/libgomp.oacc-c-c++-common/deep-copy-10.c: New test. * testsuite/libgomp.oacc-c-c++-common/deep-copy-11.c: New test. * testsuite/libgomp.oacc-c-c++-common/deep-copy-14.c: New test. * testsuite/libgomp.oacc-c++/deep-copy-12.C: New test. * testsuite/libgomp.oacc-c++/deep-copy-13.C: New test. From-SVN: r279629
64 lines
1.3 KiB
C
64 lines
1.3 KiB
C
#include <openacc.h>
|
|
#include <stdlib.h>
|
|
|
|
/* Test attach/detach operation with chained dereferences. */
|
|
|
|
typedef struct mystruct {
|
|
int *a;
|
|
struct mystruct *next;
|
|
} mystruct;
|
|
|
|
int
|
|
main (int argc, char* argv[])
|
|
{
|
|
const int N = 1024;
|
|
mystruct *m = (mystruct *) malloc (sizeof (*m));
|
|
int i;
|
|
|
|
m->a = (int *) malloc (N * sizeof (int));
|
|
m->next = (mystruct *) malloc (sizeof (*m));
|
|
m->next->a = (int *) malloc (N * sizeof (int));
|
|
m->next->next = NULL;
|
|
|
|
for (i = 0; i < N; i++)
|
|
{
|
|
m->a[i] = 0;
|
|
m->next->a[i] = 0;
|
|
}
|
|
|
|
#pragma acc enter data copyin(m[0:1])
|
|
acc_copyin (m->next, sizeof (*m));
|
|
|
|
for (int i = 0; i < 99; i++)
|
|
{
|
|
int j;
|
|
acc_copyin (m->next->a, N * sizeof (int));
|
|
acc_attach ((void **) &m->next);
|
|
/* This will attach only the innermost pointer, i.e. "a[0:N]". That's
|
|
why we have to attach the "m->next" pointer manually above. */
|
|
#pragma acc parallel loop copy(m->next->a[0:N])
|
|
for (j = 0; j < N; j++)
|
|
m->next->a[j]++;
|
|
acc_detach ((void **) &m->next);
|
|
acc_copyout (m->next->a, N * sizeof (int));
|
|
}
|
|
|
|
acc_copyout (m->next, sizeof (*m));
|
|
#pragma acc exit data copyout(m[0:1])
|
|
|
|
for (i = 0; i < N; i++)
|
|
{
|
|
if (m->a[i] != 0)
|
|
abort ();
|
|
if (m->next->a[i] != 99)
|
|
abort ();
|
|
}
|
|
|
|
free (m->next->a);
|
|
free (m->next);
|
|
free (m->a);
|
|
free (m);
|
|
|
|
return 0;
|
|
}
|