xref: /llvm-project/offload/test/api/omp_host_pinned_memory.c (revision 330d8983d25d08580fc1642fea48b2473f47a9da)
1*330d8983SJohannes Doerfert // RUN: %libomptarget-compile-run-and-check-generic
2*330d8983SJohannes Doerfert 
3*330d8983SJohannes Doerfert #include <omp.h>
4*330d8983SJohannes Doerfert #include <stdio.h>
5*330d8983SJohannes Doerfert 
6*330d8983SJohannes Doerfert // Allocate pinned memory on the host
7*330d8983SJohannes Doerfert void *llvm_omp_target_alloc_host(size_t, int);
8*330d8983SJohannes Doerfert void llvm_omp_target_free_host(void *, int);
9*330d8983SJohannes Doerfert 
main()10*330d8983SJohannes Doerfert int main() {
11*330d8983SJohannes Doerfert   const int N = 64;
12*330d8983SJohannes Doerfert   const int device = omp_get_default_device();
13*330d8983SJohannes Doerfert   const int host = omp_get_initial_device();
14*330d8983SJohannes Doerfert 
15*330d8983SJohannes Doerfert   int *hst_ptr = llvm_omp_target_alloc_host(N * sizeof(int), device);
16*330d8983SJohannes Doerfert 
17*330d8983SJohannes Doerfert   for (int i = 0; i < N; ++i)
18*330d8983SJohannes Doerfert     hst_ptr[i] = 2;
19*330d8983SJohannes Doerfert 
20*330d8983SJohannes Doerfert #pragma omp target teams distribute parallel for device(device)                \
21*330d8983SJohannes Doerfert     map(tofrom : hst_ptr[0 : N])
22*330d8983SJohannes Doerfert   for (int i = 0; i < N; ++i)
23*330d8983SJohannes Doerfert     hst_ptr[i] -= 1;
24*330d8983SJohannes Doerfert 
25*330d8983SJohannes Doerfert   int sum = 0;
26*330d8983SJohannes Doerfert   for (int i = 0; i < N; ++i)
27*330d8983SJohannes Doerfert     sum += hst_ptr[i];
28*330d8983SJohannes Doerfert 
29*330d8983SJohannes Doerfert   llvm_omp_target_free_host(hst_ptr, device);
30*330d8983SJohannes Doerfert   // CHECK: PASS
31*330d8983SJohannes Doerfert   if (sum == N)
32*330d8983SJohannes Doerfert     printf("PASS\n");
33*330d8983SJohannes Doerfert }
34