diff options
| author | Joey Gouly <joey.gouly@arm.com> | 2013-01-17 17:35:00 +0000 |
|---|---|---|
| committer | Joey Gouly <joey.gouly@arm.com> | 2013-01-17 17:35:00 +0000 |
| commit | 1d58cdbf4e1737438f0cf94a3d6f827c1b03a39f (patch) | |
| tree | a0903c92afa6131fef22c2e2c9ec638a9bc099f2 /clang/lib | |
| parent | 80a82761bde1fee351c6a7381f439ba8b6213198 (diff) | |
| download | bcm5719-llvm-1d58cdbf4e1737438f0cf94a3d6f827c1b03a39f.tar.gz bcm5719-llvm-1d58cdbf4e1737438f0cf94a3d6f827c1b03a39f.zip | |
Add some semantic checks for OpenCL. Variadic macros, VLAs and bitfields are not supported.
llvm-svn: 172732
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Lex/PPDirectives.cpp | 6 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaDecl.cpp | 6 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaType.cpp | 6 |
3 files changed, 18 insertions, 0 deletions
diff --git a/clang/lib/Lex/PPDirectives.cpp b/clang/lib/Lex/PPDirectives.cpp index 7e46a9cc28e..156ebd21f9d 100644 --- a/clang/lib/Lex/PPDirectives.cpp +++ b/clang/lib/Lex/PPDirectives.cpp @@ -1649,6 +1649,12 @@ bool Preprocessor::ReadMacroDefinitionArgList(MacroInfo *MI, Token &Tok) { diag::warn_cxx98_compat_variadic_macro : diag::ext_variadic_macro); + // OpenCL v1.2 s6.9.e: variadic macros are not supported. + if (LangOpts.OpenCL) { + Diag(Tok, diag::err_pp_opencl_variadic_macros); + return true; + } + // Lex the token after the identifier. LexUnexpandedToken(Tok); if (Tok.isNot(tok::r_paren)) { diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp index 728a58ee614..a13d8b3b462 100644 --- a/clang/lib/Sema/SemaDecl.cpp +++ b/clang/lib/Sema/SemaDecl.cpp @@ -9871,6 +9871,12 @@ FieldDecl *Sema::CheckFieldDecl(DeclarationName Name, QualType T, } } + // OpenCL v1.2 s6.9.c: bitfields are not supported. + if (BitWidth && getLangOpts().OpenCL) { + Diag(Loc, diag::err_opencl_bitfields); + InvalidDecl = true; + } + // C99 6.7.2.1p8: A member of a structure or union may have any type other // than a variably modified type. if (!InvalidDecl && T->isVariablyModifiedType()) { diff --git a/clang/lib/Sema/SemaType.cpp b/clang/lib/Sema/SemaType.cpp index 702954322e5..15aa39b7e4e 100644 --- a/clang/lib/Sema/SemaType.cpp +++ b/clang/lib/Sema/SemaType.cpp @@ -1460,6 +1460,12 @@ QualType Sema::BuildArrayType(QualType T, ArrayType::ArraySizeModifier ASM, T = Context.getConstantArrayType(T, ConstVal, ASM, Quals); } + + // OpenCL v1.2 s6.9.d: variable length arrays are not supported. + if (getLangOpts().OpenCL && T->isVariableArrayType()) { + Diag(Loc, diag::err_opencl_vla); + return QualType(); + } // If this is not C99, extwarn about VLA's and C99 array size modifiers. if (!getLangOpts().C99) { if (T->isVariableArrayType()) { |

