(root)/
gcc-13.2.0/
libgomp/
testsuite/
libgomp.oacc-c-c++-common/
structured-dynamic-lifetimes-8.c
       1  /* { dg-skip-if "" { *-*-* } { "-DACC_MEM_SHARED=1" } } */
       2  
       3  #include <openacc.h>
       4  #include <assert.h>
       5  #include <stdlib.h>
       6  
       7  #define SIZE 1024
       8  
       9  int
      10  main (int argc, char *argv[])
      11  {
      12    char *block1 = (char *) malloc (SIZE);
      13    char *block2 = (char *) malloc (SIZE);
      14  
      15  #ifdef OPENACC_API
      16    acc_copyin (block1, SIZE);
      17  #else
      18  #pragma acc enter data copyin(block1[0:SIZE])
      19  #endif
      20  
      21  #pragma acc data copy(block1[0:SIZE], block2[0:SIZE])
      22    {
      23  #ifdef OPENACC_API
      24      acc_copyout (block1, SIZE);
      25      acc_copyin (block2, SIZE);
      26  #else
      27  #pragma acc exit data copyout(block1[0:SIZE])
      28  #pragma acc enter data copyin(block2[0:SIZE])
      29  #endif
      30      assert (acc_is_present (block1, SIZE));
      31      assert (acc_is_present (block2, SIZE));
      32    }
      33  
      34    assert (!acc_is_present (block1, SIZE));
      35    assert (acc_is_present (block2, SIZE));
      36  #ifdef OPENACC_API
      37    acc_copyout (block2, SIZE);
      38  #else
      39  #pragma acc exit data copyout(block2[0:SIZE])
      40  #endif
      41    assert (!acc_is_present (block2, SIZE));
      42  
      43    free (block1);
      44    free (block2);
      45  
      46    return 0;
      47  }