annotate libgomp/testsuite/libgomp.oacc-c-c++-common/deep-copy-9.c @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
1 #include <stdlib.h>
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
2
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
3 typedef struct {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
4 int *a;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
5 int *b;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
6 } mystruct;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
7
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
8 int
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
9 main (int argc, char* argv[])
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
10 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
11 const int N = 1024;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
12 mystruct *m = (mystruct *) malloc (sizeof (*m));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
13 int i;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
14
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
15 m->a = (int *) malloc (N * sizeof (int));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
16 m->b = (int *) malloc (N * sizeof (int));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
17
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
18 for (i = 0; i < N; i++)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
19 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
20 m->a[i] = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
21 m->b[i] = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
22 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
23
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
24 #pragma acc enter data copyin(m[0:1])
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
25
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
26 for (int i = 0; i < 99; i++)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
27 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
28 int j;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
29 int *ptr = m->a;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
30 #pragma acc parallel loop copy(m->a[0:N])
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
31 for (j = 0; j < N; j++)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
32 m->a[j]++;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
33 #pragma acc parallel loop copy(m->b[0:N])
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
34 for (j = 0; j < N; j++)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
35 m->b[j]++;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
36 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
37
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
38 #pragma acc exit data copyout(m[0:1])
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
39
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
40 for (i = 0; i < N; i++)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
41 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
42 if (m->a[i] != 99)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
43 abort ();
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
44 if (m->b[i] != 99)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
45 abort ();
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
46 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
47
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
48 free (m->a);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
49 free (m->b);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
50 free (m);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
51
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
52 return 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
53 }