(root)/
gcc-13.2.0/
libgomp/
testsuite/
libgomp.c/
target-18.c
       1  extern void abort (void);
       2  struct S { int e, f; };
       3  
       4  void
       5  foo (int n)
       6  {
       7    int a[4] = { 0, 1, 2, 3 }, b[n], c = 4;
       8    struct S d = { 5, 6 };
       9    int *p = a + 1, i, err;
      10    for (i = 0; i < n; i++)
      11      b[i] = 9 + i;
      12    #pragma omp target data map(to:a)
      13    #pragma omp target data use_device_ptr(p) map(from:err)
      14    #pragma omp target is_device_ptr(p) private(i) map(from:err)
      15    {
      16      err = 0;
      17      for (i = 0; i < 4; i++)
      18        if (p[i - 1] != i)
      19  	err = 1;
      20    }
      21    if (err)
      22      abort ();
      23    for (i = 0; i < 4; i++)
      24      a[i] = 23 + i;
      25    #pragma omp target data map(to:a)
      26    #pragma omp target data use_device_addr(a) map(from:err)
      27    #pragma omp target is_device_ptr(a) private(i) map(from:err)
      28    {
      29      err = 0;
      30      for (i = 0; i < 4; i++)
      31        if (a[i] != 23 + i)
      32  	err = 1;
      33    }
      34    if (err)
      35      abort ();
      36    #pragma omp target data map(to:b)
      37    #pragma omp target data use_device_addr(b) map(from:err)
      38    #pragma omp target is_device_ptr(b) private(i) map(from:err)
      39    {
      40      err = 0;
      41      for (i = 0; i < 4; i++)
      42        if (b[i] != 9 + i)
      43  	err = 1;
      44    }
      45    if (err)
      46      abort ();
      47    #pragma omp target data map(to:c)
      48    #pragma omp target data use_device_addr(c) map(from:err)
      49    {
      50      int *q = &c;
      51      #pragma omp target is_device_ptr(q) map(from:err)
      52      {
      53        err = *q != 4;
      54      }
      55    }
      56    if (err)
      57      abort ();
      58    #pragma omp target data map(to:d)
      59    #pragma omp target data use_device_addr(d) map(from:err)
      60    {
      61      struct S *r = &d;
      62      #pragma omp target is_device_ptr(r) map(from:err)
      63      {
      64        err = r->e != 5 || r->f != 6;
      65      }
      66    }
      67    if (err)
      68      abort ();
      69  }
      70  
      71  int
      72  main ()
      73  {
      74    foo (9);
      75    return 0;
      76  }