aboutsummaryrefslogtreecommitdiff
path: root/libgomp/testsuite/libgomp.c-c++-common/map-arrayofstruct-3.c
blob: 770ac2ae1aa64855601170a9c3a7a9f32207d37c (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
65
66
67
68
#include <stdlib.h>
#include <assert.h>

struct st {
  int *p;
};

struct tt {
  struct st a[10];
};

struct ut {
  struct tt *t;
};

int main (void)
{
  struct tt *t = (struct tt *) malloc (sizeof *t);
  struct ut *u = (struct ut *) malloc (sizeof *u);

  for (int i = 0; i < 10; i++)
    t->a[i].p = (int *) calloc (5, sizeof (int));

  u->t = t;

  for (int i = 0; i < 10; i++)
    for (int j = 0; j < 10; j++)
      for (int k = 0; k < 10; k++)
	{
	  if (i == j || j == k || i == k)
	    continue;

	  /* This one can use "firstprivate" for T...  */
#pragma omp target map(t->a[i].p, t->a[j].p, t->a[k].p, \
		       t->a[i].p[0:2], t->a[j].p[1:3], t->a[k].p[2])
	  {
	    t->a[i].p[0]++;
	    t->a[j].p[1]++;
	    t->a[k].p[2]++;
	  }

	  /* ...but this one must use attach/detach for T.  */
#pragma omp target map(u->t, u->t->a[i].p, u->t->a[j].p, u->t->a[k].p, \
		       u->t->a[i].p[0:2], u->t->a[j].p[1:3], u->t->a[k].p[2])
	  {
	    u->t->a[i].p[0]++;
	    u->t->a[j].p[1]++;
	    u->t->a[k].p[2]++;
	  }
	}

  for (int i = 0; i < 10; i++)
    {
      assert (t->a[i].p[0] == 144);
      assert (t->a[i].p[1] == 144);
      assert (t->a[i].p[2] == 144);
      free (t->a[i].p);
    }

  free (u);
  free (t);

  return 0;
}

/* { dg-output "(\n|\r|\r\n)" { target offload_device_nonshared_as } } */
/* { dg-output "libgomp: Mapped array elements must be the same .*(\n|\r|\r\n)+" { target offload_device_nonshared_as } } */
/* { dg-shouldfail "" { offload_device_nonshared_as } } */