aboutsummaryrefslogtreecommitdiff
path: root/libgomp/testsuite/libgomp.c/target-link-1.c
blob: 681677cc2aa90e48ca30adace57333c144140862 (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
struct S { int s, t; };

int a = 1, b = 1;
double c[27];
struct S d = { 8888, 8888 };
#pragma omp declare target link (a) to (b) link (c, d)

int
foo (void)
{
  return a++ + b++;
}

int
bar (int n)
{
  int *p1 = &a;
  int *p2 = &b;
  c[n] += 2.0;
  d.s -= 2;
  d.t -= 2;
  return *p1 + *p2 + d.s + d.t;
}

#pragma omp declare target (foo, bar)

int
main ()
{
  a = b = 2;
  d.s = 17;
  d.t = 18;

  int res, n = 10;
  #pragma omp target map (to: a, b, c, d) map (from: res)
  {
    res = foo () + foo ();
    c[n] = 3.0;
    res += bar (n);
  }

  int shared_mem = 0;
  #pragma omp target map (alloc: shared_mem)
    shared_mem = 1;

  if ((shared_mem && res != (2 + 2) + (3 + 3) + (4 + 4 + 15 + 16))
      || (!shared_mem && res != (2 + 1) + (3 + 2) + (4 + 3 + 15 + 16)))
    __builtin_abort ();

  #pragma omp target enter data map (to: c)
  #pragma omp target update from (c)
  res = (int) (c[n] + 0.5);
  if ((shared_mem && res != 5) || (!shared_mem && res != 0))
    __builtin_abort ();

  #pragma omp target map (to: a, b) map (from: res)
    res = foo ();

  if ((shared_mem && res != 4 + 4) || (!shared_mem && res != 2 + 3))
    __builtin_abort ();

  return 0;
}