xref: /llvm-project/offload/test/api/omp_target_memcpy_async1.c (revision 330d8983d25d08580fc1642fea48b2473f47a9da)
1*330d8983SJohannes Doerfert // RUN: %libomptarget-compile-and-run-generic
2*330d8983SJohannes Doerfert 
3*330d8983SJohannes Doerfert // Test case for omp_target_memcpy_async, oringally from GCC
4*330d8983SJohannes Doerfert 
5*330d8983SJohannes Doerfert #include "stdio.h"
6*330d8983SJohannes Doerfert #include <omp.h>
7*330d8983SJohannes Doerfert #include <stdlib.h>
8*330d8983SJohannes Doerfert 
main()9*330d8983SJohannes Doerfert int main() {
10*330d8983SJohannes Doerfert   int d = omp_get_default_device();
11*330d8983SJohannes Doerfert   int id = omp_get_initial_device();
12*330d8983SJohannes Doerfert   int q[128], i;
13*330d8983SJohannes Doerfert   void *p;
14*330d8983SJohannes Doerfert 
15*330d8983SJohannes Doerfert   if (d < 0 || d >= omp_get_num_devices())
16*330d8983SJohannes Doerfert     d = id;
17*330d8983SJohannes Doerfert 
18*330d8983SJohannes Doerfert   p = omp_target_alloc(130 * sizeof(int), d);
19*330d8983SJohannes Doerfert   if (p == NULL)
20*330d8983SJohannes Doerfert     return 0;
21*330d8983SJohannes Doerfert 
22*330d8983SJohannes Doerfert   for (i = 0; i < 128; i++)
23*330d8983SJohannes Doerfert     q[i] = i;
24*330d8983SJohannes Doerfert 
25*330d8983SJohannes Doerfert   if (omp_target_memcpy_async(p, q, 128 * sizeof(int), sizeof(int), 0, d, id, 0,
26*330d8983SJohannes Doerfert                               NULL)) {
27*330d8983SJohannes Doerfert     abort();
28*330d8983SJohannes Doerfert   }
29*330d8983SJohannes Doerfert 
30*330d8983SJohannes Doerfert #pragma omp taskwait
31*330d8983SJohannes Doerfert 
32*330d8983SJohannes Doerfert   int q2[128];
33*330d8983SJohannes Doerfert   for (i = 0; i < 128; ++i)
34*330d8983SJohannes Doerfert     q2[i] = 0;
35*330d8983SJohannes Doerfert   if (omp_target_memcpy_async(q2, p, 128 * sizeof(int), 0, sizeof(int), id, d,
36*330d8983SJohannes Doerfert                               0, NULL))
37*330d8983SJohannes Doerfert     abort();
38*330d8983SJohannes Doerfert 
39*330d8983SJohannes Doerfert #pragma omp taskwait
40*330d8983SJohannes Doerfert 
41*330d8983SJohannes Doerfert   for (i = 0; i < 128; ++i)
42*330d8983SJohannes Doerfert     if (q2[i] != q[i])
43*330d8983SJohannes Doerfert       abort();
44*330d8983SJohannes Doerfert 
45*330d8983SJohannes Doerfert   omp_target_free(p, d);
46*330d8983SJohannes Doerfert 
47*330d8983SJohannes Doerfert   return 0;
48*330d8983SJohannes Doerfert }
49