llvm-project/offload/test/mapping/map_ptr_and_star_global.c
Abhinav Gaba ae4a81e849
[NFC][OpenMP] Add tests for mapping pointers and their dereferences. (#146934)
The output of the compile-and-run tests is incorrect. These will be used
for reference in future commits that resolve the issues.

Also updated the existing clang LIT test,
target_map_both_pointer_pointee_codegen.cpp, with more constructs and
fewer CHECKs (through more update_cc_test_checks filters).
2025-07-08 06:52:38 -04:00

84 lines
2.6 KiB
C

// RUN: %libomptarget-compilexx-run-and-check-generic
#include <omp.h>
#include <stdio.h>
int x[10];
int *p;
void f1() {
p = &x[0];
p[0] = 111;
p[1] = 222;
p[2] = 333;
p[3] = 444;
#pragma omp target enter data map(to : p)
#pragma omp target enter data map(to : p[0 : 5])
int **p_mappedptr = (int **)omp_get_mapped_ptr(&p, omp_get_default_device());
int *x0_mappedptr =
(int *)omp_get_mapped_ptr(&x[0], omp_get_default_device());
int *x0_hostaddr = &x[0];
printf("p_mappedptr %s null\n", p_mappedptr == (int **)NULL ? "==" : "!=");
printf("x0_mappedptr %s null\n", x0_mappedptr == (int *)NULL ? "==" : "!=");
// CHECK: p_mappedptr != null
// CHECK: x0_mappedptr != null
// p is predetermined firstprivate, so its address will be different from
// the mapped address for this construct. So, any changes to p within the
// region will not be visible after the construct.
#pragma omp target map(*p) map(to : p_mappedptr, x0_mappedptr, x0_hostaddr)
{
printf("%d %d %d %d\n", p[0], p_mappedptr == &p, x0_mappedptr == &p[0],
x0_hostaddr == &p[0]);
// CHECK: 111 0 1 0
p++;
}
// For the remaining constructs, p is not firstprivate, so its address will
// be the same as the mapped address, and changes to p will be visible to any
// subsequent regions.
#pragma omp target map(to : *p, p) \
map(to : p_mappedptr, x0_mappedptr, x0_hostaddr)
{
printf("%d %d %d %d\n", p[0], p_mappedptr == &p, x0_mappedptr == &p[0],
x0_hostaddr == &p[0]);
// EXPECTED: 111 1 1 0
// CHECK: 111 0 1 0
p++;
}
#pragma omp target map(to : p, *p) \
map(to : p_mappedptr, x0_mappedptr, x0_hostaddr)
{
printf("%d %d %d %d\n", p[0], p_mappedptr == &p, x0_mappedptr == &p[-1],
x0_hostaddr == &p[-1]);
// EXPECTED: 222 1 1 0
// CHECK: {{[0-9]+}} 0 0 0
p++;
}
#pragma omp target map(present, alloc : p) \
map(to : p_mappedptr, x0_mappedptr, x0_hostaddr)
{
printf("%d %d %d %d\n", p[0], p_mappedptr == &p, x0_mappedptr == &p[-2],
x0_hostaddr == &p[-2]);
// EXPECTED: 333 1 1 0
// CHECK: 111 1 0 0
}
// The following map(from:p) should not bring back p, because p is an
// attached pointer. So, it should still point to the same original
// location, &x[0], on host.
#pragma omp target exit data map(always, from : p)
printf("%d %d\n", p[0], p == &x[0]);
// CHECK: 111 1
#pragma omp target exit data map(delete : p[0 : 5], p)
}
int main() { f1(); }