aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/c-c++-common/gomp/interop-2.c
blob: 3e6ed81d014347a3bd2f792609945f848010d7d6 (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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/* { dg-do compile { target { c || c++11 } } } */
/* { dg-additional-options "-std=c23"  { target c } } */
/* C++11 and C23 because of 'constexpr'.  */

/* The following definitions are in omp_lib, which cannot be included
   in gcc/testsuite/  */

#if __cplusplus >= 201103L
# define __GOMP_UINTPTR_T_ENUM : __UINTPTR_TYPE__
#else
# define __GOMP_UINTPTR_T_ENUM
#endif

typedef enum omp_interop_t __GOMP_UINTPTR_T_ENUM
{
  omp_interop_none = 0,
  __omp_interop_t_max__ = __UINTPTR_MAX__
} omp_interop_t;

typedef enum omp_interop_fr_t
{
  omp_ifr_cuda = 1,
  omp_ifr_cuda_driver = 2,
  omp_ifr_opencl = 3,
  omp_ifr_sycl = 4,
  omp_ifr_hip = 5,
  omp_ifr_level_zero = 6,
  omp_ifr_hsa = 7,
  omp_ifr_last = omp_ifr_hsa
} omp_interop_fr_t;


// ---------------------------------

void f(const omp_interop_t ocp)
{
  constexpr omp_interop_t oce = omp_interop_none;
  const omp_interop_t occ = omp_interop_none;
  omp_interop_t od[5];
  omp_interop_t *op;
  short o2;
  float of;

  #pragma omp interop init (targetsync: ocp)  // { dg-error "'ocp' shall not be const" }
  #pragma omp interop init (targetsync: oce)  // { dg-error "'oce' shall not be const" }
  #pragma omp interop init (targetsync: occ)  // { dg-error "'occ' shall not be const" }
  #pragma omp interop init (targetsync: od)   // { dg-error "'od' must be of 'omp_interop_t'" }
  #pragma omp interop init (targetsync: od[1])// { dg-error "expected '\\)' before '\\\[' token" }
                                  // { dg-error "'od' must be of 'omp_interop_t'" "" { target *-*-* } .-1 }
  #pragma omp interop init (targetsync: op)   // { dg-error "'op' must be of 'omp_interop_t'" }
  #pragma omp interop init (targetsync: *op)
  // { dg-error "expected identifier before '\\*' token" "" { target c } .-1 }
  // { dg-error "expected unqualified-id before '\\*' token" "" { target c++ } .-2 }
  #pragma omp interop init (targetsync: o2)   // { dg-error "'o2' must be of 'omp_interop_t'" }
  #pragma omp interop init (targetsync: of)   // { dg-error "'of' must be of 'omp_interop_t'" }

  #pragma omp interop use (ocp)  // OK
  #pragma omp interop use (oce)  // odd but okay
  #pragma omp interop use (occ)  // okayish
  #pragma omp interop use (od)   // { dg-error "'od' must be of 'omp_interop_t'" }
  #pragma omp interop use (od[1])// { dg-error "expected '\\)' before '\\\[' token" }
                                 // { dg-error "'od' must be of 'omp_interop_t'" "" { target *-*-* } .-1 }
  #pragma omp interop use (op)   // { dg-error "'op' must be of 'omp_interop_t'" }
  #pragma omp interop use (*op)
  // { dg-error "expected identifier before '\\*' token" "" { target c } .-1 }
  // { dg-error "expected unqualified-id before '\\*' token" "" { target c++ } .-2 }
  #pragma omp interop use (o2)   // { dg-error "'o2' must be of 'omp_interop_t'" }
  #pragma omp interop use (of)   // { dg-error "'of' must be of 'omp_interop_t'" }

  #pragma omp interop destroy (ocp)  // { dg-error "'ocp' shall not be const" }
  #pragma omp interop destroy (oce)  // { dg-error "'oce' shall not be const" }
  #pragma omp interop destroy (occ)  // { dg-error "'occ' shall not be const" }
  #pragma omp interop destroy (od)   // { dg-error "'od' must be of 'omp_interop_t'" }
  #pragma omp interop destroy (od[1])// { dg-error "expected '\\)' before '\\\[' token" }
                                     // { dg-error "'od' must be of 'omp_interop_t'" "" { target *-*-* } .-1 }
  #pragma omp interop destroy (op)   // { dg-error "'op' must be of 'omp_interop_t'" }
  #pragma omp interop destroy (*op)
  // { dg-error "expected identifier before '\\*' token" "" { target c } .-1 }
  // { dg-error "expected unqualified-id before '\\*' token" "" { target c++ } .-2 }
  #pragma omp interop destroy (o2)   // { dg-error "'o2' must be of 'omp_interop_t'" }
  #pragma omp interop destroy (of)   // { dg-error "'of' must be of 'omp_interop_t'" }
}

void g()
{
  omp_interop_t obj1, obj2, obj3, obj4, obj5;
  int x;

  #pragma omp interop init (target, prefer_type( {fr("") }) : obj1)  // { dg-error "non-empty string literal expected before '\\)' token" }
  #pragma omp interop init (target, prefer_type( {fr("hip") , attr(omp_ifr_cuda) }) : obj1) ! { dg-error "expected string literal before 'omp_ifr_cuda'" }

  #pragma omp interop init (target, prefer_type( {fr("hip") , attr("myooption") }) : obj1)  // { dg-error "'attr' string literal must start with 'ompx_'" }
  #pragma omp interop init (target, prefer_type( {fr("hip") , attr("ompx_option") , attr("ompx_") } ) : obj1)
  #pragma omp interop init (target, prefer_type( {fr("hip") , attr("ompx_option") }, { attr("ompx_") } ) : obj1)
  #pragma omp interop init (target, prefer_type( {fr("hip") , attr("ompx_option") }  { attr("ompx_") } ) : obj1)  // { dg-error "expected '\\)' or ',' before '\{' token" }
  #pragma omp interop init (target, prefer_type( {fr("hip") , attr("ompx_option")   ) : obj1)  // { dg-error "expected ',' or '\}' before '\\)' token" }

  #pragma omp interop init (target, prefer_type( {fr("hip") attr("ompx_option")   ) : obj1) // { dg-error "expected ',' or '\}' before 'attr'" }
  #pragma omp interop init (target, prefer_type( {fr("hip")}), prefer_type("cuda") : obj1)  // { dg-error "duplicate 'prefer_type' modifier" }

  #pragma omp interop init (target, prefer_type( {attr("ompx_option1,ompx_option2") } ) : obj1)  // { dg-error "'attr' string literal must not contain a comma" }

  #pragma omp interop init (target, prefer_type( {attr("ompx_option1,ompx_option2")   ) : obj1) // { dg-error "'attr' string literal must not contain a comma" }

  #pragma omp interop init ( targetsync other ) : obj1)
  // { dg-error "expected an OpenMP clause before ':' token" "" { target *-*-* } .-1 }
  // { dg-error "expected ':' before 'other'" ""  { target *-*-* } .-2 }

  #pragma omp interop init (target, prefer_type( {fr("cuda") } ), other : obj1)   // { dg-error "expected 'prefer_type', 'target', or 'targetsync'" }
  #pragma omp interop init (prefer_type( {fr("cuda") } ), obj1) // { dg-error "expected 'prefer_type', 'target', or 'targetsync'" }
}