1*330d8983SJohannes Doerfert // RUN: %libomptarget-compile-and-run-generic
2*330d8983SJohannes Doerfert
3*330d8983SJohannes Doerfert #include "stdio.h"
4*330d8983SJohannes Doerfert #include <omp.h>
5*330d8983SJohannes Doerfert #include <stdlib.h>
6*330d8983SJohannes Doerfert
main()7*330d8983SJohannes Doerfert int main() {
8*330d8983SJohannes Doerfert int d = omp_get_default_device();
9*330d8983SJohannes Doerfert int id = omp_get_initial_device();
10*330d8983SJohannes Doerfert int a[128], b[64], c[32], e[16], q[128], i;
11*330d8983SJohannes Doerfert void *p;
12*330d8983SJohannes Doerfert
13*330d8983SJohannes Doerfert if (d < 0 || d >= omp_get_num_devices())
14*330d8983SJohannes Doerfert d = id;
15*330d8983SJohannes Doerfert
16*330d8983SJohannes Doerfert p = omp_target_alloc(130 * sizeof(int), d);
17*330d8983SJohannes Doerfert if (p == NULL)
18*330d8983SJohannes Doerfert return 0;
19*330d8983SJohannes Doerfert
20*330d8983SJohannes Doerfert for (i = 0; i < 128; ++i)
21*330d8983SJohannes Doerfert a[i] = i + 1;
22*330d8983SJohannes Doerfert for (i = 0; i < 64; ++i)
23*330d8983SJohannes Doerfert b[i] = i + 2;
24*330d8983SJohannes Doerfert for (i = 0; i < 32; i++)
25*330d8983SJohannes Doerfert c[i] = 0;
26*330d8983SJohannes Doerfert for (i = 0; i < 16; i++)
27*330d8983SJohannes Doerfert e[i] = i + 4;
28*330d8983SJohannes Doerfert
29*330d8983SJohannes Doerfert omp_depend_t obj[2];
30*330d8983SJohannes Doerfert
31*330d8983SJohannes Doerfert #pragma omp parallel num_threads(5)
32*330d8983SJohannes Doerfert #pragma omp single
33*330d8983SJohannes Doerfert {
34*330d8983SJohannes Doerfert #pragma omp task depend(out : p)
35*330d8983SJohannes Doerfert omp_target_memcpy(p, a, 128 * sizeof(int), 0, 0, d, id);
36*330d8983SJohannes Doerfert
37*330d8983SJohannes Doerfert #pragma omp task depend(inout : p)
38*330d8983SJohannes Doerfert omp_target_memcpy(p, b, 64 * sizeof(int), 0, 0, d, id);
39*330d8983SJohannes Doerfert
40*330d8983SJohannes Doerfert #pragma omp task depend(out : c)
41*330d8983SJohannes Doerfert for (i = 0; i < 32; i++)
42*330d8983SJohannes Doerfert c[i] = i + 3;
43*330d8983SJohannes Doerfert
44*330d8983SJohannes Doerfert #pragma omp depobj(obj[0]) depend(inout : p)
45*330d8983SJohannes Doerfert #pragma omp depobj(obj[1]) depend(in : c)
46*330d8983SJohannes Doerfert omp_target_memcpy_async(p, c, 32 * sizeof(int), 0, 0, d, id, 2, obj);
47*330d8983SJohannes Doerfert
48*330d8983SJohannes Doerfert #pragma omp task depend(in : p)
49*330d8983SJohannes Doerfert omp_target_memcpy(p, e, 16 * sizeof(int), 0, 0, d, id);
50*330d8983SJohannes Doerfert }
51*330d8983SJohannes Doerfert
52*330d8983SJohannes Doerfert #pragma omp taskwait
53*330d8983SJohannes Doerfert
54*330d8983SJohannes Doerfert for (i = 0; i < 128; ++i)
55*330d8983SJohannes Doerfert q[i] = 0;
56*330d8983SJohannes Doerfert omp_target_memcpy(q, p, 128 * sizeof(int), 0, 0, id, d);
57*330d8983SJohannes Doerfert for (i = 0; i < 16; ++i)
58*330d8983SJohannes Doerfert if (q[i] != i + 4)
59*330d8983SJohannes Doerfert abort();
60*330d8983SJohannes Doerfert for (i = 16; i < 32; ++i)
61*330d8983SJohannes Doerfert if (q[i] != i + 3)
62*330d8983SJohannes Doerfert abort();
63*330d8983SJohannes Doerfert for (i = 32; i < 64; ++i)
64*330d8983SJohannes Doerfert if (q[i] != i + 2)
65*330d8983SJohannes Doerfert abort();
66*330d8983SJohannes Doerfert for (i = 64; i < 128; ++i)
67*330d8983SJohannes Doerfert if (q[i] != i + 1)
68*330d8983SJohannes Doerfert abort();
69*330d8983SJohannes Doerfert
70*330d8983SJohannes Doerfert omp_target_free(p, d);
71*330d8983SJohannes Doerfert
72*330d8983SJohannes Doerfert return 0;
73*330d8983SJohannes Doerfert }
74