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