forked from OSchip/llvm-project
Add an error to check that all program scope variables are in the constant address space in OpenCL.
llvm-svn: 178811
This commit is contained in:
parent
df6f67ed87
commit
9812634c52
|
@ -6205,7 +6205,9 @@ def err_sampler_argument_required : Error<
|
||||||
"sampler_t variable required - got %0">;
|
"sampler_t variable required - got %0">;
|
||||||
def err_wrong_sampler_addressspace: Error<
|
def err_wrong_sampler_addressspace: Error<
|
||||||
"sampler type cannot be used with the __local and __global address space qualifiers">;
|
"sampler type cannot be used with the __local and __global address space qualifiers">;
|
||||||
|
def err_opencl_global_invalid_addr_space : Error<
|
||||||
|
"global variables must have a constant address space qualifier">;
|
||||||
|
|
||||||
// OpenMP support.
|
// OpenMP support.
|
||||||
def err_omp_expected_var_arg_suggest : Error<
|
def err_omp_expected_var_arg_suggest : Error<
|
||||||
"%0 is not a global variable, static local variable or static data member%select{|; did you mean %2?}1">;
|
"%0 is not a global variable, static local variable or static data member%select{|; did you mean %2?}1">;
|
||||||
|
|
|
@ -5177,6 +5177,16 @@ bool Sema::CheckVariableDeclaration(VarDecl *NewVD,
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// OpenCL v1.2 s6.5 - All program scope variables must be declared in the
|
||||||
|
// __constant address space.
|
||||||
|
if (getLangOpts().OpenCL && NewVD->isFileVarDecl()
|
||||||
|
&& T.getAddressSpace() != LangAS::opencl_constant
|
||||||
|
&& !T->isSamplerT()){
|
||||||
|
Diag(NewVD->getLocation(), diag::err_opencl_global_invalid_addr_space);
|
||||||
|
NewVD->setInvalidDecl();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// OpenCL v1.2 s6.8 -- The static qualifier is valid only in program
|
// OpenCL v1.2 s6.8 -- The static qualifier is valid only in program
|
||||||
// scope.
|
// scope.
|
||||||
if ((getLangOpts().OpenCLVersion >= 120)
|
if ((getLangOpts().OpenCLVersion >= 120)
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
event_t glb_evt; // expected-error {{the event_t type cannot be used to declare a program scope variable}}
|
event_t glb_evt; // expected-error {{the event_t type cannot be used to declare a program scope variable}}
|
||||||
|
|
||||||
struct evt_s {
|
constant struct evt_s {
|
||||||
event_t evt; // expected-error {{the event_t type cannot be used to declare a structure or union field}}
|
event_t evt; // expected-error {{the event_t type cannot be used to declare a structure or union field}}
|
||||||
} evt_str;
|
} evt_str;
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,8 @@
|
||||||
|
|
||||||
static constant int A = 0;
|
static constant int A = 0;
|
||||||
|
|
||||||
|
int X = 0; // expected-error{{global variables must have a constant address space qualifier}}
|
||||||
|
|
||||||
// static is not allowed at local scope.
|
// static is not allowed at local scope.
|
||||||
void kernel foo() {
|
void kernel foo() {
|
||||||
static int X = 5; // expected-error{{variables in function scope cannot be declared static}}
|
static int X = 5; // expected-error{{variables in function scope cannot be declared static}}
|
||||||
|
|
Loading…
Reference in New Issue