// RUN: %clang_cc1 -fsyntax-only -verify %s // RUN: %clang_cc1 -fsyntax-only -fcuda-is-device -verify %s #include "Inputs/cuda.h" struct S {}; __global__ void kernel_struct(__grid_constant__ const S arg) {} __global__ void kernel_scalar(__grid_constant__ const int arg) {} __global__ void gc_kernel_non_const(__grid_constant__ S arg) {} // expected-error {{__grid_constant__ is only allowed on const-qualified kernel parameters}} void non_kernel(__grid_constant__ S arg) {} // expected-error {{__grid_constant__ is only allowed on const-qualified kernel parameters}} // templates w/ non-dependent argument types get diagnosed right // away, without instantiation. template __global__ void tkernel_nd_const(__grid_constant__ const S arg, T dummy) {} template __global__ void tkernel_nd_non_const(__grid_constant__ S arg, T dummy) {} // expected-error {{__grid_constant__ is only allowed on const-qualified kernel parameters}} // dependent arguments get diagnosed after instantiation. template __global__ void tkernel_const(__grid_constant__ const T arg) {} template __global__ void tkernel(__grid_constant__ T arg) {} // expected-error {{__grid_constant__ is only allowed on const-qualified kernel parameters}} void foo() { tkernel_const<<<1,1>>>({}); tkernel_const<<<1,1>>>({}); tkernel<<<1,1>>>({}); tkernel<<<1,1>>>({}); // expected-note {{in instantiation of function template specialization 'tkernel' requested here}} }