1 // RUN: %libomptarget-compilexx-generic -fopenmp-version=51
2 // RUN: %libomptarget-run-generic 2>&1 \
3 // RUN: | %fcheck-generic
5 // UNSUPPORTED: amdgcn-amd-amdhsa
13 *t1d
= (int *)malloc(3 * sizeof(int));
16 for (j
= 0; j
< 3; j
++)
18 #pragma omp target map(tofrom : (*t1d)[0 : 3])
21 printf("%d\n", (*t1d
)[1]);
22 #pragma omp target map(tofrom : (**t2d)[0 : 3])
25 printf("%d\n", (**t2d
)[1]);
26 #pragma omp target map(tofrom : (***t3d)[0 : 3])
29 printf("%d\n", (***t3d
)[1]);
30 #pragma omp target map(tofrom : (**t1d))
33 printf("%d\n", (*t1d
)[0]);
34 #pragma omp target map(tofrom : (*(*(t1d + a) + b)))
35 { *(*(t1d
+ a
) + b
) = 5; }
37 printf("%d\n", *(*(t1d
+ a
) + b
));
46 for (int i
= 0; i
< 3; i
++) {
49 #pragma omp target map((**a)[ : 3])
53 printf("%d\n", (**a
)[1]);
66 void zoo(int **f
, SSA
*sa
) {
68 f
= (int **)malloc(sa
->i
* 4 * sizeof(int));
69 t
= (int *)malloc(sa
->i
* sizeof(int));
71 *(sa
->sa
->i
+ *(f
+ sa
->i
+ 1)) = 4;
72 printf("%d\n", *(sa
->sa
->i
+ *(1 + sa
->i
+ f
)));
73 #pragma omp target map(sa, *(sa->sa->i + *(1 + sa->i + f)))
74 { *(sa
->sa
->i
+ *(1 + sa
->i
+ f
)) = 7; }
76 printf("%d\n", *(sa
->sa
->i
+ *(1 + sa
->i
+ f
)));
86 *x
= (int *)malloc(2 * sizeof(int));
87 #pragma omp target map(**x)
93 #pragma omp target map(*(*x + 1))
97 printf("%d\n", *(*x
+ 1));