xref: /llvm-project/openmp/runtime/test/api/omp_alloc_null_fb.c (revision aa3a59e0c69e16ff25ee991636247f9f99bfc34d)
1ebf1830bSJonathan Peyton // RUN: %libomp-compile-and-run
2ebf1830bSJonathan Peyton 
3ebf1830bSJonathan Peyton #include <stdio.h>
4ebf1830bSJonathan Peyton #include <omp.h>
5ebf1830bSJonathan Peyton 
main()6ebf1830bSJonathan Peyton int main() {
7ebf1830bSJonathan Peyton   omp_alloctrait_t at[2];
8ebf1830bSJonathan Peyton   omp_allocator_handle_t a;
9ebf1830bSJonathan Peyton   void *p[2];
10ad24cf2aSKelvin Li   at[0].key = omp_atk_pool_size;
11ebf1830bSJonathan Peyton   at[0].value = 2 * 1024 * 1024;
12ad24cf2aSKelvin Li   at[1].key = omp_atk_fallback;
13ad24cf2aSKelvin Li   at[1].value = omp_atv_null_fb;
14*aa3a59e0SAndreyChurbanov   a = omp_init_allocator(omp_default_mem_space, 2, at);
15*aa3a59e0SAndreyChurbanov   printf("allocator created: %p\n", (void *)a);
16ebf1830bSJonathan Peyton #pragma omp parallel num_threads(2)
17ebf1830bSJonathan Peyton   {
18ebf1830bSJonathan Peyton     int i = omp_get_thread_num();
19ebf1830bSJonathan Peyton     #pragma omp barrier
20ebf1830bSJonathan Peyton     p[i] = omp_alloc(1024 * 1024, a);
21ebf1830bSJonathan Peyton     #pragma omp barrier
22ebf1830bSJonathan Peyton     printf("th %d, ptr %p\n", i, p[i]);
23ebf1830bSJonathan Peyton     omp_free(p[i], a);
24ebf1830bSJonathan Peyton   }
25ebf1830bSJonathan Peyton   // As an allocator has some small memory overhead
26ebf1830bSJonathan Peyton   // exactly one of the two pointers should be NULL
27ebf1830bSJonathan Peyton   // because of NULL fallback requested
28ebf1830bSJonathan Peyton   if ((p[0] == NULL && p[1] != NULL) || (p[0] != NULL && p[1] == NULL)) {
29ebf1830bSJonathan Peyton     printf("passed\n");
30ebf1830bSJonathan Peyton     return 0;
31ebf1830bSJonathan Peyton   } else {
32ebf1830bSJonathan Peyton     printf("failed: pointers %p %p\n", p[0], p[1]);
33ebf1830bSJonathan Peyton     return 1;
34ebf1830bSJonathan Peyton   }
35ebf1830bSJonathan Peyton }
36