xref: /llvm-project/offload/test/api/omp_host_pinned_memory_alloc.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 
main()6*330d8983SJohannes Doerfert int main() {
7*330d8983SJohannes Doerfert   const int N = 64;
8*330d8983SJohannes Doerfert 
9*330d8983SJohannes Doerfert   int *hst_ptr = omp_alloc(N * sizeof(int), llvm_omp_target_host_mem_alloc);
10*330d8983SJohannes Doerfert 
11*330d8983SJohannes Doerfert   for (int i = 0; i < N; ++i)
12*330d8983SJohannes Doerfert     hst_ptr[i] = 2;
13*330d8983SJohannes Doerfert 
14*330d8983SJohannes Doerfert #pragma omp target teams distribute parallel for map(tofrom : hst_ptr[0 : N])
15*330d8983SJohannes Doerfert   for (int i = 0; i < N; ++i)
16*330d8983SJohannes Doerfert     hst_ptr[i] -= 1;
17*330d8983SJohannes Doerfert 
18*330d8983SJohannes Doerfert   int sum = 0;
19*330d8983SJohannes Doerfert   for (int i = 0; i < N; ++i)
20*330d8983SJohannes Doerfert     sum += hst_ptr[i];
21*330d8983SJohannes Doerfert 
22*330d8983SJohannes Doerfert   omp_free(hst_ptr, llvm_omp_target_host_mem_alloc);
23*330d8983SJohannes Doerfert   // CHECK: PASS
24*330d8983SJohannes Doerfert   if (sum == N)
25*330d8983SJohannes Doerfert     printf("PASS\n");
26*330d8983SJohannes Doerfert }
27