diff options
author | Justin Lebar <jlebar@google.com> | 2016-09-28 22:45:58 +0000 |
---|---|---|
committer | Justin Lebar <jlebar@google.com> | 2016-09-28 22:45:58 +0000 |
commit | b17840de33e316a633749bab2c97c470d93ce933 (patch) | |
tree | 01e3fcbd55d5caa92cc7f3c932716ab845a67928 /clang/lib/Sema/SemaCUDA.cpp | |
parent | 2a8db34044c3a994bc2198730ac61a8a7f38878f (diff) | |
download | bcm5719-llvm-b17840de33e316a633749bab2c97c470d93ce933.tar.gz bcm5719-llvm-b17840de33e316a633749bab2c97c470d93ce933.zip |
[CUDA] Disallow variable-length arrays in CUDA device code.
Reviewers: tra
Subscribers: cfe-commits, jhen
Differential Revision: https://reviews.llvm.org/D25050
llvm-svn: 282647
Diffstat (limited to 'clang/lib/Sema/SemaCUDA.cpp')
-rw-r--r-- | clang/lib/Sema/SemaCUDA.cpp | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaCUDA.cpp b/clang/lib/Sema/SemaCUDA.cpp index b1939a17157..c75bdc7f59a 100644 --- a/clang/lib/Sema/SemaCUDA.cpp +++ b/clang/lib/Sema/SemaCUDA.cpp @@ -539,3 +539,23 @@ bool Sema::CheckCUDAExceptionExpr(SourceLocation Loc, StringRef ExprTy) { } return true; } + +bool Sema::CheckCUDAVLA(SourceLocation Loc) { + assert(getLangOpts().CUDA && "Should only be called during CUDA compilation"); + FunctionDecl *CurFn = dyn_cast<FunctionDecl>(CurContext); + if (!CurFn) + return true; + CUDAFunctionTarget Target = IdentifyCUDATarget(CurFn); + if (Target == CFT_Global || Target == CFT_Device) { + Diag(Loc, diag::err_cuda_vla) << Target; + return false; + } + if (Target == CFT_HostDevice && getLangOpts().CUDAIsDevice) { + PartialDiagnostic ErrPD{PartialDiagnostic::NullDiagnostic()}; + ErrPD.Reset(diag::err_cuda_vla); + ErrPD << Target; + CurFn->addDeferredDiag({Loc, std::move(ErrPD)}); + return false; + } + return true; +} |