This change adds implementation for named barriers for SPIRV backend. Since there is no built in API/intrinsics for named barrier in SPIRV, the implementation loosely follows implementation for AMD
124 lines
2.8 KiB
C
124 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
|
|
|
|
#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
|
|
}
|