| // clang-format off |
| // RUN: %libomptarget-compilexx-generic |
| // RUN: rm -rf %t.testdir |
| // RUN: mkdir -p %t.testdir |
| // RUN: env LIBOMPTARGET_RECORD=1 LIBOMPTARGET_RECORD_MEMSIZE=536870912 LIBOMPTARGET_RECORD_DIR=%t.testdir %libomptarget-run-generic 2>&1 | %fcheck-generic |
| // RUN: ls -t %t.testdir/*.json | sed -n '1p' | grep . | xargs -I {} %omp-kernel-replay --verify {} |
| // RUN: ls -t %t.testdir/*.json | sed -n '1p' | grep . | xargs -I {} %omp-kernel-replay --verify --num-teams=1 --num-threads=1 {} |
| // RUN: ls -t %t.testdir/*.json | sed -n '1p' | grep . | xargs -I {} %omp-kernel-replay --verify --num-teams=2 --num-threads=32 {} |
| // RUN: ls -t %t.testdir/*.json | sed -n '1p' | grep . | xargs -I {} %omp-kernel-replay --verify --num-teams=32 --num-threads=64 {} |
| // clang-format on |
| |
| // REQUIRES: gpu |
| |
| // UNSUPPORTED: aarch64-unknown-linux-gnu |
| // UNSUPPORTED: x86_64-unknown-linux-gnu |
| // UNSUPPORTED: s390x-ibm-linux-gnu |
| // UNSUPPORTED: intelgpu |
| |
| #include <cstdint> |
| #include <cstdio> |
| |
| int main() { |
| size_t Size = 1000; |
| uint64_t *Data = new uint64_t[Size]; |
| |
| for (size_t I = 0; I < Size; ++I) { |
| Data[I] = 20; |
| } |
| |
| #pragma omp target teams distribute parallel for thread_limit(128) \ |
| map(tofrom : Data[0 : Size]) |
| for (size_t I = 0; I < Size; ++I) { |
| Data[I] = 10 + (uint64_t)I; |
| } |
| |
| uint64_t Sum = 0; |
| for (size_t I = 0; I < Size; ++I) { |
| Sum += Data[I]; |
| } |
| |
| // CHECK: PASS |
| if (Sum == 509500) |
| printf("PASS\n"); |
| |
| delete[] Data; |
| } |