blob: 7c20e76ce138acff0115b8c0f43f4e55b7116264 (
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
|
// RUN: %libomptarget-compilexx-and-run-generic
// RUN: %libomptarget-compileoptxx-and-run-generic
#include <cassert>
int main(int argc, char *argv[]) {
int data[1024];
int sum = 0;
for (int i = 0; i < 1024; ++i)
data[i] = i;
#pragma omp target map(tofrom : sum) map(to : data) depend(inout : data[0]) \
nowait
{
for (int i = 0; i < 1024; ++i) {
sum += data[i];
}
}
#pragma omp target map(tofrom : sum) map(to : data) depend(inout : data[0])
{
for (int i = 0; i < 1024; ++i) {
sum += data[i];
}
}
assert(sum == 1023 * 1024);
return 0;
}
|