PR ipa/83619
[official-gcc.git] / libgomp / testsuite / libgomp.hsa.c / function-call-1.c
blob7f15dff96b99240d8a3ee390834fd667005b0bb0
1 #define size 8
3 #pragma omp declare target
4 int
5 identity (int x)
7 return x;
10 int
11 expx (int x, int n)
13 for (int i = 0; i < n - 1; i++)
14 x *= x;
16 return x;
19 float
20 init (int x, int y)
22 int x1 = identity (identity (identity (identity (x))));
23 int y1 = identity (identity (identity (identity (y))));
25 int x2 = expx (x1, 2);
26 int y2 = expx (y1, 2);
28 return (x2 + y2);
30 #pragma omp end declare target
32 int
33 main ()
35 int i, j;
36 int a[size][size];
38 #pragma omp target teams map(to:a[:size][:size])
39 #pragma omp distribute parallel for default(none) private(i, j) shared(a)
40 for (i = 0; i < size; ++i)
41 for (j = 0; j < size; ++j)
42 a[i][j] = init (i, j);
44 for (i = 0; i < size; ++i)
45 for (j = 0; j < size; ++j)
46 if (i * i + j * j != a[i][j])
47 __builtin_abort ();
49 return 0;