Viewing file: allocate-4.C (2.45 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
// { dg-do compile } // { dg-additional-options "-std=c++11" }
typedef enum omp_allocator_handle_t #if __cplusplus >= 201103L : __UINTPTR_TYPE__ #endif { omp_null_allocator = 0, omp_default_mem_alloc = 1, omp_large_cap_mem_alloc = 2, omp_const_mem_alloc = 3, omp_high_bw_mem_alloc = 4, omp_low_lat_mem_alloc = 5, omp_cgroup_mem_alloc = 6, omp_pteam_mem_alloc = 7, omp_thread_mem_alloc = 8, __omp_allocator_handle_t_max__ = __UINTPTR_MAX__ } omp_allocator_handle_t;
namespace N1 { using ::omp_allocator_handle_t; void foo (const omp_allocator_handle_t h) { int x = 0; #pragma omp parallel allocate (allocator (h): x) private (x) x = 1; } }
namespace N2 { typedef enum omp_allocator_handle_t { my = 0 } omp_allocator_handle_t; void foo (omp_allocator_handle_t h) { int x = 0; #pragma omp parallel allocate (allocator (h): x) private (x) // { dg-error "'allocate' clause allocator expression has type 'N2::omp_allocator_handle_t' rather than 'omp_allocator_handle_t'" } x = 1; } }
struct S { void foo () { #pragma omp parallel allocate (allocator(omp_default_mem_alloc):s) firstprivate (s) s++; } int s; };
template <typename T> struct U { int foo () { #pragma omp parallel allocate (allocator(omp_default_mem_alloc):s) firstprivate (s) s++; return 1; } T s; };
template <typename T, int N> int foo (T t) { int x = 0; #pragma omp parallel firstprivate (x) allocate (allocator(t), align (N): x) x = 1; return 0; }
template <typename T> int bar (T t) { int x = 0; #pragma omp parallel firstprivate (x) allocate (allocator(t): x) // { dg-error "'allocate' clause allocator expression has type 'int' rather than 'omp_allocator_handle_t'" } x = 1; return 0; }
template <typename T, int N> int baz (T t) { int x = 0; #pragma omp parallel firstprivate (x) allocate (allocator(t), align (N): x) // { dg-error "'allocate' clause 'align' modifier argument needs to be positive constant power of two integer expression" } x = 1; return 0; }
template <typename T> int qux () { int x = 0; #pragma omp parallel firstprivate (x) allocate (align ((T) 16): x) // { dg-error "'allocate' clause 'align' modifier argument needs to be positive constant power of two integer expression" } x = 1; return 0; }
omp_allocator_handle_t h; int a = foo<omp_allocator_handle_t, 16> (h); int b = bar (0); int c = U<int> ().foo (); int d = baz<omp_allocator_handle_t, 13> (h); int e = qux<long double> ();
|