annotate libgomp/testsuite/libgomp.c/pr64734.c @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* PR middle-end/64734 */
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 #include <stdlib.h>
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 void
kono
parents:
diff changeset
6 foo (int *x, int *y)
kono
parents:
diff changeset
7 {
kono
parents:
diff changeset
8 #pragma omp target map (alloc:x[0]) map (alloc:y[0:8])
kono
parents:
diff changeset
9 {
kono
parents:
diff changeset
10 int i;
kono
parents:
diff changeset
11 for (i = 0; i < 8; i++)
kono
parents:
diff changeset
12 if (y[i] != 2 + i)
kono
parents:
diff changeset
13 break;
kono
parents:
diff changeset
14 if (i != 8 || *x != 1)
kono
parents:
diff changeset
15 *x = 6;
kono
parents:
diff changeset
16 else
kono
parents:
diff changeset
17 {
kono
parents:
diff changeset
18 *x = 8;
kono
parents:
diff changeset
19 for (i = 0; i < 8; i++)
kono
parents:
diff changeset
20 y[i] = 9 + i;
kono
parents:
diff changeset
21 }
kono
parents:
diff changeset
22 }
kono
parents:
diff changeset
23 #pragma omp target update from (y[0:8]) from (x[0])
kono
parents:
diff changeset
24 }
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 void
kono
parents:
diff changeset
27 bar (void)
kono
parents:
diff changeset
28 {
kono
parents:
diff changeset
29 int x = 1, y[32] = { 0 };
kono
parents:
diff changeset
30 #pragma omp target data map (to:y[0:32]) map (to:x)
kono
parents:
diff changeset
31 ;
kono
parents:
diff changeset
32 }
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 int
kono
parents:
diff changeset
35 main ()
kono
parents:
diff changeset
36 {
kono
parents:
diff changeset
37 int x = 1, y[8] = { 2, 3, 4, 5, 6, 7, 8, 9 }, i;
kono
parents:
diff changeset
38 #pragma omp target data map (to:y[0:8]) map (to:x)
kono
parents:
diff changeset
39 ;
kono
parents:
diff changeset
40 #pragma omp target data map (to:y[0:8]) map (to:x)
kono
parents:
diff changeset
41 {
kono
parents:
diff changeset
42 #pragma omp target update from (y[0:8]) from (x)
kono
parents:
diff changeset
43 }
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 #pragma omp target data map (to:y[0:8]) map (to:x)
kono
parents:
diff changeset
46 foo (&x, &y[0]);
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 if (x != 8)
kono
parents:
diff changeset
49 abort ();
kono
parents:
diff changeset
50 for (i = 0; i < 8; i++)
kono
parents:
diff changeset
51 if (y[i] != 9 + i)
kono
parents:
diff changeset
52 abort ();
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 return 0;
kono
parents:
diff changeset
55 }