1 // RUN: %libomptarget-compilexx-run-and-check-generic
2 
3 // Wrong results on amdgpu
4 // XFAIL: amdgcn-amd-amdhsa
5 // XFAIL: amdgcn-amd-amdhsa-oldDriver
6 
7 #include <cstdio>
8 #include <cstdlib>
9 
10 typedef struct {
11   int a;
12   double *b;
13 } C1;
14 #pragma omp declare mapper(C1 s) map(to : s.a) map(from : s.b [0:2])
15 
16 typedef struct {
17   int a;
18   double *b;
19   C1 c;
20 } C;
21 #pragma omp declare mapper(C s) map(to : s.a, s.c) map(from : s.b [0:2])
22 
23 typedef struct {
24   int e;
25   C f;
26   int h;
27 } D;
28 
29 int main() {
30   constexpr int N = 10;
31   D s;
32   s.e = 111;
33   s.f.a = 222;
34   s.f.c.a = 777;
35   double x[2];
36   double x1[2];
37   x[1] = 20;
38   s.f.b = &x[0];
39   s.f.c.b = &x1[0];
40   s.h = N;
41 
42   D *sp = &s;
43   D **spp = &sp;
44 
45   printf("%d %d %d %4.5f %d\n", spp[0][0].e, spp[0][0].f.a, spp[0][0].f.c.a,
46          spp[0][0].f.b[1], spp[0][0].f.b == &x[0] ? 1 : 0);
47   // CHECK: 111 222 777 20.00000 1
48 
49   __intptr_t p = reinterpret_cast<__intptr_t>(&x[0]);
50 #pragma omp target map(tofrom : spp[0][0]) firstprivate(p)
51   {
52     printf("%d %d %d\n", spp[0][0].f.a, spp[0][0].f.c.a,
53            spp[0][0].f.b == reinterpret_cast<void *>(p) ? 1 : 0);
54     // CHECK: 222 777 0
55     spp[0][0].e = 333;
56     spp[0][0].f.a = 444;
57     spp[0][0].f.c.a = 555;
58     spp[0][0].f.b[1] = 40;
59   }
60   printf("%d %d %d %4.5f %d\n", spp[0][0].e, spp[0][0].f.a, spp[0][0].f.c.a,
61          spp[0][0].f.b[1], spp[0][0].f.b == &x[0] ? 1 : 0);
62   // CHECK: 333 222 777 40.00000 1
63 }
64