llvm-project/offload/test/offloading/strided_multiple_update_to.c
Nick Sarnie 75cc3cd1e8
[offload][lit] XFAIL failing non-contiguous update tests on Intel (#176955)
The new tests added in https://github.com/llvm/llvm-project/pull/169623
are [failing](https://lab.llvm.org/buildbot/#/builders/225/builds/544)
on the Intel GPU runner, so XFAIL them as with the other tests.

Signed-off-by: Sarnie, Nick <nick.sarnie@intel.com>
2026-01-20 16:39:25 +00:00

125 lines
2.8 KiB
C

// This test checks that #pragma omp target update to(data1[0:3:4],
// data2[0:2:5]) correctly updates disjoint strided sections of multiple arrays
// from the host to the device.
// RUN: %libomptarget-compile-run-and-check-generic
// XFAIL: intelgpu
#include <omp.h>
#include <stdio.h>
int main() {
int len = 12;
double data1[len], data2[len];
// Initialize host arrays
for (int i = 0; i < len; i++) {
data1[i] = i;
data2[i] = i * 10;
}
printf("original host array values:\n");
printf("data1:\n");
for (int i = 0; i < len; i++)
printf("%.1f\n", data1[i]);
printf("data2:\n");
for (int i = 0; i < len; i++)
printf("%.1f\n", data2[i]);
// CHECK: original host array values:
// CHECK-NEXT: data1:
// CHECK-NEXT: 0.0
// CHECK-NEXT: 1.0
// CHECK-NEXT: 2.0
// CHECK-NEXT: 3.0
// CHECK-NEXT: 4.0
// CHECK-NEXT: 5.0
// CHECK-NEXT: 6.0
// CHECK-NEXT: 7.0
// CHECK-NEXT: 8.0
// CHECK-NEXT: 9.0
// CHECK-NEXT: 10.0
// CHECK-NEXT: 11.0
// CHECK-NEXT: data2:
// CHECK-NEXT: 0.0
// CHECK-NEXT: 10.0
// CHECK-NEXT: 20.0
// CHECK-NEXT: 30.0
// CHECK-NEXT: 40.0
// CHECK-NEXT: 50.0
// CHECK-NEXT: 60.0
// CHECK-NEXT: 70.0
// CHECK-NEXT: 80.0
// CHECK-NEXT: 90.0
// CHECK-NEXT: 100.0
// CHECK-NEXT: 110.0
#pragma omp target data map(tofrom : data1[0 : len], data2[0 : len])
{
// Initialize device arrays to 20
#pragma omp target
{
for (int i = 0; i < len; i++) {
data1[i] = 20.0;
data2[i] = 20.0;
}
}
// Modify host arrays for strided elements
data1[0] = 10.0;
data1[4] = 10.0;
data1[8] = 10.0;
data2[0] = 10.0;
data2[5] = 10.0;
// data1[0:3:4] // indices 0,4,8
// data2[0:2:5] // indices 0,5
#pragma omp target update to(data1[0 : 3 : 4], data2[0 : 2 : 5])
// Verify on device by adding 5
#pragma omp target
{
for (int i = 0; i < len; i++)
data1[i] += 5.0;
for (int i = 0; i < len; i++)
data2[i] += 5.0;
}
}
printf("device array values after update to:\n");
printf("data1:\n");
for (int i = 0; i < len; i++)
printf("%.1f\n", data1[i]);
printf("data2:\n");
for (int i = 0; i < len; i++)
printf("%.1f\n", data2[i]);
// CHECK: device array values after update to:
// CHECK-NEXT: data1:
// CHECK-NEXT: 15.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 15.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 15.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: data2:
// CHECK-NEXT: 15.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 15.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
// CHECK-NEXT: 25.0
}