diff options
author | Alexey Bataev <a.bataev@hotmail.com> | 2019-03-22 15:25:12 +0000 |
---|---|---|
committer | Alexey Bataev <a.bataev@hotmail.com> | 2019-03-22 15:25:12 +0000 |
commit | 318f431beb1898a75d12701871c23785283cfd75 (patch) | |
tree | 55c81fcb1c10f11fa2818d9e81ecb4c98e2be095 | |
parent | 6f0191a55a53a2ac337914d670fe3f127ac65b70 (diff) | |
download | bcm5719-llvm-318f431beb1898a75d12701871c23785283cfd75.tar.gz bcm5719-llvm-318f431beb1898a75d12701871c23785283cfd75.zip |
[OPENMP]Allow no allocator clause in target regions with requires
dynamic_allocators.
According to the OpenMP 5.0, 2.11.3 allocate Directive, Restrictions,
allocate directives that appear in a target region must specify an
allocator clause unless a requires directive with the dynamic_allocators
clause is present in the same compilation unit. Patch adds a check for a
presence of the requires directive with the dynamic_allocators clause.
llvm-svn: 356758
-rw-r--r-- | clang/lib/Sema/SemaOpenMP.cpp | 13 | ||||
-rw-r--r-- | clang/test/OpenMP/nvptx_allocate_messages.cpp | 19 |
2 files changed, 24 insertions, 8 deletions
diff --git a/clang/lib/Sema/SemaOpenMP.cpp b/clang/lib/Sema/SemaOpenMP.cpp index 9232ab9d6e8..51e0dafbbc5 100644 --- a/clang/lib/Sema/SemaOpenMP.cpp +++ b/clang/lib/Sema/SemaOpenMP.cpp @@ -422,6 +422,16 @@ public: RequiresDecls.push_back(RD); } + /// Checks if the defined 'requires' directive has specified type of clause. + template <typename ClauseType> + bool hasRequiresDeclWithClause() { + return llvm::any_of(RequiresDecls, [](const OMPRequiresDecl *D) { + return llvm::any_of(D->clauselists(), [](const OMPClause *C) { + return isa<ClauseType>(C); + }); + }); + } + /// Checks for a duplicate clause amongst previously declared requires /// directives bool hasDuplicateRequiresClause(ArrayRef<OMPClause *> ClauseList) const { @@ -2244,7 +2254,8 @@ Sema::DeclGroupPtrTy Sema::ActOnOpenMPAllocateDirective( assert(Clauses.size() <= 1 && "Expected at most one clause."); Expr *Allocator = nullptr; if (Clauses.empty()) { - if (LangOpts.OpenMPIsDevice) + if (LangOpts.OpenMPIsDevice && + !DSAStack->hasRequiresDeclWithClause<OMPDynamicAllocatorsClause>()) targetDiag(Loc, diag::err_expected_allocator_clause); } else { Allocator = cast<OMPAllocatorClause>(Clauses.back())->getAllocator(); diff --git a/clang/test/OpenMP/nvptx_allocate_messages.cpp b/clang/test/OpenMP/nvptx_allocate_messages.cpp index 99aef4338d8..5bb94222270 100644 --- a/clang/test/OpenMP/nvptx_allocate_messages.cpp +++ b/clang/test/OpenMP/nvptx_allocate_messages.cpp @@ -1,17 +1,22 @@ // RUN: %clang_cc1 -verify -fopenmp -triple x86_64-apple-darwin10.6.0 -fopenmp-targets=nvptx64-nvidia-cuda -emit-llvm-bc -o %t-host.bc %s // RUN: %clang_cc1 -verify -DDEVICE -fopenmp -triple nvptx64-nvidia-cuda -fopenmp-targets=nvptx64-nvidia-cuda -fsyntax-only %s -fopenmp-is-device -fopenmp-host-ir-file-path %t-host.bc -#ifndef DEVICE +// RUN: %clang_cc1 -verify -DDEVICE -DREQUIRES -fopenmp -triple nvptx64-nvidia-cuda -fopenmp-targets=nvptx64-nvidia-cuda -fsyntax-only %s -fopenmp-is-device -fopenmp-host-ir-file-path %t-host.bc +#if !defined(DEVICE) || defined(REQUIRES) // expected-no-diagnostics #endif // DEVICE #ifndef HEADER #define HEADER +#if defined(REQUIRES) && defined(DEVICE) +#pragma omp requires dynamic_allocators +#endif // REQUIRES && DEVICE + int bar() { int res = 0; -#ifdef DEVICE +#if defined(DEVICE) && !defined(REQUIRES) // expected-error@+2 {{expected an 'allocator' clause inside of the target region; provide an 'allocator' clause or use 'requires' directive with the 'dynamic_allocators' clause}} -#endif // DEVICE +#endif // DEVICE && !REQUIRES #pragma omp allocate(res) return 0; } @@ -65,13 +70,13 @@ int main () { #pragma omp allocate(a) allocator(omp_thread_mem_alloc) a=2; double b = 3; -#ifdef DEVICE +#if defined(DEVICE) && !defined(REQUIRES) // expected-error@+2 {{expected an 'allocator' clause inside of the target region; provide an 'allocator' clause or use 'requires' directive with the 'dynamic_allocators' clause}} -#endif // DEVICE +#endif // DEVICE && !REQUIRES #pragma omp allocate(b) -#ifdef DEVICE +#if defined(DEVICE) && !defined(REQUIRES) // expected-note@+2 {{called by 'main'}} -#endif // DEVICE +#endif // DEVICE && !REQUIRES return (foo<int>() + bar()); } |