diff options
Diffstat (limited to 'clang/lib/Sema')
| -rw-r--r-- | clang/lib/Sema/SemaOpenMP.cpp | 20 | 
1 files changed, 20 insertions, 0 deletions
| diff --git a/clang/lib/Sema/SemaOpenMP.cpp b/clang/lib/Sema/SemaOpenMP.cpp index ffcb4ba2de5..3767f40ecb2 100644 --- a/clang/lib/Sema/SemaOpenMP.cpp +++ b/clang/lib/Sema/SemaOpenMP.cpp @@ -12333,6 +12333,26 @@ static bool checkMapConflicts(          // An expression is a subset of the other.          if (CurrentRegionOnly && (CI == CE || SI == SE)) {            if (CKind == OMPC_map) { +            if (CI != CE || SI != SE) { +              // Allow constructs like this: map(s, s.ptr[0:1]), where s.ptr is +              // a pointer. +              auto Begin = +                  CI != CE ? CurComponents.begin() : StackComponents.begin(); +              auto End = CI != CE ? CurComponents.end() : StackComponents.end(); +              auto It = Begin; +              while (It != End && !It->getAssociatedDeclaration()) +                std::advance(It, 1); +              assert(It != End && +                     "Expected at least one component with the declaration."); +              if (It != Begin && It->getAssociatedDeclaration() +                                     ->getType() +                                     .getCanonicalType() +                                     ->isAnyPointerType()) { +                IsEnclosedByDataEnvironmentExpr = false; +                EnclosingExpr = nullptr; +                return false; +              } +            }              SemaRef.Diag(ELoc, diag::err_omp_map_shared_storage) << ERange;            } else {              assert(CKind == OMPC_to || CKind == OMPC_from); | 

