gcc/libgomp/testsuite/libgomp.oacc-c-c++-common/deep-copy-14.c
Julian Brown c2eb021fd2 OpenACC 2.6 deep copy: C and C++ execution tests
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
2019-12-20 01:39:42 +00:00

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;
}