]> git.ipfire.org Git - thirdparty/gcc.git/commit
libgomp.c-c++-common/metadirective-1.c: Expect 'error:' for nvptx compile [PR118694]
authorTobias Burnus <tburnus@baylibre.com>
Fri, 23 May 2025 09:30:48 +0000 (11:30 +0200)
committerTobias Burnus <tburnus@baylibre.com>
Fri, 23 May 2025 09:30:48 +0000 (11:30 +0200)
commitb3d07ec7ac2ccd935a79b29e1a0e2eb16225286a
tree3512801bbb03cea9bccd5cafadbb0a93c9e900d9
parentc637186943b78b6e07e3310e878da922ecdd99f4
libgomp.c-c++-common/metadirective-1.c: Expect 'error:' for nvptx compile [PR118694]

OpenMP's 'target teams' is strictly coupled with 'teams'; if the latter
exists, the kernel is launched in directly with multiple teams. Thus,
the host has to know whether the teams construct exists or not. For

   #pragma omp target
     #pragma omp metadirective when (device={arch("nvptx")}: teams loop)

it is simple when 'nvptx' offloading is not supported, otherwise it depends
on the default device at runtime as the user code asks for a single team for
host fallback and gcn offload and multiple for nvptx offload.

In any case, this commit ensures that no FAIL is printed, whatever a
future solution might look like. Instead of a dg-bogus combined with an
'xfail offload_target_nvptx', one an also argue that a dg-error for
'target offload_target_nvptx' would be more appropriate.

libgomp/ChangeLog:

PR middle-end/118694
* testsuite/libgomp.c-c++-common/metadirective-1.c: xfail when
compiling (also) for nvptx offloading as an error is then expected.
libgomp/testsuite/libgomp.c-c++-common/metadirective-1.c