Files
llvm/offload/test/offloading/spmdization.c
Joseph Huber 0fcce4fb7b [OpenMP] Mark problematic tests as XFAIL / UNSUPPORTED (#161267)
Summary:
Several of these tests have been failing for literal years. Ideally we
make efforts to fix this, but keeping these broken has had serious
consequences on our testing infrastructure where failures are the norm
so almost all test failures are disregarded. I made a tracking issue for
the ones that have been disabled.

https://github.com/llvm/llvm-project/issues/161265
2025-09-29 15:17:55 -05:00

47 lines
1.4 KiB
C

// clang-format off
// RUN: %libomptarget-compileopt-generic
// RUN: env LIBOMPTARGET_INFO=16 \
// RUN: %libomptarget-run-generic 2>&1 | %fcheck-generic --check-prefixes=CHECK,SPMD
// RUN: %libomptarget-compileopt-generic -mllvm --openmp-opt-disable-spmdization \
// RUN: -Xoffload-linker -mllvm=--openmp-opt-disable-spmdization
// RUN: env LIBOMPTARGET_INFO=16 \
// RUN: %libomptarget-run-generic 2>&1 | %fcheck-generic --check-prefixes=CHECK,GENERIC
// clang-format on
// REQUIRES: gpu
#include <omp.h>
#include <stdio.h>
__attribute__((weak)) void noop() {}
int main(void) {
int nthreads = 0, ip = 0, lvl = 0, alvl = 0, nested = 0, tid = 0, maxt = 0;
#pragma omp target map(from : nthreads, ip, lvl, alvl, nested, tid, maxt)
{
nthreads = omp_get_num_threads();
ip = omp_in_parallel();
lvl = omp_get_level();
alvl = omp_get_active_level();
nested = omp_get_nested();
tid = omp_get_thread_num();
maxt = omp_get_max_threads();
#pragma omp parallel
noop();
}
printf("NumThreads: %i, InParallel: %i, Level: %i, ActiveLevel: %i, Nested: %i, "
"ThreadNum: %i, MaxThreads: %i\n",
nthreads, ip, lvl, alvl, nested, tid, maxt);
// GENERIC: Generic mode
// SPMD: Generic-SPMD mode
// CHECK: NumThreads: 1
// CHECK: InParallel: 0
// CHECK: Level: 0
// CHECK: ActiveLevel: 0
// CHECK: Nested: 0
// CHECK: ThreadNum: 0
// CHECK: MaxThreads:
return 0;
}