Many tests in the `offload` project have requirements defined by which targets are not supported rather than which platforms are supported. This patch aims to streamline the requirement definitions by adding four new feature tags: `host`, `gpu`, `amdgpu`, and `nvidiagpu`.
39 lines
840 B
C
39 lines
840 B
C
// RUN: %libomptarget-compilexx-run-and-check-generic
|
|
//
|
|
// REQUIRES: gpu
|
|
|
|
#include <assert.h>
|
|
#include <ompx.h>
|
|
#include <stdint.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
|
|
int main(int argc, char *argv[]) {
|
|
const int num_blocks = 1;
|
|
const int block_size = 256;
|
|
const int N = num_blocks * block_size;
|
|
int *res = (int *)malloc(N * sizeof(int));
|
|
|
|
#pragma omp target teams ompx_bare num_teams(num_blocks) thread_limit(block_size) \
|
|
map(from: res[0:N])
|
|
{
|
|
int tid = ompx_thread_id_x();
|
|
uint64_t mask = ompx_ballot_sync(~0LU, tid & 0x1);
|
|
#if defined __AMDGCN_WAVEFRONT_SIZE && __AMDGCN_WAVEFRONT_SIZE == 64
|
|
res[tid] = mask == 0xaaaaaaaaaaaaaaaa;
|
|
#else
|
|
res[tid] = mask == 0xaaaaaaaa;
|
|
#endif
|
|
}
|
|
|
|
for (int i = 0; i < N; ++i)
|
|
assert(res[i]);
|
|
|
|
// CHECK: PASS
|
|
printf("PASS\n");
|
|
|
|
free(res);
|
|
|
|
return 0;
|
|
}
|