blob: 44719f9e86c0026ee7b4b878c08aec22db823e8c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
// RUN: %libomptarget-compile-run-and-check-generic
// https://github.com/llvm/llvm-project/issues/182119
// UNSUPPORTED: intelgpu
#include <omp.h>
#include <stdio.h>
#include <assert.h>
int main() {
const int N = 64;
int *device_ptr =
omp_alloc(N * sizeof(int), llvm_omp_target_device_mem_alloc);
#pragma omp target teams distribute parallel for is_device_ptr(device_ptr)
for (int i = 0; i < N; ++i) {
device_ptr[i] = 1;
}
int sum = 0;
#pragma omp target parallel for reduction(+ : sum) is_device_ptr(device_ptr)
for (int i = 0; i < N; ++i)
sum += device_ptr[i];
// CHECK: PASS
if (sum == N)
printf("PASS\n");
omp_free(device_ptr, llvm_omp_target_device_mem_alloc);
// Make sure this interface works.
void *ptr = omp_alloc(0, llvm_omp_target_device_mem_alloc);
assert(!ptr && "Ptr not (nullptr)");
omp_free(ptr, llvm_omp_target_device_mem_alloc);
}
|