aboutsummaryrefslogtreecommitdiff
path: root/libgomp/testsuite/libgomp.c++/target-6.C
blob: 8dbafb0437bd4cab64c2235cf5c6e6b343dde1ce (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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
extern "C" void abort (void);
struct S { int s, t; };

void
foo (int &x, int &y, S &u, S &v, double &s, double &t)
{
  int err = 0, i;
  int a[y - 2], b[y - 2];
  int (&c)[y - 2] = a, (&d)[y - 2] = b;
  for (i = 0; i < y - 2; i++)
    {
      c[i] = i;
      d[i] = 3 + i;
    }
  #pragma omp target private (x, u, s, c, i) firstprivate (y, v, t, d) map(from:err)
  {
    x = y;
    u = v;
    s = t;
    for (i = 0; i < y - 2; i++)
      c[i] = d[i];
    err = (x != 6 || y != 6
	   || u.s != 9 || u.t != 10 || v.s != 9 || v.t != 10
	   || s != 12.5 || t != 12.5);
    for (i = 0; i < y - 2; i++)
      if (d[i] != 3 + i || c[i] != 3 + i)
	err = 1;
      else
	{
	  c[i] += 2 * i;
	  d[i] += i;
	}
    x += 1;
    y += 2;
    u.s += 3;
    v.t += 4;
    s += 2.5;
    t += 3.0;
    if (x != 7 || y != 8
	|| u.s != 12 || u.t != 10 || v.s != 9 || v.t != 14
	|| s != 15.0 || t != 15.5)
      err = 1;
    for (i = 0; i < y - 4; i++)
      if (d[i] != 3 + 2 * i || c[i] != 3 + 3 * i)
	err = 1;
  }
  if (err || x != 5 || y != 6
      || u.s != 7 || u.t != 8 || v.s != 9 || v.t != 10
      || s != 11.5 || t != 12.5)
    abort ();
  for (i = 0; i < y - 2; i++)
    if (d[i] != 3 + i || c[i] != i)
      abort ();
}

int
main ()
{
  int x = 5, y = 6;
  S u = { 7, 8 }, v = { 9, 10 };
  double s = 11.5, t = 12.5;
  foo (x, y, u, v, s, t);
  return 0;
}