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