// clang-format off
// RUN: %libomptarget-compilexx-generic && %libomptarget-run-generic 2>&1 | %fcheck-generic
// clang-format on
// UNSUPPORTED: aarch64-unknown-linux-gnu
// UNSUPPORTED: aarch64-unknown-linux-gnu-LTO
// UNSUPPORTED: x86_64-unknown-linux-gnu
// UNSUPPORTED: x86_64-unknown-linux-gnu-LTO
// UNSUPPORTED: s390x-ibm-linux-gnu
// UNSUPPORTED: s390x-ibm-linux-gnu-LTO
// REQUIRES: amdgcn-amd-amdhsa
#include <omp.h>
#include <stdio.h>
#define N 100
bool schedule(int lb, int ub, int stride, int chunk) {
int i;
int result[N];
for (i = 0; i < N; i++) {
result[i] = 0;
}
#pragma omp target parallel for schedule(dynamic, chunk) \
map(tofrom : result[ : N])
for (i = lb; i < ub; i += stride) {
result[i] += i;
}
int value = 0;
bool success = true;
for (i = 0; i < N; i += stride) {
if (value != result[i]) {
printf("ERROR: result[%d] = %d instead of %d\n", i, result[i], value);
success = false;
break;
}
value += stride;
}
return success;
}
int main() {
// CHECK: SUCCESS CHUNK SIZE 1
if (schedule(0, N, 5, 1))
printf("SUCCESS CHUNK SIZE 1\n");
// CHECK: SUCCESS CHUNK SIZE 3
if (schedule(0, N, 5, 3))
printf("SUCCESS CHUNK SIZE 3\n");
return 0;
}