1 //===--- SemaOpenMP.cpp - Semantic Analysis for OpenMP constructs ---------===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 /// \file
10 /// \brief This file implements semantic analysis for OpenMP directives and
11 /// clauses.
12 ///
13 //===----------------------------------------------------------------------===//
14
15 #include "clang/AST/ASTContext.h"
16 #include "clang/AST/Decl.h"
17 #include "clang/AST/DeclCXX.h"
18 #include "clang/AST/DeclOpenMP.h"
19 #include "clang/AST/StmtCXX.h"
20 #include "clang/AST/StmtOpenMP.h"
21 #include "clang/AST/StmtVisitor.h"
22 #include "clang/Basic/OpenMPKinds.h"
23 #include "clang/Lex/Preprocessor.h"
24 #include "clang/Sema/Initialization.h"
25 #include "clang/Sema/Lookup.h"
26 #include "clang/Sema/Scope.h"
27 #include "clang/Sema/ScopeInfo.h"
28 #include "clang/Sema/SemaInternal.h"
29 using namespace clang;
30
31 //===----------------------------------------------------------------------===//
32 // Stack of data-sharing attributes for variables
33 //===----------------------------------------------------------------------===//
34
35 namespace {
36 /// \brief Default data sharing attributes, which can be applied to directive.
37 enum DefaultDataSharingAttributes {
38 DSA_unspecified = 0, /// \brief Data sharing attribute not specified.
39 DSA_none = 1 << 0, /// \brief Default data sharing attribute 'none'.
40 DSA_shared = 1 << 1 /// \brief Default data sharing attribute 'shared'.
41 };
42
43 template <class T> struct MatchesAny {
MatchesAny__anonc48eae3d0111::MatchesAny44 explicit MatchesAny(ArrayRef<T> Arr) : Arr(std::move(Arr)) {}
operator ()__anonc48eae3d0111::MatchesAny45 bool operator()(T Kind) {
46 for (auto KindEl : Arr)
47 if (KindEl == Kind)
48 return true;
49 return false;
50 }
51
52 private:
53 ArrayRef<T> Arr;
54 };
55 struct MatchesAlways {
MatchesAlways__anonc48eae3d0111::MatchesAlways56 MatchesAlways() {}
operator ()__anonc48eae3d0111::MatchesAlways57 template <class T> bool operator()(T) { return true; }
58 };
59
60 typedef MatchesAny<OpenMPClauseKind> MatchesAnyClause;
61 typedef MatchesAny<OpenMPDirectiveKind> MatchesAnyDirective;
62
63 /// \brief Stack for tracking declarations used in OpenMP directives and
64 /// clauses and their data-sharing attributes.
65 class DSAStackTy {
66 public:
67 struct DSAVarData {
68 OpenMPDirectiveKind DKind;
69 OpenMPClauseKind CKind;
70 DeclRefExpr *RefExpr;
71 SourceLocation ImplicitDSALoc;
DSAVarData__anonc48eae3d0111::DSAStackTy::DSAVarData72 DSAVarData()
73 : DKind(OMPD_unknown), CKind(OMPC_unknown), RefExpr(nullptr),
74 ImplicitDSALoc() {}
75 };
76
77 private:
78 struct DSAInfo {
79 OpenMPClauseKind Attributes;
80 DeclRefExpr *RefExpr;
81 };
82 typedef llvm::SmallDenseMap<VarDecl *, DSAInfo, 64> DeclSAMapTy;
83 typedef llvm::SmallDenseMap<VarDecl *, DeclRefExpr *, 64> AlignedMapTy;
84
85 struct SharingMapTy {
86 DeclSAMapTy SharingMap;
87 AlignedMapTy AlignedMap;
88 DefaultDataSharingAttributes DefaultAttr;
89 SourceLocation DefaultAttrLoc;
90 OpenMPDirectiveKind Directive;
91 DeclarationNameInfo DirectiveName;
92 Scope *CurScope;
93 SourceLocation ConstructLoc;
SharingMapTy__anonc48eae3d0111::DSAStackTy::SharingMapTy94 SharingMapTy(OpenMPDirectiveKind DKind, DeclarationNameInfo Name,
95 Scope *CurScope, SourceLocation Loc)
96 : SharingMap(), AlignedMap(), DefaultAttr(DSA_unspecified),
97 Directive(DKind), DirectiveName(std::move(Name)), CurScope(CurScope),
98 ConstructLoc(Loc) {}
SharingMapTy__anonc48eae3d0111::DSAStackTy::SharingMapTy99 SharingMapTy()
100 : SharingMap(), AlignedMap(), DefaultAttr(DSA_unspecified),
101 Directive(OMPD_unknown), DirectiveName(), CurScope(nullptr),
102 ConstructLoc() {}
103 };
104
105 typedef SmallVector<SharingMapTy, 64> StackTy;
106
107 /// \brief Stack of used declaration and their data-sharing attributes.
108 StackTy Stack;
109 Sema &SemaRef;
110
111 typedef SmallVector<SharingMapTy, 8>::reverse_iterator reverse_iterator;
112
113 DSAVarData getDSA(StackTy::reverse_iterator Iter, VarDecl *D);
114
115 /// \brief Checks if the variable is a local for OpenMP region.
116 bool isOpenMPLocal(VarDecl *D, StackTy::reverse_iterator Iter);
117
118 public:
DSAStackTy(Sema & S)119 explicit DSAStackTy(Sema &S) : Stack(1), SemaRef(S) {}
120
push(OpenMPDirectiveKind DKind,const DeclarationNameInfo & DirName,Scope * CurScope,SourceLocation Loc)121 void push(OpenMPDirectiveKind DKind, const DeclarationNameInfo &DirName,
122 Scope *CurScope, SourceLocation Loc) {
123 Stack.push_back(SharingMapTy(DKind, DirName, CurScope, Loc));
124 Stack.back().DefaultAttrLoc = Loc;
125 }
126
pop()127 void pop() {
128 assert(Stack.size() > 1 && "Data-sharing attributes stack is empty!");
129 Stack.pop_back();
130 }
131
132 /// \brief If 'aligned' declaration for given variable \a D was not seen yet,
133 /// add it and return NULL; otherwise return previous occurrence's expression
134 /// for diagnostics.
135 DeclRefExpr *addUniqueAligned(VarDecl *D, DeclRefExpr *NewDE);
136
137 /// \brief Adds explicit data sharing attribute to the specified declaration.
138 void addDSA(VarDecl *D, DeclRefExpr *E, OpenMPClauseKind A);
139
140 /// \brief Returns data sharing attributes from top of the stack for the
141 /// specified declaration.
142 DSAVarData getTopDSA(VarDecl *D);
143 /// \brief Returns data-sharing attributes for the specified declaration.
144 DSAVarData getImplicitDSA(VarDecl *D);
145 /// \brief Checks if the specified variables has data-sharing attributes which
146 /// match specified \a CPred predicate in any directive which matches \a DPred
147 /// predicate.
148 template <class ClausesPredicate, class DirectivesPredicate>
149 DSAVarData hasDSA(VarDecl *D, ClausesPredicate CPred,
150 DirectivesPredicate DPred);
151 /// \brief Checks if the specified variables has data-sharing attributes which
152 /// match specified \a CPred predicate in any innermost directive which
153 /// matches \a DPred predicate.
154 template <class ClausesPredicate, class DirectivesPredicate>
155 DSAVarData hasInnermostDSA(VarDecl *D, ClausesPredicate CPred,
156 DirectivesPredicate DPred);
157
158 /// \brief Returns currently analyzed directive.
getCurrentDirective() const159 OpenMPDirectiveKind getCurrentDirective() const {
160 return Stack.back().Directive;
161 }
162 /// \brief Returns parent directive.
getParentDirective() const163 OpenMPDirectiveKind getParentDirective() const {
164 if (Stack.size() > 2)
165 return Stack[Stack.size() - 2].Directive;
166 return OMPD_unknown;
167 }
168
169 /// \brief Set default data sharing attribute to none.
setDefaultDSANone(SourceLocation Loc)170 void setDefaultDSANone(SourceLocation Loc) {
171 Stack.back().DefaultAttr = DSA_none;
172 Stack.back().DefaultAttrLoc = Loc;
173 }
174 /// \brief Set default data sharing attribute to shared.
setDefaultDSAShared(SourceLocation Loc)175 void setDefaultDSAShared(SourceLocation Loc) {
176 Stack.back().DefaultAttr = DSA_shared;
177 Stack.back().DefaultAttrLoc = Loc;
178 }
179
getDefaultDSA() const180 DefaultDataSharingAttributes getDefaultDSA() const {
181 return Stack.back().DefaultAttr;
182 }
getDefaultDSALocation() const183 SourceLocation getDefaultDSALocation() const {
184 return Stack.back().DefaultAttrLoc;
185 }
186
187 /// \brief Checks if the specified variable is a threadprivate.
isThreadPrivate(VarDecl * D)188 bool isThreadPrivate(VarDecl *D) {
189 DSAVarData DVar = getTopDSA(D);
190 return isOpenMPThreadPrivate(DVar.CKind);
191 }
192
getCurScope() const193 Scope *getCurScope() const { return Stack.back().CurScope; }
getCurScope()194 Scope *getCurScope() { return Stack.back().CurScope; }
getConstructLoc()195 SourceLocation getConstructLoc() { return Stack.back().ConstructLoc; }
196 };
197 } // namespace
198
getDSA(StackTy::reverse_iterator Iter,VarDecl * D)199 DSAStackTy::DSAVarData DSAStackTy::getDSA(StackTy::reverse_iterator Iter,
200 VarDecl *D) {
201 DSAVarData DVar;
202 if (Iter == std::prev(Stack.rend())) {
203 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
204 // in a region but not in construct]
205 // File-scope or namespace-scope variables referenced in called routines
206 // in the region are shared unless they appear in a threadprivate
207 // directive.
208 if (!D->isFunctionOrMethodVarDecl())
209 DVar.CKind = OMPC_shared;
210
211 // OpenMP [2.9.1.2, Data-sharing Attribute Rules for Variables Referenced
212 // in a region but not in construct]
213 // Variables with static storage duration that are declared in called
214 // routines in the region are shared.
215 if (D->hasGlobalStorage())
216 DVar.CKind = OMPC_shared;
217
218 return DVar;
219 }
220
221 DVar.DKind = Iter->Directive;
222 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
223 // in a Construct, C/C++, predetermined, p.1]
224 // Variables with automatic storage duration that are declared in a scope
225 // inside the construct are private.
226 if (isOpenMPLocal(D, Iter) && D->isLocalVarDecl() &&
227 (D->getStorageClass() == SC_Auto || D->getStorageClass() == SC_None)) {
228 DVar.CKind = OMPC_private;
229 return DVar;
230 }
231
232 // Explicitly specified attributes and local variables with predetermined
233 // attributes.
234 if (Iter->SharingMap.count(D)) {
235 DVar.RefExpr = Iter->SharingMap[D].RefExpr;
236 DVar.CKind = Iter->SharingMap[D].Attributes;
237 return DVar;
238 }
239
240 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
241 // in a Construct, C/C++, implicitly determined, p.1]
242 // In a parallel or task construct, the data-sharing attributes of these
243 // variables are determined by the default clause, if present.
244 switch (Iter->DefaultAttr) {
245 case DSA_shared:
246 DVar.CKind = OMPC_shared;
247 DVar.ImplicitDSALoc = Iter->DefaultAttrLoc;
248 return DVar;
249 case DSA_none:
250 return DVar;
251 case DSA_unspecified:
252 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
253 // in a Construct, implicitly determined, p.2]
254 // In a parallel construct, if no default clause is present, these
255 // variables are shared.
256 DVar.ImplicitDSALoc = Iter->DefaultAttrLoc;
257 if (isOpenMPParallelDirective(DVar.DKind)) {
258 DVar.CKind = OMPC_shared;
259 return DVar;
260 }
261
262 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
263 // in a Construct, implicitly determined, p.4]
264 // In a task construct, if no default clause is present, a variable that in
265 // the enclosing context is determined to be shared by all implicit tasks
266 // bound to the current team is shared.
267 if (DVar.DKind == OMPD_task) {
268 DSAVarData DVarTemp;
269 for (StackTy::reverse_iterator I = std::next(Iter),
270 EE = std::prev(Stack.rend());
271 I != EE; ++I) {
272 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables
273 // Referenced
274 // in a Construct, implicitly determined, p.6]
275 // In a task construct, if no default clause is present, a variable
276 // whose data-sharing attribute is not determined by the rules above is
277 // firstprivate.
278 DVarTemp = getDSA(I, D);
279 if (DVarTemp.CKind != OMPC_shared) {
280 DVar.RefExpr = nullptr;
281 DVar.DKind = OMPD_task;
282 DVar.CKind = OMPC_firstprivate;
283 return DVar;
284 }
285 if (isOpenMPParallelDirective(I->Directive))
286 break;
287 }
288 DVar.DKind = OMPD_task;
289 DVar.CKind =
290 (DVarTemp.CKind == OMPC_unknown) ? OMPC_firstprivate : OMPC_shared;
291 return DVar;
292 }
293 }
294 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
295 // in a Construct, implicitly determined, p.3]
296 // For constructs other than task, if no default clause is present, these
297 // variables inherit their data-sharing attributes from the enclosing
298 // context.
299 return getDSA(std::next(Iter), D);
300 }
301
addUniqueAligned(VarDecl * D,DeclRefExpr * NewDE)302 DeclRefExpr *DSAStackTy::addUniqueAligned(VarDecl *D, DeclRefExpr *NewDE) {
303 assert(Stack.size() > 1 && "Data sharing attributes stack is empty");
304 auto It = Stack.back().AlignedMap.find(D);
305 if (It == Stack.back().AlignedMap.end()) {
306 assert(NewDE && "Unexpected nullptr expr to be added into aligned map");
307 Stack.back().AlignedMap[D] = NewDE;
308 return nullptr;
309 } else {
310 assert(It->second && "Unexpected nullptr expr in the aligned map");
311 return It->second;
312 }
313 return nullptr;
314 }
315
addDSA(VarDecl * D,DeclRefExpr * E,OpenMPClauseKind A)316 void DSAStackTy::addDSA(VarDecl *D, DeclRefExpr *E, OpenMPClauseKind A) {
317 if (A == OMPC_threadprivate) {
318 Stack[0].SharingMap[D].Attributes = A;
319 Stack[0].SharingMap[D].RefExpr = E;
320 } else {
321 assert(Stack.size() > 1 && "Data-sharing attributes stack is empty");
322 Stack.back().SharingMap[D].Attributes = A;
323 Stack.back().SharingMap[D].RefExpr = E;
324 }
325 }
326
isOpenMPLocal(VarDecl * D,StackTy::reverse_iterator Iter)327 bool DSAStackTy::isOpenMPLocal(VarDecl *D, StackTy::reverse_iterator Iter) {
328 if (Stack.size() > 2) {
329 reverse_iterator I = Iter, E = std::prev(Stack.rend());
330 Scope *TopScope = nullptr;
331 while (I != E && !isOpenMPParallelDirective(I->Directive)) {
332 ++I;
333 }
334 if (I == E)
335 return false;
336 TopScope = I->CurScope ? I->CurScope->getParent() : nullptr;
337 Scope *CurScope = getCurScope();
338 while (CurScope != TopScope && !CurScope->isDeclScope(D)) {
339 CurScope = CurScope->getParent();
340 }
341 return CurScope != TopScope;
342 }
343 return false;
344 }
345
getTopDSA(VarDecl * D)346 DSAStackTy::DSAVarData DSAStackTy::getTopDSA(VarDecl *D) {
347 DSAVarData DVar;
348
349 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
350 // in a Construct, C/C++, predetermined, p.1]
351 // Variables appearing in threadprivate directives are threadprivate.
352 if (D->getTLSKind() != VarDecl::TLS_None) {
353 DVar.CKind = OMPC_threadprivate;
354 return DVar;
355 }
356 if (Stack[0].SharingMap.count(D)) {
357 DVar.RefExpr = Stack[0].SharingMap[D].RefExpr;
358 DVar.CKind = OMPC_threadprivate;
359 return DVar;
360 }
361
362 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
363 // in a Construct, C/C++, predetermined, p.1]
364 // Variables with automatic storage duration that are declared in a scope
365 // inside the construct are private.
366 OpenMPDirectiveKind Kind = getCurrentDirective();
367 if (!isOpenMPParallelDirective(Kind)) {
368 if (isOpenMPLocal(D, std::next(Stack.rbegin())) && D->isLocalVarDecl() &&
369 (D->getStorageClass() == SC_Auto || D->getStorageClass() == SC_None)) {
370 DVar.CKind = OMPC_private;
371 return DVar;
372 }
373 }
374
375 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
376 // in a Construct, C/C++, predetermined, p.4]
377 // Static data members are shared.
378 if (D->isStaticDataMember()) {
379 // Variables with const-qualified type having no mutable member may be
380 // listed in a firstprivate clause, even if they are static data members.
381 DSAVarData DVarTemp =
382 hasDSA(D, MatchesAnyClause(OMPC_firstprivate), MatchesAlways());
383 if (DVarTemp.CKind == OMPC_firstprivate && DVarTemp.RefExpr)
384 return DVar;
385
386 DVar.CKind = OMPC_shared;
387 return DVar;
388 }
389
390 QualType Type = D->getType().getNonReferenceType().getCanonicalType();
391 bool IsConstant = Type.isConstant(SemaRef.getASTContext());
392 while (Type->isArrayType()) {
393 QualType ElemType = cast<ArrayType>(Type.getTypePtr())->getElementType();
394 Type = ElemType.getNonReferenceType().getCanonicalType();
395 }
396 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
397 // in a Construct, C/C++, predetermined, p.6]
398 // Variables with const qualified type having no mutable member are
399 // shared.
400 CXXRecordDecl *RD =
401 SemaRef.getLangOpts().CPlusPlus ? Type->getAsCXXRecordDecl() : nullptr;
402 if (IsConstant &&
403 !(SemaRef.getLangOpts().CPlusPlus && RD && RD->hasMutableFields())) {
404 // Variables with const-qualified type having no mutable member may be
405 // listed in a firstprivate clause, even if they are static data members.
406 DSAVarData DVarTemp =
407 hasDSA(D, MatchesAnyClause(OMPC_firstprivate), MatchesAlways());
408 if (DVarTemp.CKind == OMPC_firstprivate && DVarTemp.RefExpr)
409 return DVar;
410
411 DVar.CKind = OMPC_shared;
412 return DVar;
413 }
414
415 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
416 // in a Construct, C/C++, predetermined, p.7]
417 // Variables with static storage duration that are declared in a scope
418 // inside the construct are shared.
419 if (D->isStaticLocal()) {
420 DVar.CKind = OMPC_shared;
421 return DVar;
422 }
423
424 // Explicitly specified attributes and local variables with predetermined
425 // attributes.
426 if (Stack.back().SharingMap.count(D)) {
427 DVar.RefExpr = Stack.back().SharingMap[D].RefExpr;
428 DVar.CKind = Stack.back().SharingMap[D].Attributes;
429 }
430
431 return DVar;
432 }
433
getImplicitDSA(VarDecl * D)434 DSAStackTy::DSAVarData DSAStackTy::getImplicitDSA(VarDecl *D) {
435 return getDSA(std::next(Stack.rbegin()), D);
436 }
437
438 template <class ClausesPredicate, class DirectivesPredicate>
hasDSA(VarDecl * D,ClausesPredicate CPred,DirectivesPredicate DPred)439 DSAStackTy::DSAVarData DSAStackTy::hasDSA(VarDecl *D, ClausesPredicate CPred,
440 DirectivesPredicate DPred) {
441 for (StackTy::reverse_iterator I = std::next(Stack.rbegin()),
442 E = std::prev(Stack.rend());
443 I != E; ++I) {
444 if (!DPred(I->Directive))
445 continue;
446 DSAVarData DVar = getDSA(I, D);
447 if (CPred(DVar.CKind))
448 return DVar;
449 }
450 return DSAVarData();
451 }
452
453 template <class ClausesPredicate, class DirectivesPredicate>
hasInnermostDSA(VarDecl * D,ClausesPredicate CPred,DirectivesPredicate DPred)454 DSAStackTy::DSAVarData DSAStackTy::hasInnermostDSA(VarDecl *D,
455 ClausesPredicate CPred,
456 DirectivesPredicate DPred) {
457 for (auto I = Stack.rbegin(), EE = std::prev(Stack.rend()); I != EE; ++I) {
458 if (!DPred(I->Directive))
459 continue;
460 DSAVarData DVar = getDSA(I, D);
461 if (CPred(DVar.CKind))
462 return DVar;
463 return DSAVarData();
464 }
465 return DSAVarData();
466 }
467
InitDataSharingAttributesStack()468 void Sema::InitDataSharingAttributesStack() {
469 VarDataSharingAttributesStack = new DSAStackTy(*this);
470 }
471
472 #define DSAStack static_cast<DSAStackTy *>(VarDataSharingAttributesStack)
473
DestroyDataSharingAttributesStack()474 void Sema::DestroyDataSharingAttributesStack() { delete DSAStack; }
475
StartOpenMPDSABlock(OpenMPDirectiveKind DKind,const DeclarationNameInfo & DirName,Scope * CurScope,SourceLocation Loc)476 void Sema::StartOpenMPDSABlock(OpenMPDirectiveKind DKind,
477 const DeclarationNameInfo &DirName,
478 Scope *CurScope, SourceLocation Loc) {
479 DSAStack->push(DKind, DirName, CurScope, Loc);
480 PushExpressionEvaluationContext(PotentiallyEvaluated);
481 }
482
EndOpenMPDSABlock(Stmt * CurDirective)483 void Sema::EndOpenMPDSABlock(Stmt *CurDirective) {
484 // OpenMP [2.14.3.5, Restrictions, C/C++, p.1]
485 // A variable of class type (or array thereof) that appears in a lastprivate
486 // clause requires an accessible, unambiguous default constructor for the
487 // class type, unless the list item is also specified in a firstprivate
488 // clause.
489 if (auto D = dyn_cast_or_null<OMPExecutableDirective>(CurDirective)) {
490 for (auto C : D->clauses()) {
491 if (auto Clause = dyn_cast<OMPLastprivateClause>(C)) {
492 for (auto VarRef : Clause->varlists()) {
493 if (VarRef->isValueDependent() || VarRef->isTypeDependent())
494 continue;
495 auto VD = cast<VarDecl>(cast<DeclRefExpr>(VarRef)->getDecl());
496 auto DVar = DSAStack->getTopDSA(VD);
497 if (DVar.CKind == OMPC_lastprivate) {
498 SourceLocation ELoc = VarRef->getExprLoc();
499 auto Type = VarRef->getType();
500 if (Type->isArrayType())
501 Type = QualType(Type->getArrayElementTypeNoTypeQual(), 0);
502 CXXRecordDecl *RD =
503 getLangOpts().CPlusPlus ? Type->getAsCXXRecordDecl() : nullptr;
504 // FIXME This code must be replaced by actual constructing of the
505 // lastprivate variable.
506 if (RD) {
507 CXXConstructorDecl *CD = LookupDefaultConstructor(RD);
508 PartialDiagnostic PD =
509 PartialDiagnostic(PartialDiagnostic::NullDiagnostic());
510 if (!CD ||
511 CheckConstructorAccess(
512 ELoc, CD, InitializedEntity::InitializeTemporary(Type),
513 CD->getAccess(), PD) == AR_inaccessible ||
514 CD->isDeleted()) {
515 Diag(ELoc, diag::err_omp_required_method)
516 << getOpenMPClauseName(OMPC_lastprivate) << 0;
517 bool IsDecl = VD->isThisDeclarationADefinition(Context) ==
518 VarDecl::DeclarationOnly;
519 Diag(VD->getLocation(), IsDecl ? diag::note_previous_decl
520 : diag::note_defined_here)
521 << VD;
522 Diag(RD->getLocation(), diag::note_previous_decl) << RD;
523 continue;
524 }
525 MarkFunctionReferenced(ELoc, CD);
526 DiagnoseUseOfDecl(CD, ELoc);
527 }
528 }
529 }
530 }
531 }
532 }
533
534 DSAStack->pop();
535 DiscardCleanupsInEvaluationContext();
536 PopExpressionEvaluationContext();
537 }
538
539 namespace {
540
541 class VarDeclFilterCCC : public CorrectionCandidateCallback {
542 private:
543 Sema &SemaRef;
544
545 public:
VarDeclFilterCCC(Sema & S)546 explicit VarDeclFilterCCC(Sema &S) : SemaRef(S) {}
ValidateCandidate(const TypoCorrection & Candidate)547 bool ValidateCandidate(const TypoCorrection &Candidate) override {
548 NamedDecl *ND = Candidate.getCorrectionDecl();
549 if (VarDecl *VD = dyn_cast_or_null<VarDecl>(ND)) {
550 return VD->hasGlobalStorage() &&
551 SemaRef.isDeclInScope(ND, SemaRef.getCurLexicalContext(),
552 SemaRef.getCurScope());
553 }
554 return false;
555 }
556 };
557 } // namespace
558
ActOnOpenMPIdExpression(Scope * CurScope,CXXScopeSpec & ScopeSpec,const DeclarationNameInfo & Id)559 ExprResult Sema::ActOnOpenMPIdExpression(Scope *CurScope,
560 CXXScopeSpec &ScopeSpec,
561 const DeclarationNameInfo &Id) {
562 LookupResult Lookup(*this, Id, LookupOrdinaryName);
563 LookupParsedName(Lookup, CurScope, &ScopeSpec, true);
564
565 if (Lookup.isAmbiguous())
566 return ExprError();
567
568 VarDecl *VD;
569 if (!Lookup.isSingleResult()) {
570 VarDeclFilterCCC Validator(*this);
571 if (TypoCorrection Corrected =
572 CorrectTypo(Id, LookupOrdinaryName, CurScope, nullptr, Validator,
573 CTK_ErrorRecovery)) {
574 diagnoseTypo(Corrected,
575 PDiag(Lookup.empty()
576 ? diag::err_undeclared_var_use_suggest
577 : diag::err_omp_expected_var_arg_suggest)
578 << Id.getName());
579 VD = Corrected.getCorrectionDeclAs<VarDecl>();
580 } else {
581 Diag(Id.getLoc(), Lookup.empty() ? diag::err_undeclared_var_use
582 : diag::err_omp_expected_var_arg)
583 << Id.getName();
584 return ExprError();
585 }
586 } else {
587 if (!(VD = Lookup.getAsSingle<VarDecl>())) {
588 Diag(Id.getLoc(), diag::err_omp_expected_var_arg) << Id.getName();
589 Diag(Lookup.getFoundDecl()->getLocation(), diag::note_declared_at);
590 return ExprError();
591 }
592 }
593 Lookup.suppressDiagnostics();
594
595 // OpenMP [2.9.2, Syntax, C/C++]
596 // Variables must be file-scope, namespace-scope, or static block-scope.
597 if (!VD->hasGlobalStorage()) {
598 Diag(Id.getLoc(), diag::err_omp_global_var_arg)
599 << getOpenMPDirectiveName(OMPD_threadprivate) << !VD->isStaticLocal();
600 bool IsDecl =
601 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
602 Diag(VD->getLocation(),
603 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
604 << VD;
605 return ExprError();
606 }
607
608 VarDecl *CanonicalVD = VD->getCanonicalDecl();
609 NamedDecl *ND = cast<NamedDecl>(CanonicalVD);
610 // OpenMP [2.9.2, Restrictions, C/C++, p.2]
611 // A threadprivate directive for file-scope variables must appear outside
612 // any definition or declaration.
613 if (CanonicalVD->getDeclContext()->isTranslationUnit() &&
614 !getCurLexicalContext()->isTranslationUnit()) {
615 Diag(Id.getLoc(), diag::err_omp_var_scope)
616 << getOpenMPDirectiveName(OMPD_threadprivate) << VD;
617 bool IsDecl =
618 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
619 Diag(VD->getLocation(),
620 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
621 << VD;
622 return ExprError();
623 }
624 // OpenMP [2.9.2, Restrictions, C/C++, p.3]
625 // A threadprivate directive for static class member variables must appear
626 // in the class definition, in the same scope in which the member
627 // variables are declared.
628 if (CanonicalVD->isStaticDataMember() &&
629 !CanonicalVD->getDeclContext()->Equals(getCurLexicalContext())) {
630 Diag(Id.getLoc(), diag::err_omp_var_scope)
631 << getOpenMPDirectiveName(OMPD_threadprivate) << VD;
632 bool IsDecl =
633 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
634 Diag(VD->getLocation(),
635 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
636 << VD;
637 return ExprError();
638 }
639 // OpenMP [2.9.2, Restrictions, C/C++, p.4]
640 // A threadprivate directive for namespace-scope variables must appear
641 // outside any definition or declaration other than the namespace
642 // definition itself.
643 if (CanonicalVD->getDeclContext()->isNamespace() &&
644 (!getCurLexicalContext()->isFileContext() ||
645 !getCurLexicalContext()->Encloses(CanonicalVD->getDeclContext()))) {
646 Diag(Id.getLoc(), diag::err_omp_var_scope)
647 << getOpenMPDirectiveName(OMPD_threadprivate) << VD;
648 bool IsDecl =
649 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
650 Diag(VD->getLocation(),
651 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
652 << VD;
653 return ExprError();
654 }
655 // OpenMP [2.9.2, Restrictions, C/C++, p.6]
656 // A threadprivate directive for static block-scope variables must appear
657 // in the scope of the variable and not in a nested scope.
658 if (CanonicalVD->isStaticLocal() && CurScope &&
659 !isDeclInScope(ND, getCurLexicalContext(), CurScope)) {
660 Diag(Id.getLoc(), diag::err_omp_var_scope)
661 << getOpenMPDirectiveName(OMPD_threadprivate) << VD;
662 bool IsDecl =
663 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
664 Diag(VD->getLocation(),
665 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
666 << VD;
667 return ExprError();
668 }
669
670 // OpenMP [2.9.2, Restrictions, C/C++, p.2-6]
671 // A threadprivate directive must lexically precede all references to any
672 // of the variables in its list.
673 if (VD->isUsed()) {
674 Diag(Id.getLoc(), diag::err_omp_var_used)
675 << getOpenMPDirectiveName(OMPD_threadprivate) << VD;
676 return ExprError();
677 }
678
679 QualType ExprType = VD->getType().getNonReferenceType();
680 ExprResult DE = BuildDeclRefExpr(VD, ExprType, VK_LValue, Id.getLoc());
681 return DE;
682 }
683
684 Sema::DeclGroupPtrTy
ActOnOpenMPThreadprivateDirective(SourceLocation Loc,ArrayRef<Expr * > VarList)685 Sema::ActOnOpenMPThreadprivateDirective(SourceLocation Loc,
686 ArrayRef<Expr *> VarList) {
687 if (OMPThreadPrivateDecl *D = CheckOMPThreadPrivateDecl(Loc, VarList)) {
688 CurContext->addDecl(D);
689 return DeclGroupPtrTy::make(DeclGroupRef(D));
690 }
691 return DeclGroupPtrTy();
692 }
693
694 namespace {
695 class LocalVarRefChecker : public ConstStmtVisitor<LocalVarRefChecker, bool> {
696 Sema &SemaRef;
697
698 public:
VisitDeclRefExpr(const DeclRefExpr * E)699 bool VisitDeclRefExpr(const DeclRefExpr *E) {
700 if (auto VD = dyn_cast<VarDecl>(E->getDecl())) {
701 if (VD->hasLocalStorage()) {
702 SemaRef.Diag(E->getLocStart(),
703 diag::err_omp_local_var_in_threadprivate_init)
704 << E->getSourceRange();
705 SemaRef.Diag(VD->getLocation(), diag::note_defined_here)
706 << VD << VD->getSourceRange();
707 return true;
708 }
709 }
710 return false;
711 }
VisitStmt(const Stmt * S)712 bool VisitStmt(const Stmt *S) {
713 for (auto Child : S->children()) {
714 if (Child && Visit(Child))
715 return true;
716 }
717 return false;
718 }
LocalVarRefChecker(Sema & SemaRef)719 explicit LocalVarRefChecker(Sema &SemaRef) : SemaRef(SemaRef) {}
720 };
721 } // namespace
722
723 OMPThreadPrivateDecl *
CheckOMPThreadPrivateDecl(SourceLocation Loc,ArrayRef<Expr * > VarList)724 Sema::CheckOMPThreadPrivateDecl(SourceLocation Loc, ArrayRef<Expr *> VarList) {
725 SmallVector<Expr *, 8> Vars;
726 for (auto &RefExpr : VarList) {
727 DeclRefExpr *DE = cast<DeclRefExpr>(RefExpr);
728 VarDecl *VD = cast<VarDecl>(DE->getDecl());
729 SourceLocation ILoc = DE->getExprLoc();
730
731 // OpenMP [2.9.2, Restrictions, C/C++, p.10]
732 // A threadprivate variable must not have an incomplete type.
733 if (RequireCompleteType(ILoc, VD->getType(),
734 diag::err_omp_threadprivate_incomplete_type)) {
735 continue;
736 }
737
738 // OpenMP [2.9.2, Restrictions, C/C++, p.10]
739 // A threadprivate variable must not have a reference type.
740 if (VD->getType()->isReferenceType()) {
741 Diag(ILoc, diag::err_omp_ref_type_arg)
742 << getOpenMPDirectiveName(OMPD_threadprivate) << VD->getType();
743 bool IsDecl =
744 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
745 Diag(VD->getLocation(),
746 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
747 << VD;
748 continue;
749 }
750
751 // Check if this is a TLS variable.
752 if (VD->getTLSKind()) {
753 Diag(ILoc, diag::err_omp_var_thread_local) << VD;
754 bool IsDecl =
755 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
756 Diag(VD->getLocation(),
757 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
758 << VD;
759 continue;
760 }
761
762 // Check if initial value of threadprivate variable reference variable with
763 // local storage (it is not supported by runtime).
764 if (auto Init = VD->getAnyInitializer()) {
765 LocalVarRefChecker Checker(*this);
766 if (Checker.Visit(Init))
767 continue;
768 }
769
770 Vars.push_back(RefExpr);
771 DSAStack->addDSA(VD, DE, OMPC_threadprivate);
772 }
773 OMPThreadPrivateDecl *D = nullptr;
774 if (!Vars.empty()) {
775 D = OMPThreadPrivateDecl::Create(Context, getCurLexicalContext(), Loc,
776 Vars);
777 D->setAccess(AS_public);
778 }
779 return D;
780 }
781
ReportOriginalDSA(Sema & SemaRef,DSAStackTy * Stack,const VarDecl * VD,DSAStackTy::DSAVarData DVar,bool IsLoopIterVar=false)782 static void ReportOriginalDSA(Sema &SemaRef, DSAStackTy *Stack,
783 const VarDecl *VD, DSAStackTy::DSAVarData DVar,
784 bool IsLoopIterVar = false) {
785 if (DVar.RefExpr) {
786 SemaRef.Diag(DVar.RefExpr->getExprLoc(), diag::note_omp_explicit_dsa)
787 << getOpenMPClauseName(DVar.CKind);
788 return;
789 }
790 enum {
791 PDSA_StaticMemberShared,
792 PDSA_StaticLocalVarShared,
793 PDSA_LoopIterVarPrivate,
794 PDSA_LoopIterVarLinear,
795 PDSA_LoopIterVarLastprivate,
796 PDSA_ConstVarShared,
797 PDSA_GlobalVarShared,
798 PDSA_LocalVarPrivate,
799 PDSA_Implicit
800 } Reason = PDSA_Implicit;
801 bool ReportHint = false;
802 if (IsLoopIterVar) {
803 if (DVar.CKind == OMPC_private)
804 Reason = PDSA_LoopIterVarPrivate;
805 else if (DVar.CKind == OMPC_lastprivate)
806 Reason = PDSA_LoopIterVarLastprivate;
807 else
808 Reason = PDSA_LoopIterVarLinear;
809 } else if (VD->isStaticLocal())
810 Reason = PDSA_StaticLocalVarShared;
811 else if (VD->isStaticDataMember())
812 Reason = PDSA_StaticMemberShared;
813 else if (VD->isFileVarDecl())
814 Reason = PDSA_GlobalVarShared;
815 else if (VD->getType().isConstant(SemaRef.getASTContext()))
816 Reason = PDSA_ConstVarShared;
817 else if (VD->isLocalVarDecl() && DVar.CKind == OMPC_private) {
818 ReportHint = true;
819 Reason = PDSA_LocalVarPrivate;
820 }
821 if (Reason != PDSA_Implicit) {
822 SemaRef.Diag(VD->getLocation(), diag::note_omp_predetermined_dsa)
823 << Reason << ReportHint
824 << getOpenMPDirectiveName(Stack->getCurrentDirective());
825 } else if (DVar.ImplicitDSALoc.isValid()) {
826 SemaRef.Diag(DVar.ImplicitDSALoc, diag::note_omp_implicit_dsa)
827 << getOpenMPClauseName(DVar.CKind);
828 }
829 }
830
831 namespace {
832 class DSAAttrChecker : public StmtVisitor<DSAAttrChecker, void> {
833 DSAStackTy *Stack;
834 Sema &SemaRef;
835 bool ErrorFound;
836 CapturedStmt *CS;
837 llvm::SmallVector<Expr *, 8> ImplicitFirstprivate;
838 llvm::DenseMap<VarDecl *, Expr *> VarsWithInheritedDSA;
839
840 public:
VisitDeclRefExpr(DeclRefExpr * E)841 void VisitDeclRefExpr(DeclRefExpr *E) {
842 if (VarDecl *VD = dyn_cast<VarDecl>(E->getDecl())) {
843 // Skip internally declared variables.
844 if (VD->isLocalVarDecl() && !CS->capturesVariable(VD))
845 return;
846
847 SourceLocation ELoc = E->getExprLoc();
848
849 OpenMPDirectiveKind DKind = Stack->getCurrentDirective();
850 DSAStackTy::DSAVarData DVar = Stack->getTopDSA(VD);
851 if (DVar.CKind != OMPC_unknown) {
852 if (DKind == OMPD_task && DVar.CKind != OMPC_shared &&
853 !Stack->isThreadPrivate(VD) && !DVar.RefExpr)
854 ImplicitFirstprivate.push_back(DVar.RefExpr);
855 return;
856 }
857 // The default(none) clause requires that each variable that is referenced
858 // in the construct, and does not have a predetermined data-sharing
859 // attribute, must have its data-sharing attribute explicitly determined
860 // by being listed in a data-sharing attribute clause.
861 if (DVar.CKind == OMPC_unknown && Stack->getDefaultDSA() == DSA_none &&
862 (isOpenMPParallelDirective(DKind) || DKind == OMPD_task) &&
863 VarsWithInheritedDSA.count(VD) == 0) {
864 VarsWithInheritedDSA[VD] = E;
865 return;
866 }
867
868 // OpenMP [2.9.3.6, Restrictions, p.2]
869 // A list item that appears in a reduction clause of the innermost
870 // enclosing worksharing or parallel construct may not be accessed in an
871 // explicit task.
872 DVar = Stack->hasInnermostDSA(VD, MatchesAnyClause(OMPC_reduction),
873 MatchesAlways());
874 if (DKind == OMPD_task && DVar.CKind == OMPC_reduction) {
875 ErrorFound = true;
876 SemaRef.Diag(ELoc, diag::err_omp_reduction_in_task);
877 ReportOriginalDSA(SemaRef, Stack, VD, DVar);
878 return;
879 }
880
881 // Define implicit data-sharing attributes for task.
882 DVar = Stack->getImplicitDSA(VD);
883 if (DKind == OMPD_task && DVar.CKind != OMPC_shared)
884 ImplicitFirstprivate.push_back(DVar.RefExpr);
885 }
886 }
VisitOMPExecutableDirective(OMPExecutableDirective * S)887 void VisitOMPExecutableDirective(OMPExecutableDirective *S) {
888 for (auto C : S->clauses())
889 if (C)
890 for (StmtRange R = C->children(); R; ++R)
891 if (Stmt *Child = *R)
892 Visit(Child);
893 }
VisitStmt(Stmt * S)894 void VisitStmt(Stmt *S) {
895 for (Stmt::child_iterator I = S->child_begin(), E = S->child_end(); I != E;
896 ++I)
897 if (Stmt *Child = *I)
898 if (!isa<OMPExecutableDirective>(Child))
899 Visit(Child);
900 }
901
isErrorFound()902 bool isErrorFound() { return ErrorFound; }
getImplicitFirstprivate()903 ArrayRef<Expr *> getImplicitFirstprivate() { return ImplicitFirstprivate; }
getVarsWithInheritedDSA()904 llvm::DenseMap<VarDecl *, Expr *> &getVarsWithInheritedDSA() {
905 return VarsWithInheritedDSA;
906 }
907
DSAAttrChecker(DSAStackTy * S,Sema & SemaRef,CapturedStmt * CS)908 DSAAttrChecker(DSAStackTy *S, Sema &SemaRef, CapturedStmt *CS)
909 : Stack(S), SemaRef(SemaRef), ErrorFound(false), CS(CS) {}
910 };
911 } // namespace
912
ActOnOpenMPRegionStart(OpenMPDirectiveKind DKind,Scope * CurScope)913 void Sema::ActOnOpenMPRegionStart(OpenMPDirectiveKind DKind, Scope *CurScope) {
914 switch (DKind) {
915 case OMPD_parallel: {
916 QualType KmpInt32Ty = Context.getIntTypeForBitwidth(32, 1);
917 QualType KmpInt32PtrTy = Context.getPointerType(KmpInt32Ty);
918 Sema::CapturedParamNameType Params[] = {
919 std::make_pair(".global_tid.", KmpInt32PtrTy),
920 std::make_pair(".bound_tid.", KmpInt32PtrTy),
921 std::make_pair(StringRef(), QualType()) // __context with shared vars
922 };
923 ActOnCapturedRegionStart(DSAStack->getConstructLoc(), CurScope, CR_OpenMP,
924 Params);
925 break;
926 }
927 case OMPD_simd: {
928 Sema::CapturedParamNameType Params[] = {
929 std::make_pair(StringRef(), QualType()) // __context with shared vars
930 };
931 ActOnCapturedRegionStart(DSAStack->getConstructLoc(), CurScope, CR_OpenMP,
932 Params);
933 break;
934 }
935 case OMPD_for: {
936 Sema::CapturedParamNameType Params[] = {
937 std::make_pair(StringRef(), QualType()) // __context with shared vars
938 };
939 ActOnCapturedRegionStart(DSAStack->getConstructLoc(), CurScope, CR_OpenMP,
940 Params);
941 break;
942 }
943 case OMPD_sections: {
944 Sema::CapturedParamNameType Params[] = {
945 std::make_pair(StringRef(), QualType()) // __context with shared vars
946 };
947 ActOnCapturedRegionStart(DSAStack->getConstructLoc(), CurScope, CR_OpenMP,
948 Params);
949 break;
950 }
951 case OMPD_section: {
952 Sema::CapturedParamNameType Params[] = {
953 std::make_pair(StringRef(), QualType()) // __context with shared vars
954 };
955 ActOnCapturedRegionStart(DSAStack->getConstructLoc(), CurScope, CR_OpenMP,
956 Params);
957 break;
958 }
959 case OMPD_single: {
960 Sema::CapturedParamNameType Params[] = {
961 std::make_pair(StringRef(), QualType()) // __context with shared vars
962 };
963 ActOnCapturedRegionStart(DSAStack->getConstructLoc(), CurScope, CR_OpenMP,
964 Params);
965 break;
966 }
967 case OMPD_parallel_for: {
968 QualType KmpInt32Ty = Context.getIntTypeForBitwidth(32, 1);
969 QualType KmpInt32PtrTy = Context.getPointerType(KmpInt32Ty);
970 Sema::CapturedParamNameType Params[] = {
971 std::make_pair(".global_tid.", KmpInt32PtrTy),
972 std::make_pair(".bound_tid.", KmpInt32PtrTy),
973 std::make_pair(StringRef(), QualType()) // __context with shared vars
974 };
975 ActOnCapturedRegionStart(DSAStack->getConstructLoc(), CurScope, CR_OpenMP,
976 Params);
977 break;
978 }
979 case OMPD_parallel_sections: {
980 Sema::CapturedParamNameType Params[] = {
981 std::make_pair(StringRef(), QualType()) // __context with shared vars
982 };
983 ActOnCapturedRegionStart(DSAStack->getConstructLoc(), CurScope, CR_OpenMP,
984 Params);
985 break;
986 }
987 case OMPD_threadprivate:
988 case OMPD_task:
989 llvm_unreachable("OpenMP Directive is not allowed");
990 case OMPD_unknown:
991 llvm_unreachable("Unknown OpenMP directive");
992 }
993 }
994
CheckNestingOfRegions(Sema & SemaRef,DSAStackTy * Stack,OpenMPDirectiveKind CurrentRegion,SourceLocation StartLoc)995 bool CheckNestingOfRegions(Sema &SemaRef, DSAStackTy *Stack,
996 OpenMPDirectiveKind CurrentRegion,
997 SourceLocation StartLoc) {
998 // Allowed nesting of constructs
999 // +------------------+-----------------+------------------------------------+
1000 // | Parent directive | Child directive | Closely (!), No-Closely(+), Both(*)|
1001 // +------------------+-----------------+------------------------------------+
1002 // | parallel | parallel | * |
1003 // | parallel | for | * |
1004 // | parallel | simd | * |
1005 // | parallel | sections | * |
1006 // | parallel | section | + |
1007 // | parallel | single | * |
1008 // | parallel | parallel for | * |
1009 // | parallel |parallel sections| * |
1010 // +------------------+-----------------+------------------------------------+
1011 // | for | parallel | * |
1012 // | for | for | + |
1013 // | for | simd | * |
1014 // | for | sections | + |
1015 // | for | section | + |
1016 // | for | single | + |
1017 // | for | parallel for | * |
1018 // | for |parallel sections| * |
1019 // +------------------+-----------------+------------------------------------+
1020 // | simd | parallel | |
1021 // | simd | for | |
1022 // | simd | simd | |
1023 // | simd | sections | |
1024 // | simd | section | |
1025 // | simd | single | |
1026 // | simd | parallel for | |
1027 // | simd |parallel sections| |
1028 // +------------------+-----------------+------------------------------------+
1029 // | sections | parallel | * |
1030 // | sections | for | + |
1031 // | sections | simd | * |
1032 // | sections | sections | + |
1033 // | sections | section | * |
1034 // | sections | single | + |
1035 // | sections | parallel for | * |
1036 // | sections |parallel sections| * |
1037 // +------------------+-----------------+------------------------------------+
1038 // | section | parallel | * |
1039 // | section | for | + |
1040 // | section | simd | * |
1041 // | section | sections | + |
1042 // | section | section | + |
1043 // | section | single | + |
1044 // | section | parallel for | * |
1045 // | section |parallel sections| * |
1046 // +------------------+-----------------+------------------------------------+
1047 // | single | parallel | * |
1048 // | single | for | + |
1049 // | single | simd | * |
1050 // | single | sections | + |
1051 // | single | section | + |
1052 // | single | single | + |
1053 // | single | parallel for | * |
1054 // | single |parallel sections| * |
1055 // +------------------+-----------------+------------------------------------+
1056 // | parallel for | parallel | * |
1057 // | parallel for | for | + |
1058 // | parallel for | simd | * |
1059 // | parallel for | sections | + |
1060 // | parallel for | section | + |
1061 // | parallel for | single | + |
1062 // | parallel for | parallel for | * |
1063 // | parallel for |parallel sections| * |
1064 // +------------------+-----------------+------------------------------------+
1065 // | parallel sections| parallel | * |
1066 // | parallel sections| for | + |
1067 // | parallel sections| simd | * |
1068 // | parallel sections| sections | + |
1069 // | parallel sections| section | * |
1070 // | parallel sections| single | + |
1071 // | parallel sections| parallel for | * |
1072 // | parallel sections|parallel sections| * |
1073 // +------------------+-----------------+------------------------------------+
1074 if (Stack->getCurScope()) {
1075 auto ParentRegion = Stack->getParentDirective();
1076 bool NestingProhibited = false;
1077 bool CloseNesting = true;
1078 bool ShouldBeInParallelRegion = false;
1079 if (isOpenMPSimdDirective(ParentRegion)) {
1080 // OpenMP [2.16, Nesting of Regions]
1081 // OpenMP constructs may not be nested inside a simd region.
1082 SemaRef.Diag(StartLoc, diag::err_omp_prohibited_region_simd);
1083 return true;
1084 }
1085 if (CurrentRegion == OMPD_section) {
1086 // OpenMP [2.7.2, sections Construct, Restrictions]
1087 // Orphaned section directives are prohibited. That is, the section
1088 // directives must appear within the sections construct and must not be
1089 // encountered elsewhere in the sections region.
1090 if (ParentRegion != OMPD_sections &&
1091 ParentRegion != OMPD_parallel_sections) {
1092 SemaRef.Diag(StartLoc, diag::err_omp_orphaned_section_directive)
1093 << (ParentRegion != OMPD_unknown)
1094 << getOpenMPDirectiveName(ParentRegion);
1095 return true;
1096 }
1097 return false;
1098 }
1099 if (isOpenMPWorksharingDirective(CurrentRegion) &&
1100 !isOpenMPParallelDirective(CurrentRegion) &&
1101 !isOpenMPSimdDirective(CurrentRegion)) {
1102 // OpenMP [2.16, Nesting of Regions]
1103 // A worksharing region may not be closely nested inside a worksharing,
1104 // explicit task, critical, ordered, atomic, or master region.
1105 // TODO
1106 NestingProhibited = isOpenMPWorksharingDirective(ParentRegion) &&
1107 !isOpenMPSimdDirective(ParentRegion);
1108 ShouldBeInParallelRegion = true;
1109 }
1110 if (NestingProhibited) {
1111 SemaRef.Diag(StartLoc, diag::err_omp_prohibited_region)
1112 << CloseNesting << getOpenMPDirectiveName(ParentRegion)
1113 << ShouldBeInParallelRegion << getOpenMPDirectiveName(CurrentRegion);
1114 return true;
1115 }
1116 }
1117 return false;
1118 }
1119
ActOnOpenMPExecutableDirective(OpenMPDirectiveKind Kind,ArrayRef<OMPClause * > Clauses,Stmt * AStmt,SourceLocation StartLoc,SourceLocation EndLoc)1120 StmtResult Sema::ActOnOpenMPExecutableDirective(OpenMPDirectiveKind Kind,
1121 ArrayRef<OMPClause *> Clauses,
1122 Stmt *AStmt,
1123 SourceLocation StartLoc,
1124 SourceLocation EndLoc) {
1125 assert(AStmt && isa<CapturedStmt>(AStmt) && "Captured statement expected");
1126
1127 StmtResult Res = StmtError();
1128 if (CheckNestingOfRegions(*this, DSAStack, Kind, StartLoc))
1129 return StmtError();
1130
1131 // Check default data sharing attributes for referenced variables.
1132 DSAAttrChecker DSAChecker(DSAStack, *this, cast<CapturedStmt>(AStmt));
1133 DSAChecker.Visit(cast<CapturedStmt>(AStmt)->getCapturedStmt());
1134 if (DSAChecker.isErrorFound())
1135 return StmtError();
1136 // Generate list of implicitly defined firstprivate variables.
1137 auto &VarsWithInheritedDSA = DSAChecker.getVarsWithInheritedDSA();
1138 llvm::SmallVector<OMPClause *, 8> ClausesWithImplicit;
1139 ClausesWithImplicit.append(Clauses.begin(), Clauses.end());
1140
1141 bool ErrorFound = false;
1142 if (!DSAChecker.getImplicitFirstprivate().empty()) {
1143 if (OMPClause *Implicit = ActOnOpenMPFirstprivateClause(
1144 DSAChecker.getImplicitFirstprivate(), SourceLocation(),
1145 SourceLocation(), SourceLocation())) {
1146 ClausesWithImplicit.push_back(Implicit);
1147 ErrorFound = cast<OMPFirstprivateClause>(Implicit)->varlist_size() !=
1148 DSAChecker.getImplicitFirstprivate().size();
1149 } else
1150 ErrorFound = true;
1151 }
1152
1153 switch (Kind) {
1154 case OMPD_parallel:
1155 Res = ActOnOpenMPParallelDirective(ClausesWithImplicit, AStmt, StartLoc,
1156 EndLoc);
1157 break;
1158 case OMPD_simd:
1159 Res = ActOnOpenMPSimdDirective(ClausesWithImplicit, AStmt, StartLoc, EndLoc,
1160 VarsWithInheritedDSA);
1161 break;
1162 case OMPD_for:
1163 Res = ActOnOpenMPForDirective(ClausesWithImplicit, AStmt, StartLoc, EndLoc,
1164 VarsWithInheritedDSA);
1165 break;
1166 case OMPD_sections:
1167 Res = ActOnOpenMPSectionsDirective(ClausesWithImplicit, AStmt, StartLoc,
1168 EndLoc);
1169 break;
1170 case OMPD_section:
1171 assert(ClausesWithImplicit.empty() &&
1172 "No clauses is allowed for 'omp section' directive");
1173 Res = ActOnOpenMPSectionDirective(AStmt, StartLoc, EndLoc);
1174 break;
1175 case OMPD_single:
1176 Res = ActOnOpenMPSingleDirective(ClausesWithImplicit, AStmt, StartLoc,
1177 EndLoc);
1178 break;
1179 case OMPD_parallel_for:
1180 Res = ActOnOpenMPParallelForDirective(ClausesWithImplicit, AStmt, StartLoc,
1181 EndLoc, VarsWithInheritedDSA);
1182 break;
1183 case OMPD_parallel_sections:
1184 Res = ActOnOpenMPParallelSectionsDirective(ClausesWithImplicit, AStmt,
1185 StartLoc, EndLoc);
1186 break;
1187 case OMPD_threadprivate:
1188 case OMPD_task:
1189 llvm_unreachable("OpenMP Directive is not allowed");
1190 case OMPD_unknown:
1191 llvm_unreachable("Unknown OpenMP directive");
1192 }
1193
1194 for (auto P : VarsWithInheritedDSA) {
1195 Diag(P.second->getExprLoc(), diag::err_omp_no_dsa_for_variable)
1196 << P.first << P.second->getSourceRange();
1197 }
1198 if (!VarsWithInheritedDSA.empty())
1199 return StmtError();
1200
1201 if (ErrorFound)
1202 return StmtError();
1203 return Res;
1204 }
1205
ActOnOpenMPParallelDirective(ArrayRef<OMPClause * > Clauses,Stmt * AStmt,SourceLocation StartLoc,SourceLocation EndLoc)1206 StmtResult Sema::ActOnOpenMPParallelDirective(ArrayRef<OMPClause *> Clauses,
1207 Stmt *AStmt,
1208 SourceLocation StartLoc,
1209 SourceLocation EndLoc) {
1210 assert(AStmt && isa<CapturedStmt>(AStmt) && "Captured statement expected");
1211 CapturedStmt *CS = cast<CapturedStmt>(AStmt);
1212 // 1.2.2 OpenMP Language Terminology
1213 // Structured block - An executable statement with a single entry at the
1214 // top and a single exit at the bottom.
1215 // The point of exit cannot be a branch out of the structured block.
1216 // longjmp() and throw() must not violate the entry/exit criteria.
1217 CS->getCapturedDecl()->setNothrow();
1218
1219 getCurFunction()->setHasBranchProtectedScope();
1220
1221 return OMPParallelDirective::Create(Context, StartLoc, EndLoc, Clauses,
1222 AStmt);
1223 }
1224
1225 namespace {
1226 /// \brief Helper class for checking canonical form of the OpenMP loops and
1227 /// extracting iteration space of each loop in the loop nest, that will be used
1228 /// for IR generation.
1229 class OpenMPIterationSpaceChecker {
1230 /// \brief Reference to Sema.
1231 Sema &SemaRef;
1232 /// \brief A location for diagnostics (when there is no some better location).
1233 SourceLocation DefaultLoc;
1234 /// \brief A location for diagnostics (when increment is not compatible).
1235 SourceLocation ConditionLoc;
1236 /// \brief A source location for referring to condition later.
1237 SourceRange ConditionSrcRange;
1238 /// \brief Loop variable.
1239 VarDecl *Var;
1240 /// \brief Lower bound (initializer for the var).
1241 Expr *LB;
1242 /// \brief Upper bound.
1243 Expr *UB;
1244 /// \brief Loop step (increment).
1245 Expr *Step;
1246 /// \brief This flag is true when condition is one of:
1247 /// Var < UB
1248 /// Var <= UB
1249 /// UB > Var
1250 /// UB >= Var
1251 bool TestIsLessOp;
1252 /// \brief This flag is true when condition is strict ( < or > ).
1253 bool TestIsStrictOp;
1254 /// \brief This flag is true when step is subtracted on each iteration.
1255 bool SubtractStep;
1256
1257 public:
OpenMPIterationSpaceChecker(Sema & SemaRef,SourceLocation DefaultLoc)1258 OpenMPIterationSpaceChecker(Sema &SemaRef, SourceLocation DefaultLoc)
1259 : SemaRef(SemaRef), DefaultLoc(DefaultLoc), ConditionLoc(DefaultLoc),
1260 ConditionSrcRange(SourceRange()), Var(nullptr), LB(nullptr),
1261 UB(nullptr), Step(nullptr), TestIsLessOp(false), TestIsStrictOp(false),
1262 SubtractStep(false) {}
1263 /// \brief Check init-expr for canonical loop form and save loop counter
1264 /// variable - #Var and its initialization value - #LB.
1265 bool CheckInit(Stmt *S);
1266 /// \brief Check test-expr for canonical form, save upper-bound (#UB), flags
1267 /// for less/greater and for strict/non-strict comparison.
1268 bool CheckCond(Expr *S);
1269 /// \brief Check incr-expr for canonical loop form and return true if it
1270 /// does not conform, otherwise save loop step (#Step).
1271 bool CheckInc(Expr *S);
1272 /// \brief Return the loop counter variable.
GetLoopVar() const1273 VarDecl *GetLoopVar() const { return Var; }
1274 /// \brief Return true if any expression is dependent.
1275 bool Dependent() const;
1276
1277 private:
1278 /// \brief Check the right-hand side of an assignment in the increment
1279 /// expression.
1280 bool CheckIncRHS(Expr *RHS);
1281 /// \brief Helper to set loop counter variable and its initializer.
1282 bool SetVarAndLB(VarDecl *NewVar, Expr *NewLB);
1283 /// \brief Helper to set upper bound.
1284 bool SetUB(Expr *NewUB, bool LessOp, bool StrictOp, const SourceRange &SR,
1285 const SourceLocation &SL);
1286 /// \brief Helper to set loop increment.
1287 bool SetStep(Expr *NewStep, bool Subtract);
1288 };
1289
Dependent() const1290 bool OpenMPIterationSpaceChecker::Dependent() const {
1291 if (!Var) {
1292 assert(!LB && !UB && !Step);
1293 return false;
1294 }
1295 return Var->getType()->isDependentType() || (LB && LB->isValueDependent()) ||
1296 (UB && UB->isValueDependent()) || (Step && Step->isValueDependent());
1297 }
1298
SetVarAndLB(VarDecl * NewVar,Expr * NewLB)1299 bool OpenMPIterationSpaceChecker::SetVarAndLB(VarDecl *NewVar, Expr *NewLB) {
1300 // State consistency checking to ensure correct usage.
1301 assert(Var == nullptr && LB == nullptr && UB == nullptr && Step == nullptr &&
1302 !TestIsLessOp && !TestIsStrictOp);
1303 if (!NewVar || !NewLB)
1304 return true;
1305 Var = NewVar;
1306 LB = NewLB;
1307 return false;
1308 }
1309
SetUB(Expr * NewUB,bool LessOp,bool StrictOp,const SourceRange & SR,const SourceLocation & SL)1310 bool OpenMPIterationSpaceChecker::SetUB(Expr *NewUB, bool LessOp, bool StrictOp,
1311 const SourceRange &SR,
1312 const SourceLocation &SL) {
1313 // State consistency checking to ensure correct usage.
1314 assert(Var != nullptr && LB != nullptr && UB == nullptr && Step == nullptr &&
1315 !TestIsLessOp && !TestIsStrictOp);
1316 if (!NewUB)
1317 return true;
1318 UB = NewUB;
1319 TestIsLessOp = LessOp;
1320 TestIsStrictOp = StrictOp;
1321 ConditionSrcRange = SR;
1322 ConditionLoc = SL;
1323 return false;
1324 }
1325
SetStep(Expr * NewStep,bool Subtract)1326 bool OpenMPIterationSpaceChecker::SetStep(Expr *NewStep, bool Subtract) {
1327 // State consistency checking to ensure correct usage.
1328 assert(Var != nullptr && LB != nullptr && Step == nullptr);
1329 if (!NewStep)
1330 return true;
1331 if (!NewStep->isValueDependent()) {
1332 // Check that the step is integer expression.
1333 SourceLocation StepLoc = NewStep->getLocStart();
1334 ExprResult Val =
1335 SemaRef.PerformOpenMPImplicitIntegerConversion(StepLoc, NewStep);
1336 if (Val.isInvalid())
1337 return true;
1338 NewStep = Val.get();
1339
1340 // OpenMP [2.6, Canonical Loop Form, Restrictions]
1341 // If test-expr is of form var relational-op b and relational-op is < or
1342 // <= then incr-expr must cause var to increase on each iteration of the
1343 // loop. If test-expr is of form var relational-op b and relational-op is
1344 // > or >= then incr-expr must cause var to decrease on each iteration of
1345 // the loop.
1346 // If test-expr is of form b relational-op var and relational-op is < or
1347 // <= then incr-expr must cause var to decrease on each iteration of the
1348 // loop. If test-expr is of form b relational-op var and relational-op is
1349 // > or >= then incr-expr must cause var to increase on each iteration of
1350 // the loop.
1351 llvm::APSInt Result;
1352 bool IsConstant = NewStep->isIntegerConstantExpr(Result, SemaRef.Context);
1353 bool IsUnsigned = !NewStep->getType()->hasSignedIntegerRepresentation();
1354 bool IsConstNeg =
1355 IsConstant && Result.isSigned() && (Subtract != Result.isNegative());
1356 bool IsConstZero = IsConstant && !Result.getBoolValue();
1357 if (UB && (IsConstZero ||
1358 (TestIsLessOp ? (IsConstNeg || (IsUnsigned && Subtract))
1359 : (!IsConstNeg || (IsUnsigned && !Subtract))))) {
1360 SemaRef.Diag(NewStep->getExprLoc(),
1361 diag::err_omp_loop_incr_not_compatible)
1362 << Var << TestIsLessOp << NewStep->getSourceRange();
1363 SemaRef.Diag(ConditionLoc,
1364 diag::note_omp_loop_cond_requres_compatible_incr)
1365 << TestIsLessOp << ConditionSrcRange;
1366 return true;
1367 }
1368 }
1369
1370 Step = NewStep;
1371 SubtractStep = Subtract;
1372 return false;
1373 }
1374
CheckInit(Stmt * S)1375 bool OpenMPIterationSpaceChecker::CheckInit(Stmt *S) {
1376 // Check init-expr for canonical loop form and save loop counter
1377 // variable - #Var and its initialization value - #LB.
1378 // OpenMP [2.6] Canonical loop form. init-expr may be one of the following:
1379 // var = lb
1380 // integer-type var = lb
1381 // random-access-iterator-type var = lb
1382 // pointer-type var = lb
1383 //
1384 if (!S) {
1385 SemaRef.Diag(DefaultLoc, diag::err_omp_loop_not_canonical_init);
1386 return true;
1387 }
1388 if (Expr *E = dyn_cast<Expr>(S))
1389 S = E->IgnoreParens();
1390 if (auto BO = dyn_cast<BinaryOperator>(S)) {
1391 if (BO->getOpcode() == BO_Assign)
1392 if (auto DRE = dyn_cast<DeclRefExpr>(BO->getLHS()->IgnoreParens()))
1393 return SetVarAndLB(dyn_cast<VarDecl>(DRE->getDecl()), BO->getLHS());
1394 } else if (auto DS = dyn_cast<DeclStmt>(S)) {
1395 if (DS->isSingleDecl()) {
1396 if (auto Var = dyn_cast_or_null<VarDecl>(DS->getSingleDecl())) {
1397 if (Var->hasInit()) {
1398 // Accept non-canonical init form here but emit ext. warning.
1399 if (Var->getInitStyle() != VarDecl::CInit)
1400 SemaRef.Diag(S->getLocStart(),
1401 diag::ext_omp_loop_not_canonical_init)
1402 << S->getSourceRange();
1403 return SetVarAndLB(Var, Var->getInit());
1404 }
1405 }
1406 }
1407 } else if (auto CE = dyn_cast<CXXOperatorCallExpr>(S))
1408 if (CE->getOperator() == OO_Equal)
1409 if (auto DRE = dyn_cast<DeclRefExpr>(CE->getArg(0)))
1410 return SetVarAndLB(dyn_cast<VarDecl>(DRE->getDecl()), CE->getArg(1));
1411
1412 SemaRef.Diag(S->getLocStart(), diag::err_omp_loop_not_canonical_init)
1413 << S->getSourceRange();
1414 return true;
1415 }
1416
1417 /// \brief Ignore parenthesizes, implicit casts, copy constructor and return the
1418 /// variable (which may be the loop variable) if possible.
GetInitVarDecl(const Expr * E)1419 static const VarDecl *GetInitVarDecl(const Expr *E) {
1420 if (!E)
1421 return nullptr;
1422 E = E->IgnoreParenImpCasts();
1423 if (auto *CE = dyn_cast_or_null<CXXConstructExpr>(E))
1424 if (const CXXConstructorDecl *Ctor = CE->getConstructor())
1425 if (Ctor->isCopyConstructor() && CE->getNumArgs() == 1 &&
1426 CE->getArg(0) != nullptr)
1427 E = CE->getArg(0)->IgnoreParenImpCasts();
1428 auto DRE = dyn_cast_or_null<DeclRefExpr>(E);
1429 if (!DRE)
1430 return nullptr;
1431 return dyn_cast<VarDecl>(DRE->getDecl());
1432 }
1433
CheckCond(Expr * S)1434 bool OpenMPIterationSpaceChecker::CheckCond(Expr *S) {
1435 // Check test-expr for canonical form, save upper-bound UB, flags for
1436 // less/greater and for strict/non-strict comparison.
1437 // OpenMP [2.6] Canonical loop form. Test-expr may be one of the following:
1438 // var relational-op b
1439 // b relational-op var
1440 //
1441 if (!S) {
1442 SemaRef.Diag(DefaultLoc, diag::err_omp_loop_not_canonical_cond) << Var;
1443 return true;
1444 }
1445 S = S->IgnoreParenImpCasts();
1446 SourceLocation CondLoc = S->getLocStart();
1447 if (auto BO = dyn_cast<BinaryOperator>(S)) {
1448 if (BO->isRelationalOp()) {
1449 if (GetInitVarDecl(BO->getLHS()) == Var)
1450 return SetUB(BO->getRHS(),
1451 (BO->getOpcode() == BO_LT || BO->getOpcode() == BO_LE),
1452 (BO->getOpcode() == BO_LT || BO->getOpcode() == BO_GT),
1453 BO->getSourceRange(), BO->getOperatorLoc());
1454 if (GetInitVarDecl(BO->getRHS()) == Var)
1455 return SetUB(BO->getLHS(),
1456 (BO->getOpcode() == BO_GT || BO->getOpcode() == BO_GE),
1457 (BO->getOpcode() == BO_LT || BO->getOpcode() == BO_GT),
1458 BO->getSourceRange(), BO->getOperatorLoc());
1459 }
1460 } else if (auto CE = dyn_cast<CXXOperatorCallExpr>(S)) {
1461 if (CE->getNumArgs() == 2) {
1462 auto Op = CE->getOperator();
1463 switch (Op) {
1464 case OO_Greater:
1465 case OO_GreaterEqual:
1466 case OO_Less:
1467 case OO_LessEqual:
1468 if (GetInitVarDecl(CE->getArg(0)) == Var)
1469 return SetUB(CE->getArg(1), Op == OO_Less || Op == OO_LessEqual,
1470 Op == OO_Less || Op == OO_Greater, CE->getSourceRange(),
1471 CE->getOperatorLoc());
1472 if (GetInitVarDecl(CE->getArg(1)) == Var)
1473 return SetUB(CE->getArg(0), Op == OO_Greater || Op == OO_GreaterEqual,
1474 Op == OO_Less || Op == OO_Greater, CE->getSourceRange(),
1475 CE->getOperatorLoc());
1476 break;
1477 default:
1478 break;
1479 }
1480 }
1481 }
1482 SemaRef.Diag(CondLoc, diag::err_omp_loop_not_canonical_cond)
1483 << S->getSourceRange() << Var;
1484 return true;
1485 }
1486
CheckIncRHS(Expr * RHS)1487 bool OpenMPIterationSpaceChecker::CheckIncRHS(Expr *RHS) {
1488 // RHS of canonical loop form increment can be:
1489 // var + incr
1490 // incr + var
1491 // var - incr
1492 //
1493 RHS = RHS->IgnoreParenImpCasts();
1494 if (auto BO = dyn_cast<BinaryOperator>(RHS)) {
1495 if (BO->isAdditiveOp()) {
1496 bool IsAdd = BO->getOpcode() == BO_Add;
1497 if (GetInitVarDecl(BO->getLHS()) == Var)
1498 return SetStep(BO->getRHS(), !IsAdd);
1499 if (IsAdd && GetInitVarDecl(BO->getRHS()) == Var)
1500 return SetStep(BO->getLHS(), false);
1501 }
1502 } else if (auto CE = dyn_cast<CXXOperatorCallExpr>(RHS)) {
1503 bool IsAdd = CE->getOperator() == OO_Plus;
1504 if ((IsAdd || CE->getOperator() == OO_Minus) && CE->getNumArgs() == 2) {
1505 if (GetInitVarDecl(CE->getArg(0)) == Var)
1506 return SetStep(CE->getArg(1), !IsAdd);
1507 if (IsAdd && GetInitVarDecl(CE->getArg(1)) == Var)
1508 return SetStep(CE->getArg(0), false);
1509 }
1510 }
1511 SemaRef.Diag(RHS->getLocStart(), diag::err_omp_loop_not_canonical_incr)
1512 << RHS->getSourceRange() << Var;
1513 return true;
1514 }
1515
CheckInc(Expr * S)1516 bool OpenMPIterationSpaceChecker::CheckInc(Expr *S) {
1517 // Check incr-expr for canonical loop form and return true if it
1518 // does not conform.
1519 // OpenMP [2.6] Canonical loop form. Test-expr may be one of the following:
1520 // ++var
1521 // var++
1522 // --var
1523 // var--
1524 // var += incr
1525 // var -= incr
1526 // var = var + incr
1527 // var = incr + var
1528 // var = var - incr
1529 //
1530 if (!S) {
1531 SemaRef.Diag(DefaultLoc, diag::err_omp_loop_not_canonical_incr) << Var;
1532 return true;
1533 }
1534 S = S->IgnoreParens();
1535 if (auto UO = dyn_cast<UnaryOperator>(S)) {
1536 if (UO->isIncrementDecrementOp() && GetInitVarDecl(UO->getSubExpr()) == Var)
1537 return SetStep(
1538 SemaRef.ActOnIntegerConstant(UO->getLocStart(),
1539 (UO->isDecrementOp() ? -1 : 1)).get(),
1540 false);
1541 } else if (auto BO = dyn_cast<BinaryOperator>(S)) {
1542 switch (BO->getOpcode()) {
1543 case BO_AddAssign:
1544 case BO_SubAssign:
1545 if (GetInitVarDecl(BO->getLHS()) == Var)
1546 return SetStep(BO->getRHS(), BO->getOpcode() == BO_SubAssign);
1547 break;
1548 case BO_Assign:
1549 if (GetInitVarDecl(BO->getLHS()) == Var)
1550 return CheckIncRHS(BO->getRHS());
1551 break;
1552 default:
1553 break;
1554 }
1555 } else if (auto CE = dyn_cast<CXXOperatorCallExpr>(S)) {
1556 switch (CE->getOperator()) {
1557 case OO_PlusPlus:
1558 case OO_MinusMinus:
1559 if (GetInitVarDecl(CE->getArg(0)) == Var)
1560 return SetStep(
1561 SemaRef.ActOnIntegerConstant(
1562 CE->getLocStart(),
1563 ((CE->getOperator() == OO_MinusMinus) ? -1 : 1)).get(),
1564 false);
1565 break;
1566 case OO_PlusEqual:
1567 case OO_MinusEqual:
1568 if (GetInitVarDecl(CE->getArg(0)) == Var)
1569 return SetStep(CE->getArg(1), CE->getOperator() == OO_MinusEqual);
1570 break;
1571 case OO_Equal:
1572 if (GetInitVarDecl(CE->getArg(0)) == Var)
1573 return CheckIncRHS(CE->getArg(1));
1574 break;
1575 default:
1576 break;
1577 }
1578 }
1579 SemaRef.Diag(S->getLocStart(), diag::err_omp_loop_not_canonical_incr)
1580 << S->getSourceRange() << Var;
1581 return true;
1582 }
1583 } // namespace
1584
1585 /// \brief Called on a for stmt to check and extract its iteration space
1586 /// for further processing (such as collapsing).
CheckOpenMPIterationSpace(OpenMPDirectiveKind DKind,Stmt * S,Sema & SemaRef,DSAStackTy & DSA,unsigned CurrentNestedLoopCount,unsigned NestedLoopCount,Expr * NestedLoopCountExpr,llvm::DenseMap<VarDecl *,Expr * > & VarsWithImplicitDSA)1587 static bool CheckOpenMPIterationSpace(
1588 OpenMPDirectiveKind DKind, Stmt *S, Sema &SemaRef, DSAStackTy &DSA,
1589 unsigned CurrentNestedLoopCount, unsigned NestedLoopCount,
1590 Expr *NestedLoopCountExpr,
1591 llvm::DenseMap<VarDecl *, Expr *> &VarsWithImplicitDSA) {
1592 // OpenMP [2.6, Canonical Loop Form]
1593 // for (init-expr; test-expr; incr-expr) structured-block
1594 auto For = dyn_cast_or_null<ForStmt>(S);
1595 if (!For) {
1596 SemaRef.Diag(S->getLocStart(), diag::err_omp_not_for)
1597 << (NestedLoopCountExpr != nullptr) << getOpenMPDirectiveName(DKind)
1598 << NestedLoopCount << (CurrentNestedLoopCount > 0)
1599 << CurrentNestedLoopCount;
1600 if (NestedLoopCount > 1)
1601 SemaRef.Diag(NestedLoopCountExpr->getExprLoc(),
1602 diag::note_omp_collapse_expr)
1603 << NestedLoopCountExpr->getSourceRange();
1604 return true;
1605 }
1606 assert(For->getBody());
1607
1608 OpenMPIterationSpaceChecker ISC(SemaRef, For->getForLoc());
1609
1610 // Check init.
1611 auto Init = For->getInit();
1612 if (ISC.CheckInit(Init)) {
1613 return true;
1614 }
1615
1616 bool HasErrors = false;
1617
1618 // Check loop variable's type.
1619 auto Var = ISC.GetLoopVar();
1620
1621 // OpenMP [2.6, Canonical Loop Form]
1622 // Var is one of the following:
1623 // A variable of signed or unsigned integer type.
1624 // For C++, a variable of a random access iterator type.
1625 // For C, a variable of a pointer type.
1626 auto VarType = Var->getType();
1627 if (!VarType->isDependentType() && !VarType->isIntegerType() &&
1628 !VarType->isPointerType() &&
1629 !(SemaRef.getLangOpts().CPlusPlus && VarType->isOverloadableType())) {
1630 SemaRef.Diag(Init->getLocStart(), diag::err_omp_loop_variable_type)
1631 << SemaRef.getLangOpts().CPlusPlus;
1632 HasErrors = true;
1633 }
1634
1635 // OpenMP, 2.14.1.1 Data-sharing Attribute Rules for Variables Referenced in a
1636 // Construct
1637 // The loop iteration variable(s) in the associated for-loop(s) of a for or
1638 // parallel for construct is (are) private.
1639 // The loop iteration variable in the associated for-loop of a simd construct
1640 // with just one associated for-loop is linear with a constant-linear-step
1641 // that is the increment of the associated for-loop.
1642 // Exclude loop var from the list of variables with implicitly defined data
1643 // sharing attributes.
1644 while (VarsWithImplicitDSA.count(Var) > 0)
1645 VarsWithImplicitDSA.erase(Var);
1646
1647 // OpenMP [2.14.1.1, Data-sharing Attribute Rules for Variables Referenced in
1648 // a Construct, C/C++].
1649 // The loop iteration variable in the associated for-loop of a simd construct
1650 // with just one associated for-loop may be listed in a linear clause with a
1651 // constant-linear-step that is the increment of the associated for-loop.
1652 // The loop iteration variable(s) in the associated for-loop(s) of a for or
1653 // parallel for construct may be listed in a private or lastprivate clause.
1654 DSAStackTy::DSAVarData DVar = DSA.getTopDSA(Var);
1655 auto PredeterminedCKind =
1656 isOpenMPSimdDirective(DKind)
1657 ? ((NestedLoopCount == 1) ? OMPC_linear : OMPC_lastprivate)
1658 : OMPC_private;
1659 if (((isOpenMPSimdDirective(DKind) && DVar.CKind != OMPC_unknown &&
1660 DVar.CKind != PredeterminedCKind) ||
1661 (isOpenMPWorksharingDirective(DKind) && DVar.CKind != OMPC_unknown &&
1662 DVar.CKind != OMPC_private && DVar.CKind != OMPC_lastprivate)) &&
1663 (DVar.CKind != OMPC_private || DVar.RefExpr != nullptr)) {
1664 SemaRef.Diag(Init->getLocStart(), diag::err_omp_loop_var_dsa)
1665 << getOpenMPClauseName(DVar.CKind) << getOpenMPDirectiveName(DKind)
1666 << getOpenMPClauseName(PredeterminedCKind);
1667 ReportOriginalDSA(SemaRef, &DSA, Var, DVar, true);
1668 HasErrors = true;
1669 } else {
1670 // Make the loop iteration variable private (for worksharing constructs),
1671 // linear (for simd directives with the only one associated loop) or
1672 // lastprivate (for simd directives with several collapsed loops).
1673 DSA.addDSA(Var, nullptr, PredeterminedCKind);
1674 }
1675
1676 assert(isOpenMPLoopDirective(DKind) && "DSA for non-loop vars");
1677
1678 // Check test-expr.
1679 HasErrors |= ISC.CheckCond(For->getCond());
1680
1681 // Check incr-expr.
1682 HasErrors |= ISC.CheckInc(For->getInc());
1683
1684 if (ISC.Dependent())
1685 return HasErrors;
1686
1687 // FIXME: Build loop's iteration space representation.
1688 return HasErrors;
1689 }
1690
1691 /// \brief A helper routine to skip no-op (attributed, compound) stmts get the
1692 /// next nested for loop. If \a IgnoreCaptured is true, it skips captured stmt
1693 /// to get the first for loop.
IgnoreContainerStmts(Stmt * S,bool IgnoreCaptured)1694 static Stmt *IgnoreContainerStmts(Stmt *S, bool IgnoreCaptured) {
1695 if (IgnoreCaptured)
1696 if (auto CapS = dyn_cast_or_null<CapturedStmt>(S))
1697 S = CapS->getCapturedStmt();
1698 // OpenMP [2.8.1, simd construct, Restrictions]
1699 // All loops associated with the construct must be perfectly nested; that is,
1700 // there must be no intervening code nor any OpenMP directive between any two
1701 // loops.
1702 while (true) {
1703 if (auto AS = dyn_cast_or_null<AttributedStmt>(S))
1704 S = AS->getSubStmt();
1705 else if (auto CS = dyn_cast_or_null<CompoundStmt>(S)) {
1706 if (CS->size() != 1)
1707 break;
1708 S = CS->body_back();
1709 } else
1710 break;
1711 }
1712 return S;
1713 }
1714
1715 /// \brief Called on a for stmt to check itself and nested loops (if any).
1716 /// \return Returns 0 if one of the collapsed stmts is not canonical for loop,
1717 /// number of collapsed loops otherwise.
1718 static unsigned
CheckOpenMPLoop(OpenMPDirectiveKind DKind,Expr * NestedLoopCountExpr,Stmt * AStmt,Sema & SemaRef,DSAStackTy & DSA,llvm::DenseMap<VarDecl *,Expr * > & VarsWithImplicitDSA)1719 CheckOpenMPLoop(OpenMPDirectiveKind DKind, Expr *NestedLoopCountExpr,
1720 Stmt *AStmt, Sema &SemaRef, DSAStackTy &DSA,
1721 llvm::DenseMap<VarDecl *, Expr *> &VarsWithImplicitDSA) {
1722 unsigned NestedLoopCount = 1;
1723 if (NestedLoopCountExpr) {
1724 // Found 'collapse' clause - calculate collapse number.
1725 llvm::APSInt Result;
1726 if (NestedLoopCountExpr->EvaluateAsInt(Result, SemaRef.getASTContext()))
1727 NestedLoopCount = Result.getLimitedValue();
1728 }
1729 // This is helper routine for loop directives (e.g., 'for', 'simd',
1730 // 'for simd', etc.).
1731 Stmt *CurStmt = IgnoreContainerStmts(AStmt, true);
1732 for (unsigned Cnt = 0; Cnt < NestedLoopCount; ++Cnt) {
1733 if (CheckOpenMPIterationSpace(DKind, CurStmt, SemaRef, DSA, Cnt,
1734 NestedLoopCount, NestedLoopCountExpr,
1735 VarsWithImplicitDSA))
1736 return 0;
1737 // Move on to the next nested for loop, or to the loop body.
1738 CurStmt = IgnoreContainerStmts(cast<ForStmt>(CurStmt)->getBody(), false);
1739 }
1740
1741 // FIXME: Build resulting iteration space for IR generation (collapsing
1742 // iteration spaces when loop count > 1 ('collapse' clause)).
1743 return NestedLoopCount;
1744 }
1745
GetCollapseNumberExpr(ArrayRef<OMPClause * > Clauses)1746 static Expr *GetCollapseNumberExpr(ArrayRef<OMPClause *> Clauses) {
1747 auto CollapseFilter = [](const OMPClause *C) -> bool {
1748 return C->getClauseKind() == OMPC_collapse;
1749 };
1750 OMPExecutableDirective::filtered_clause_iterator<decltype(CollapseFilter)> I(
1751 Clauses, CollapseFilter);
1752 if (I)
1753 return cast<OMPCollapseClause>(*I)->getNumForLoops();
1754 return nullptr;
1755 }
1756
ActOnOpenMPSimdDirective(ArrayRef<OMPClause * > Clauses,Stmt * AStmt,SourceLocation StartLoc,SourceLocation EndLoc,llvm::DenseMap<VarDecl *,Expr * > & VarsWithImplicitDSA)1757 StmtResult Sema::ActOnOpenMPSimdDirective(
1758 ArrayRef<OMPClause *> Clauses, Stmt *AStmt, SourceLocation StartLoc,
1759 SourceLocation EndLoc,
1760 llvm::DenseMap<VarDecl *, Expr *> &VarsWithImplicitDSA) {
1761 // In presence of clause 'collapse', it will define the nested loops number.
1762 unsigned NestedLoopCount =
1763 CheckOpenMPLoop(OMPD_simd, GetCollapseNumberExpr(Clauses), AStmt, *this,
1764 *DSAStack, VarsWithImplicitDSA);
1765 if (NestedLoopCount == 0)
1766 return StmtError();
1767
1768 getCurFunction()->setHasBranchProtectedScope();
1769 return OMPSimdDirective::Create(Context, StartLoc, EndLoc, NestedLoopCount,
1770 Clauses, AStmt);
1771 }
1772
ActOnOpenMPForDirective(ArrayRef<OMPClause * > Clauses,Stmt * AStmt,SourceLocation StartLoc,SourceLocation EndLoc,llvm::DenseMap<VarDecl *,Expr * > & VarsWithImplicitDSA)1773 StmtResult Sema::ActOnOpenMPForDirective(
1774 ArrayRef<OMPClause *> Clauses, Stmt *AStmt, SourceLocation StartLoc,
1775 SourceLocation EndLoc,
1776 llvm::DenseMap<VarDecl *, Expr *> &VarsWithImplicitDSA) {
1777 // In presence of clause 'collapse', it will define the nested loops number.
1778 unsigned NestedLoopCount =
1779 CheckOpenMPLoop(OMPD_for, GetCollapseNumberExpr(Clauses), AStmt, *this,
1780 *DSAStack, VarsWithImplicitDSA);
1781 if (NestedLoopCount == 0)
1782 return StmtError();
1783
1784 getCurFunction()->setHasBranchProtectedScope();
1785 return OMPForDirective::Create(Context, StartLoc, EndLoc, NestedLoopCount,
1786 Clauses, AStmt);
1787 }
1788
ActOnOpenMPSectionsDirective(ArrayRef<OMPClause * > Clauses,Stmt * AStmt,SourceLocation StartLoc,SourceLocation EndLoc)1789 StmtResult Sema::ActOnOpenMPSectionsDirective(ArrayRef<OMPClause *> Clauses,
1790 Stmt *AStmt,
1791 SourceLocation StartLoc,
1792 SourceLocation EndLoc) {
1793 assert(AStmt && isa<CapturedStmt>(AStmt) && "Captured statement expected");
1794 auto BaseStmt = AStmt;
1795 while (CapturedStmt *CS = dyn_cast_or_null<CapturedStmt>(BaseStmt))
1796 BaseStmt = CS->getCapturedStmt();
1797 if (auto C = dyn_cast_or_null<CompoundStmt>(BaseStmt)) {
1798 auto S = C->children();
1799 if (!S)
1800 return StmtError();
1801 // All associated statements must be '#pragma omp section' except for
1802 // the first one.
1803 for (++S; S; ++S) {
1804 auto SectionStmt = *S;
1805 if (!SectionStmt || !isa<OMPSectionDirective>(SectionStmt)) {
1806 if (SectionStmt)
1807 Diag(SectionStmt->getLocStart(),
1808 diag::err_omp_sections_substmt_not_section);
1809 return StmtError();
1810 }
1811 }
1812 } else {
1813 Diag(AStmt->getLocStart(), diag::err_omp_sections_not_compound_stmt);
1814 return StmtError();
1815 }
1816
1817 getCurFunction()->setHasBranchProtectedScope();
1818
1819 return OMPSectionsDirective::Create(Context, StartLoc, EndLoc, Clauses,
1820 AStmt);
1821 }
1822
ActOnOpenMPSectionDirective(Stmt * AStmt,SourceLocation StartLoc,SourceLocation EndLoc)1823 StmtResult Sema::ActOnOpenMPSectionDirective(Stmt *AStmt,
1824 SourceLocation StartLoc,
1825 SourceLocation EndLoc) {
1826 assert(AStmt && isa<CapturedStmt>(AStmt) && "Captured statement expected");
1827
1828 getCurFunction()->setHasBranchProtectedScope();
1829
1830 return OMPSectionDirective::Create(Context, StartLoc, EndLoc, AStmt);
1831 }
1832
ActOnOpenMPSingleDirective(ArrayRef<OMPClause * > Clauses,Stmt * AStmt,SourceLocation StartLoc,SourceLocation EndLoc)1833 StmtResult Sema::ActOnOpenMPSingleDirective(ArrayRef<OMPClause *> Clauses,
1834 Stmt *AStmt,
1835 SourceLocation StartLoc,
1836 SourceLocation EndLoc) {
1837 getCurFunction()->setHasBranchProtectedScope();
1838 return OMPSingleDirective::Create(Context, StartLoc, EndLoc, Clauses, AStmt);
1839 }
1840
ActOnOpenMPParallelForDirective(ArrayRef<OMPClause * > Clauses,Stmt * AStmt,SourceLocation StartLoc,SourceLocation EndLoc,llvm::DenseMap<VarDecl *,Expr * > & VarsWithImplicitDSA)1841 StmtResult Sema::ActOnOpenMPParallelForDirective(
1842 ArrayRef<OMPClause *> Clauses, Stmt *AStmt, SourceLocation StartLoc,
1843 SourceLocation EndLoc,
1844 llvm::DenseMap<VarDecl *, Expr *> &VarsWithImplicitDSA) {
1845 assert(AStmt && isa<CapturedStmt>(AStmt) && "Captured statement expected");
1846 CapturedStmt *CS = cast<CapturedStmt>(AStmt);
1847 // 1.2.2 OpenMP Language Terminology
1848 // Structured block - An executable statement with a single entry at the
1849 // top and a single exit at the bottom.
1850 // The point of exit cannot be a branch out of the structured block.
1851 // longjmp() and throw() must not violate the entry/exit criteria.
1852 CS->getCapturedDecl()->setNothrow();
1853
1854 // In presence of clause 'collapse', it will define the nested loops number.
1855 unsigned NestedLoopCount =
1856 CheckOpenMPLoop(OMPD_parallel_for, GetCollapseNumberExpr(Clauses), AStmt,
1857 *this, *DSAStack, VarsWithImplicitDSA);
1858 if (NestedLoopCount == 0)
1859 return StmtError();
1860
1861 getCurFunction()->setHasBranchProtectedScope();
1862 return OMPParallelForDirective::Create(Context, StartLoc, EndLoc,
1863 NestedLoopCount, Clauses, AStmt);
1864 }
1865
1866 StmtResult
ActOnOpenMPParallelSectionsDirective(ArrayRef<OMPClause * > Clauses,Stmt * AStmt,SourceLocation StartLoc,SourceLocation EndLoc)1867 Sema::ActOnOpenMPParallelSectionsDirective(ArrayRef<OMPClause *> Clauses,
1868 Stmt *AStmt, SourceLocation StartLoc,
1869 SourceLocation EndLoc) {
1870 assert(AStmt && isa<CapturedStmt>(AStmt) && "Captured statement expected");
1871 auto BaseStmt = AStmt;
1872 while (CapturedStmt *CS = dyn_cast_or_null<CapturedStmt>(BaseStmt))
1873 BaseStmt = CS->getCapturedStmt();
1874 if (auto C = dyn_cast_or_null<CompoundStmt>(BaseStmt)) {
1875 auto S = C->children();
1876 if (!S)
1877 return StmtError();
1878 // All associated statements must be '#pragma omp section' except for
1879 // the first one.
1880 for (++S; S; ++S) {
1881 auto SectionStmt = *S;
1882 if (!SectionStmt || !isa<OMPSectionDirective>(SectionStmt)) {
1883 if (SectionStmt)
1884 Diag(SectionStmt->getLocStart(),
1885 diag::err_omp_parallel_sections_substmt_not_section);
1886 return StmtError();
1887 }
1888 }
1889 } else {
1890 Diag(AStmt->getLocStart(),
1891 diag::err_omp_parallel_sections_not_compound_stmt);
1892 return StmtError();
1893 }
1894
1895 getCurFunction()->setHasBranchProtectedScope();
1896
1897 return OMPParallelSectionsDirective::Create(Context, StartLoc, EndLoc,
1898 Clauses, AStmt);
1899 }
1900
ActOnOpenMPSingleExprClause(OpenMPClauseKind Kind,Expr * Expr,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)1901 OMPClause *Sema::ActOnOpenMPSingleExprClause(OpenMPClauseKind Kind, Expr *Expr,
1902 SourceLocation StartLoc,
1903 SourceLocation LParenLoc,
1904 SourceLocation EndLoc) {
1905 OMPClause *Res = nullptr;
1906 switch (Kind) {
1907 case OMPC_if:
1908 Res = ActOnOpenMPIfClause(Expr, StartLoc, LParenLoc, EndLoc);
1909 break;
1910 case OMPC_num_threads:
1911 Res = ActOnOpenMPNumThreadsClause(Expr, StartLoc, LParenLoc, EndLoc);
1912 break;
1913 case OMPC_safelen:
1914 Res = ActOnOpenMPSafelenClause(Expr, StartLoc, LParenLoc, EndLoc);
1915 break;
1916 case OMPC_collapse:
1917 Res = ActOnOpenMPCollapseClause(Expr, StartLoc, LParenLoc, EndLoc);
1918 break;
1919 case OMPC_default:
1920 case OMPC_proc_bind:
1921 case OMPC_schedule:
1922 case OMPC_private:
1923 case OMPC_firstprivate:
1924 case OMPC_lastprivate:
1925 case OMPC_shared:
1926 case OMPC_reduction:
1927 case OMPC_linear:
1928 case OMPC_aligned:
1929 case OMPC_copyin:
1930 case OMPC_copyprivate:
1931 case OMPC_ordered:
1932 case OMPC_nowait:
1933 case OMPC_threadprivate:
1934 case OMPC_unknown:
1935 llvm_unreachable("Clause is not allowed.");
1936 }
1937 return Res;
1938 }
1939
ActOnOpenMPIfClause(Expr * Condition,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)1940 OMPClause *Sema::ActOnOpenMPIfClause(Expr *Condition, SourceLocation StartLoc,
1941 SourceLocation LParenLoc,
1942 SourceLocation EndLoc) {
1943 Expr *ValExpr = Condition;
1944 if (!Condition->isValueDependent() && !Condition->isTypeDependent() &&
1945 !Condition->isInstantiationDependent() &&
1946 !Condition->containsUnexpandedParameterPack()) {
1947 ExprResult Val = ActOnBooleanCondition(DSAStack->getCurScope(),
1948 Condition->getExprLoc(), Condition);
1949 if (Val.isInvalid())
1950 return nullptr;
1951
1952 ValExpr = Val.get();
1953 }
1954
1955 return new (Context) OMPIfClause(ValExpr, StartLoc, LParenLoc, EndLoc);
1956 }
1957
PerformOpenMPImplicitIntegerConversion(SourceLocation Loc,Expr * Op)1958 ExprResult Sema::PerformOpenMPImplicitIntegerConversion(SourceLocation Loc,
1959 Expr *Op) {
1960 if (!Op)
1961 return ExprError();
1962
1963 class IntConvertDiagnoser : public ICEConvertDiagnoser {
1964 public:
1965 IntConvertDiagnoser()
1966 : ICEConvertDiagnoser(/*AllowScopedEnumerations*/ false, false, true) {}
1967 SemaDiagnosticBuilder diagnoseNotInt(Sema &S, SourceLocation Loc,
1968 QualType T) override {
1969 return S.Diag(Loc, diag::err_omp_not_integral) << T;
1970 }
1971 SemaDiagnosticBuilder diagnoseIncomplete(Sema &S, SourceLocation Loc,
1972 QualType T) override {
1973 return S.Diag(Loc, diag::err_omp_incomplete_type) << T;
1974 }
1975 SemaDiagnosticBuilder diagnoseExplicitConv(Sema &S, SourceLocation Loc,
1976 QualType T,
1977 QualType ConvTy) override {
1978 return S.Diag(Loc, diag::err_omp_explicit_conversion) << T << ConvTy;
1979 }
1980 SemaDiagnosticBuilder noteExplicitConv(Sema &S, CXXConversionDecl *Conv,
1981 QualType ConvTy) override {
1982 return S.Diag(Conv->getLocation(), diag::note_omp_conversion_here)
1983 << ConvTy->isEnumeralType() << ConvTy;
1984 }
1985 SemaDiagnosticBuilder diagnoseAmbiguous(Sema &S, SourceLocation Loc,
1986 QualType T) override {
1987 return S.Diag(Loc, diag::err_omp_ambiguous_conversion) << T;
1988 }
1989 SemaDiagnosticBuilder noteAmbiguous(Sema &S, CXXConversionDecl *Conv,
1990 QualType ConvTy) override {
1991 return S.Diag(Conv->getLocation(), diag::note_omp_conversion_here)
1992 << ConvTy->isEnumeralType() << ConvTy;
1993 }
1994 SemaDiagnosticBuilder diagnoseConversion(Sema &, SourceLocation, QualType,
1995 QualType) override {
1996 llvm_unreachable("conversion functions are permitted");
1997 }
1998 } ConvertDiagnoser;
1999 return PerformContextualImplicitConversion(Loc, Op, ConvertDiagnoser);
2000 }
2001
ActOnOpenMPNumThreadsClause(Expr * NumThreads,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)2002 OMPClause *Sema::ActOnOpenMPNumThreadsClause(Expr *NumThreads,
2003 SourceLocation StartLoc,
2004 SourceLocation LParenLoc,
2005 SourceLocation EndLoc) {
2006 Expr *ValExpr = NumThreads;
2007 if (!NumThreads->isValueDependent() && !NumThreads->isTypeDependent() &&
2008 !NumThreads->isInstantiationDependent() &&
2009 !NumThreads->containsUnexpandedParameterPack()) {
2010 SourceLocation NumThreadsLoc = NumThreads->getLocStart();
2011 ExprResult Val =
2012 PerformOpenMPImplicitIntegerConversion(NumThreadsLoc, NumThreads);
2013 if (Val.isInvalid())
2014 return nullptr;
2015
2016 ValExpr = Val.get();
2017
2018 // OpenMP [2.5, Restrictions]
2019 // The num_threads expression must evaluate to a positive integer value.
2020 llvm::APSInt Result;
2021 if (ValExpr->isIntegerConstantExpr(Result, Context) && Result.isSigned() &&
2022 !Result.isStrictlyPositive()) {
2023 Diag(NumThreadsLoc, diag::err_omp_negative_expression_in_clause)
2024 << "num_threads" << NumThreads->getSourceRange();
2025 return nullptr;
2026 }
2027 }
2028
2029 return new (Context)
2030 OMPNumThreadsClause(ValExpr, StartLoc, LParenLoc, EndLoc);
2031 }
2032
VerifyPositiveIntegerConstantInClause(Expr * E,OpenMPClauseKind CKind)2033 ExprResult Sema::VerifyPositiveIntegerConstantInClause(Expr *E,
2034 OpenMPClauseKind CKind) {
2035 if (!E)
2036 return ExprError();
2037 if (E->isValueDependent() || E->isTypeDependent() ||
2038 E->isInstantiationDependent() || E->containsUnexpandedParameterPack())
2039 return E;
2040 llvm::APSInt Result;
2041 ExprResult ICE = VerifyIntegerConstantExpression(E, &Result);
2042 if (ICE.isInvalid())
2043 return ExprError();
2044 if (!Result.isStrictlyPositive()) {
2045 Diag(E->getExprLoc(), diag::err_omp_negative_expression_in_clause)
2046 << getOpenMPClauseName(CKind) << E->getSourceRange();
2047 return ExprError();
2048 }
2049 return ICE;
2050 }
2051
ActOnOpenMPSafelenClause(Expr * Len,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)2052 OMPClause *Sema::ActOnOpenMPSafelenClause(Expr *Len, SourceLocation StartLoc,
2053 SourceLocation LParenLoc,
2054 SourceLocation EndLoc) {
2055 // OpenMP [2.8.1, simd construct, Description]
2056 // The parameter of the safelen clause must be a constant
2057 // positive integer expression.
2058 ExprResult Safelen = VerifyPositiveIntegerConstantInClause(Len, OMPC_safelen);
2059 if (Safelen.isInvalid())
2060 return nullptr;
2061 return new (Context)
2062 OMPSafelenClause(Safelen.get(), StartLoc, LParenLoc, EndLoc);
2063 }
2064
ActOnOpenMPCollapseClause(Expr * NumForLoops,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)2065 OMPClause *Sema::ActOnOpenMPCollapseClause(Expr *NumForLoops,
2066 SourceLocation StartLoc,
2067 SourceLocation LParenLoc,
2068 SourceLocation EndLoc) {
2069 // OpenMP [2.7.1, loop construct, Description]
2070 // OpenMP [2.8.1, simd construct, Description]
2071 // OpenMP [2.9.6, distribute construct, Description]
2072 // The parameter of the collapse clause must be a constant
2073 // positive integer expression.
2074 ExprResult NumForLoopsResult =
2075 VerifyPositiveIntegerConstantInClause(NumForLoops, OMPC_collapse);
2076 if (NumForLoopsResult.isInvalid())
2077 return nullptr;
2078 return new (Context)
2079 OMPCollapseClause(NumForLoopsResult.get(), StartLoc, LParenLoc, EndLoc);
2080 }
2081
ActOnOpenMPSimpleClause(OpenMPClauseKind Kind,unsigned Argument,SourceLocation ArgumentLoc,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)2082 OMPClause *Sema::ActOnOpenMPSimpleClause(
2083 OpenMPClauseKind Kind, unsigned Argument, SourceLocation ArgumentLoc,
2084 SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc) {
2085 OMPClause *Res = nullptr;
2086 switch (Kind) {
2087 case OMPC_default:
2088 Res =
2089 ActOnOpenMPDefaultClause(static_cast<OpenMPDefaultClauseKind>(Argument),
2090 ArgumentLoc, StartLoc, LParenLoc, EndLoc);
2091 break;
2092 case OMPC_proc_bind:
2093 Res = ActOnOpenMPProcBindClause(
2094 static_cast<OpenMPProcBindClauseKind>(Argument), ArgumentLoc, StartLoc,
2095 LParenLoc, EndLoc);
2096 break;
2097 case OMPC_if:
2098 case OMPC_num_threads:
2099 case OMPC_safelen:
2100 case OMPC_collapse:
2101 case OMPC_schedule:
2102 case OMPC_private:
2103 case OMPC_firstprivate:
2104 case OMPC_lastprivate:
2105 case OMPC_shared:
2106 case OMPC_reduction:
2107 case OMPC_linear:
2108 case OMPC_aligned:
2109 case OMPC_copyin:
2110 case OMPC_copyprivate:
2111 case OMPC_ordered:
2112 case OMPC_nowait:
2113 case OMPC_threadprivate:
2114 case OMPC_unknown:
2115 llvm_unreachable("Clause is not allowed.");
2116 }
2117 return Res;
2118 }
2119
ActOnOpenMPDefaultClause(OpenMPDefaultClauseKind Kind,SourceLocation KindKwLoc,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)2120 OMPClause *Sema::ActOnOpenMPDefaultClause(OpenMPDefaultClauseKind Kind,
2121 SourceLocation KindKwLoc,
2122 SourceLocation StartLoc,
2123 SourceLocation LParenLoc,
2124 SourceLocation EndLoc) {
2125 if (Kind == OMPC_DEFAULT_unknown) {
2126 std::string Values;
2127 static_assert(OMPC_DEFAULT_unknown > 0,
2128 "OMPC_DEFAULT_unknown not greater than 0");
2129 std::string Sep(", ");
2130 for (unsigned i = 0; i < OMPC_DEFAULT_unknown; ++i) {
2131 Values += "'";
2132 Values += getOpenMPSimpleClauseTypeName(OMPC_default, i);
2133 Values += "'";
2134 switch (i) {
2135 case OMPC_DEFAULT_unknown - 2:
2136 Values += " or ";
2137 break;
2138 case OMPC_DEFAULT_unknown - 1:
2139 break;
2140 default:
2141 Values += Sep;
2142 break;
2143 }
2144 }
2145 Diag(KindKwLoc, diag::err_omp_unexpected_clause_value)
2146 << Values << getOpenMPClauseName(OMPC_default);
2147 return nullptr;
2148 }
2149 switch (Kind) {
2150 case OMPC_DEFAULT_none:
2151 DSAStack->setDefaultDSANone(KindKwLoc);
2152 break;
2153 case OMPC_DEFAULT_shared:
2154 DSAStack->setDefaultDSAShared(KindKwLoc);
2155 break;
2156 case OMPC_DEFAULT_unknown:
2157 llvm_unreachable("Clause kind is not allowed.");
2158 break;
2159 }
2160 return new (Context)
2161 OMPDefaultClause(Kind, KindKwLoc, StartLoc, LParenLoc, EndLoc);
2162 }
2163
ActOnOpenMPProcBindClause(OpenMPProcBindClauseKind Kind,SourceLocation KindKwLoc,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)2164 OMPClause *Sema::ActOnOpenMPProcBindClause(OpenMPProcBindClauseKind Kind,
2165 SourceLocation KindKwLoc,
2166 SourceLocation StartLoc,
2167 SourceLocation LParenLoc,
2168 SourceLocation EndLoc) {
2169 if (Kind == OMPC_PROC_BIND_unknown) {
2170 std::string Values;
2171 std::string Sep(", ");
2172 for (unsigned i = 0; i < OMPC_PROC_BIND_unknown; ++i) {
2173 Values += "'";
2174 Values += getOpenMPSimpleClauseTypeName(OMPC_proc_bind, i);
2175 Values += "'";
2176 switch (i) {
2177 case OMPC_PROC_BIND_unknown - 2:
2178 Values += " or ";
2179 break;
2180 case OMPC_PROC_BIND_unknown - 1:
2181 break;
2182 default:
2183 Values += Sep;
2184 break;
2185 }
2186 }
2187 Diag(KindKwLoc, diag::err_omp_unexpected_clause_value)
2188 << Values << getOpenMPClauseName(OMPC_proc_bind);
2189 return nullptr;
2190 }
2191 return new (Context)
2192 OMPProcBindClause(Kind, KindKwLoc, StartLoc, LParenLoc, EndLoc);
2193 }
2194
ActOnOpenMPSingleExprWithArgClause(OpenMPClauseKind Kind,unsigned Argument,Expr * Expr,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation ArgumentLoc,SourceLocation CommaLoc,SourceLocation EndLoc)2195 OMPClause *Sema::ActOnOpenMPSingleExprWithArgClause(
2196 OpenMPClauseKind Kind, unsigned Argument, Expr *Expr,
2197 SourceLocation StartLoc, SourceLocation LParenLoc,
2198 SourceLocation ArgumentLoc, SourceLocation CommaLoc,
2199 SourceLocation EndLoc) {
2200 OMPClause *Res = nullptr;
2201 switch (Kind) {
2202 case OMPC_schedule:
2203 Res = ActOnOpenMPScheduleClause(
2204 static_cast<OpenMPScheduleClauseKind>(Argument), Expr, StartLoc,
2205 LParenLoc, ArgumentLoc, CommaLoc, EndLoc);
2206 break;
2207 case OMPC_if:
2208 case OMPC_num_threads:
2209 case OMPC_safelen:
2210 case OMPC_collapse:
2211 case OMPC_default:
2212 case OMPC_proc_bind:
2213 case OMPC_private:
2214 case OMPC_firstprivate:
2215 case OMPC_lastprivate:
2216 case OMPC_shared:
2217 case OMPC_reduction:
2218 case OMPC_linear:
2219 case OMPC_aligned:
2220 case OMPC_copyin:
2221 case OMPC_copyprivate:
2222 case OMPC_ordered:
2223 case OMPC_nowait:
2224 case OMPC_threadprivate:
2225 case OMPC_unknown:
2226 llvm_unreachable("Clause is not allowed.");
2227 }
2228 return Res;
2229 }
2230
ActOnOpenMPScheduleClause(OpenMPScheduleClauseKind Kind,Expr * ChunkSize,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation KindLoc,SourceLocation CommaLoc,SourceLocation EndLoc)2231 OMPClause *Sema::ActOnOpenMPScheduleClause(
2232 OpenMPScheduleClauseKind Kind, Expr *ChunkSize, SourceLocation StartLoc,
2233 SourceLocation LParenLoc, SourceLocation KindLoc, SourceLocation CommaLoc,
2234 SourceLocation EndLoc) {
2235 if (Kind == OMPC_SCHEDULE_unknown) {
2236 std::string Values;
2237 std::string Sep(", ");
2238 for (unsigned i = 0; i < OMPC_SCHEDULE_unknown; ++i) {
2239 Values += "'";
2240 Values += getOpenMPSimpleClauseTypeName(OMPC_schedule, i);
2241 Values += "'";
2242 switch (i) {
2243 case OMPC_SCHEDULE_unknown - 2:
2244 Values += " or ";
2245 break;
2246 case OMPC_SCHEDULE_unknown - 1:
2247 break;
2248 default:
2249 Values += Sep;
2250 break;
2251 }
2252 }
2253 Diag(KindLoc, diag::err_omp_unexpected_clause_value)
2254 << Values << getOpenMPClauseName(OMPC_schedule);
2255 return nullptr;
2256 }
2257 Expr *ValExpr = ChunkSize;
2258 if (ChunkSize) {
2259 if (!ChunkSize->isValueDependent() && !ChunkSize->isTypeDependent() &&
2260 !ChunkSize->isInstantiationDependent() &&
2261 !ChunkSize->containsUnexpandedParameterPack()) {
2262 SourceLocation ChunkSizeLoc = ChunkSize->getLocStart();
2263 ExprResult Val =
2264 PerformOpenMPImplicitIntegerConversion(ChunkSizeLoc, ChunkSize);
2265 if (Val.isInvalid())
2266 return nullptr;
2267
2268 ValExpr = Val.get();
2269
2270 // OpenMP [2.7.1, Restrictions]
2271 // chunk_size must be a loop invariant integer expression with a positive
2272 // value.
2273 llvm::APSInt Result;
2274 if (ValExpr->isIntegerConstantExpr(Result, Context) &&
2275 Result.isSigned() && !Result.isStrictlyPositive()) {
2276 Diag(ChunkSizeLoc, diag::err_omp_negative_expression_in_clause)
2277 << "schedule" << ChunkSize->getSourceRange();
2278 return nullptr;
2279 }
2280 }
2281 }
2282
2283 return new (Context) OMPScheduleClause(StartLoc, LParenLoc, KindLoc, CommaLoc,
2284 EndLoc, Kind, ValExpr);
2285 }
2286
ActOnOpenMPClause(OpenMPClauseKind Kind,SourceLocation StartLoc,SourceLocation EndLoc)2287 OMPClause *Sema::ActOnOpenMPClause(OpenMPClauseKind Kind,
2288 SourceLocation StartLoc,
2289 SourceLocation EndLoc) {
2290 OMPClause *Res = nullptr;
2291 switch (Kind) {
2292 case OMPC_ordered:
2293 Res = ActOnOpenMPOrderedClause(StartLoc, EndLoc);
2294 break;
2295 case OMPC_nowait:
2296 Res = ActOnOpenMPNowaitClause(StartLoc, EndLoc);
2297 break;
2298 case OMPC_if:
2299 case OMPC_num_threads:
2300 case OMPC_safelen:
2301 case OMPC_collapse:
2302 case OMPC_schedule:
2303 case OMPC_private:
2304 case OMPC_firstprivate:
2305 case OMPC_lastprivate:
2306 case OMPC_shared:
2307 case OMPC_reduction:
2308 case OMPC_linear:
2309 case OMPC_aligned:
2310 case OMPC_copyin:
2311 case OMPC_copyprivate:
2312 case OMPC_default:
2313 case OMPC_proc_bind:
2314 case OMPC_threadprivate:
2315 case OMPC_unknown:
2316 llvm_unreachable("Clause is not allowed.");
2317 }
2318 return Res;
2319 }
2320
ActOnOpenMPOrderedClause(SourceLocation StartLoc,SourceLocation EndLoc)2321 OMPClause *Sema::ActOnOpenMPOrderedClause(SourceLocation StartLoc,
2322 SourceLocation EndLoc) {
2323 return new (Context) OMPOrderedClause(StartLoc, EndLoc);
2324 }
2325
ActOnOpenMPNowaitClause(SourceLocation StartLoc,SourceLocation EndLoc)2326 OMPClause *Sema::ActOnOpenMPNowaitClause(SourceLocation StartLoc,
2327 SourceLocation EndLoc) {
2328 return new (Context) OMPNowaitClause(StartLoc, EndLoc);
2329 }
2330
ActOnOpenMPVarListClause(OpenMPClauseKind Kind,ArrayRef<Expr * > VarList,Expr * TailExpr,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation ColonLoc,SourceLocation EndLoc,CXXScopeSpec & ReductionIdScopeSpec,const DeclarationNameInfo & ReductionId)2331 OMPClause *Sema::ActOnOpenMPVarListClause(
2332 OpenMPClauseKind Kind, ArrayRef<Expr *> VarList, Expr *TailExpr,
2333 SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation ColonLoc,
2334 SourceLocation EndLoc, CXXScopeSpec &ReductionIdScopeSpec,
2335 const DeclarationNameInfo &ReductionId) {
2336 OMPClause *Res = nullptr;
2337 switch (Kind) {
2338 case OMPC_private:
2339 Res = ActOnOpenMPPrivateClause(VarList, StartLoc, LParenLoc, EndLoc);
2340 break;
2341 case OMPC_firstprivate:
2342 Res = ActOnOpenMPFirstprivateClause(VarList, StartLoc, LParenLoc, EndLoc);
2343 break;
2344 case OMPC_lastprivate:
2345 Res = ActOnOpenMPLastprivateClause(VarList, StartLoc, LParenLoc, EndLoc);
2346 break;
2347 case OMPC_shared:
2348 Res = ActOnOpenMPSharedClause(VarList, StartLoc, LParenLoc, EndLoc);
2349 break;
2350 case OMPC_reduction:
2351 Res = ActOnOpenMPReductionClause(VarList, StartLoc, LParenLoc, ColonLoc,
2352 EndLoc, ReductionIdScopeSpec, ReductionId);
2353 break;
2354 case OMPC_linear:
2355 Res = ActOnOpenMPLinearClause(VarList, TailExpr, StartLoc, LParenLoc,
2356 ColonLoc, EndLoc);
2357 break;
2358 case OMPC_aligned:
2359 Res = ActOnOpenMPAlignedClause(VarList, TailExpr, StartLoc, LParenLoc,
2360 ColonLoc, EndLoc);
2361 break;
2362 case OMPC_copyin:
2363 Res = ActOnOpenMPCopyinClause(VarList, StartLoc, LParenLoc, EndLoc);
2364 break;
2365 case OMPC_copyprivate:
2366 Res = ActOnOpenMPCopyprivateClause(VarList, StartLoc, LParenLoc, EndLoc);
2367 break;
2368 case OMPC_if:
2369 case OMPC_num_threads:
2370 case OMPC_safelen:
2371 case OMPC_collapse:
2372 case OMPC_default:
2373 case OMPC_proc_bind:
2374 case OMPC_schedule:
2375 case OMPC_ordered:
2376 case OMPC_nowait:
2377 case OMPC_threadprivate:
2378 case OMPC_unknown:
2379 llvm_unreachable("Clause is not allowed.");
2380 }
2381 return Res;
2382 }
2383
ActOnOpenMPPrivateClause(ArrayRef<Expr * > VarList,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)2384 OMPClause *Sema::ActOnOpenMPPrivateClause(ArrayRef<Expr *> VarList,
2385 SourceLocation StartLoc,
2386 SourceLocation LParenLoc,
2387 SourceLocation EndLoc) {
2388 SmallVector<Expr *, 8> Vars;
2389 for (auto &RefExpr : VarList) {
2390 assert(RefExpr && "NULL expr in OpenMP private clause.");
2391 if (isa<DependentScopeDeclRefExpr>(RefExpr)) {
2392 // It will be analyzed later.
2393 Vars.push_back(RefExpr);
2394 continue;
2395 }
2396
2397 SourceLocation ELoc = RefExpr->getExprLoc();
2398 // OpenMP [2.1, C/C++]
2399 // A list item is a variable name.
2400 // OpenMP [2.9.3.3, Restrictions, p.1]
2401 // A variable that is part of another variable (as an array or
2402 // structure element) cannot appear in a private clause.
2403 DeclRefExpr *DE = dyn_cast_or_null<DeclRefExpr>(RefExpr);
2404 if (!DE || !isa<VarDecl>(DE->getDecl())) {
2405 Diag(ELoc, diag::err_omp_expected_var_name) << RefExpr->getSourceRange();
2406 continue;
2407 }
2408 Decl *D = DE->getDecl();
2409 VarDecl *VD = cast<VarDecl>(D);
2410
2411 QualType Type = VD->getType();
2412 if (Type->isDependentType() || Type->isInstantiationDependentType()) {
2413 // It will be analyzed later.
2414 Vars.push_back(DE);
2415 continue;
2416 }
2417
2418 // OpenMP [2.9.3.3, Restrictions, C/C++, p.3]
2419 // A variable that appears in a private clause must not have an incomplete
2420 // type or a reference type.
2421 if (RequireCompleteType(ELoc, Type,
2422 diag::err_omp_private_incomplete_type)) {
2423 continue;
2424 }
2425 if (Type->isReferenceType()) {
2426 Diag(ELoc, diag::err_omp_clause_ref_type_arg)
2427 << getOpenMPClauseName(OMPC_private) << Type;
2428 bool IsDecl =
2429 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
2430 Diag(VD->getLocation(),
2431 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
2432 << VD;
2433 continue;
2434 }
2435
2436 // OpenMP [2.9.3.3, Restrictions, C/C++, p.1]
2437 // A variable of class type (or array thereof) that appears in a private
2438 // clause requires an accessible, unambiguous default constructor for the
2439 // class type.
2440 while (Type.getNonReferenceType()->isArrayType()) {
2441 Type = cast<ArrayType>(Type.getNonReferenceType().getTypePtr())
2442 ->getElementType();
2443 }
2444 CXXRecordDecl *RD = getLangOpts().CPlusPlus
2445 ? Type.getNonReferenceType()->getAsCXXRecordDecl()
2446 : nullptr;
2447 // FIXME This code must be replaced by actual constructing/destructing of
2448 // the private variable.
2449 if (RD) {
2450 CXXConstructorDecl *CD = LookupDefaultConstructor(RD);
2451 PartialDiagnostic PD =
2452 PartialDiagnostic(PartialDiagnostic::NullDiagnostic());
2453 if (!CD ||
2454 CheckConstructorAccess(ELoc, CD,
2455 InitializedEntity::InitializeTemporary(Type),
2456 CD->getAccess(), PD) == AR_inaccessible ||
2457 CD->isDeleted()) {
2458 Diag(ELoc, diag::err_omp_required_method)
2459 << getOpenMPClauseName(OMPC_private) << 0;
2460 bool IsDecl = VD->isThisDeclarationADefinition(Context) ==
2461 VarDecl::DeclarationOnly;
2462 Diag(VD->getLocation(),
2463 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
2464 << VD;
2465 Diag(RD->getLocation(), diag::note_previous_decl) << RD;
2466 continue;
2467 }
2468 MarkFunctionReferenced(ELoc, CD);
2469 DiagnoseUseOfDecl(CD, ELoc);
2470
2471 CXXDestructorDecl *DD = RD->getDestructor();
2472 if (DD) {
2473 if (CheckDestructorAccess(ELoc, DD, PD) == AR_inaccessible ||
2474 DD->isDeleted()) {
2475 Diag(ELoc, diag::err_omp_required_method)
2476 << getOpenMPClauseName(OMPC_private) << 4;
2477 bool IsDecl = VD->isThisDeclarationADefinition(Context) ==
2478 VarDecl::DeclarationOnly;
2479 Diag(VD->getLocation(),
2480 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
2481 << VD;
2482 Diag(RD->getLocation(), diag::note_previous_decl) << RD;
2483 continue;
2484 }
2485 MarkFunctionReferenced(ELoc, DD);
2486 DiagnoseUseOfDecl(DD, ELoc);
2487 }
2488 }
2489
2490 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
2491 // in a Construct]
2492 // Variables with the predetermined data-sharing attributes may not be
2493 // listed in data-sharing attributes clauses, except for the cases
2494 // listed below. For these exceptions only, listing a predetermined
2495 // variable in a data-sharing attribute clause is allowed and overrides
2496 // the variable's predetermined data-sharing attributes.
2497 DSAStackTy::DSAVarData DVar = DSAStack->getTopDSA(VD);
2498 if (DVar.CKind != OMPC_unknown && DVar.CKind != OMPC_private) {
2499 Diag(ELoc, diag::err_omp_wrong_dsa) << getOpenMPClauseName(DVar.CKind)
2500 << getOpenMPClauseName(OMPC_private);
2501 ReportOriginalDSA(*this, DSAStack, VD, DVar);
2502 continue;
2503 }
2504
2505 DSAStack->addDSA(VD, DE, OMPC_private);
2506 Vars.push_back(DE);
2507 }
2508
2509 if (Vars.empty())
2510 return nullptr;
2511
2512 return OMPPrivateClause::Create(Context, StartLoc, LParenLoc, EndLoc, Vars);
2513 }
2514
ActOnOpenMPFirstprivateClause(ArrayRef<Expr * > VarList,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)2515 OMPClause *Sema::ActOnOpenMPFirstprivateClause(ArrayRef<Expr *> VarList,
2516 SourceLocation StartLoc,
2517 SourceLocation LParenLoc,
2518 SourceLocation EndLoc) {
2519 SmallVector<Expr *, 8> Vars;
2520 for (auto &RefExpr : VarList) {
2521 assert(RefExpr && "NULL expr in OpenMP firstprivate clause.");
2522 if (isa<DependentScopeDeclRefExpr>(RefExpr)) {
2523 // It will be analyzed later.
2524 Vars.push_back(RefExpr);
2525 continue;
2526 }
2527
2528 SourceLocation ELoc = RefExpr->getExprLoc();
2529 // OpenMP [2.1, C/C++]
2530 // A list item is a variable name.
2531 // OpenMP [2.9.3.3, Restrictions, p.1]
2532 // A variable that is part of another variable (as an array or
2533 // structure element) cannot appear in a private clause.
2534 DeclRefExpr *DE = dyn_cast_or_null<DeclRefExpr>(RefExpr);
2535 if (!DE || !isa<VarDecl>(DE->getDecl())) {
2536 Diag(ELoc, diag::err_omp_expected_var_name) << RefExpr->getSourceRange();
2537 continue;
2538 }
2539 Decl *D = DE->getDecl();
2540 VarDecl *VD = cast<VarDecl>(D);
2541
2542 QualType Type = VD->getType();
2543 if (Type->isDependentType() || Type->isInstantiationDependentType()) {
2544 // It will be analyzed later.
2545 Vars.push_back(DE);
2546 continue;
2547 }
2548
2549 // OpenMP [2.9.3.3, Restrictions, C/C++, p.3]
2550 // A variable that appears in a private clause must not have an incomplete
2551 // type or a reference type.
2552 if (RequireCompleteType(ELoc, Type,
2553 diag::err_omp_firstprivate_incomplete_type)) {
2554 continue;
2555 }
2556 if (Type->isReferenceType()) {
2557 Diag(ELoc, diag::err_omp_clause_ref_type_arg)
2558 << getOpenMPClauseName(OMPC_firstprivate) << Type;
2559 bool IsDecl =
2560 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
2561 Diag(VD->getLocation(),
2562 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
2563 << VD;
2564 continue;
2565 }
2566
2567 // OpenMP [2.9.3.4, Restrictions, C/C++, p.1]
2568 // A variable of class type (or array thereof) that appears in a private
2569 // clause requires an accessible, unambiguous copy constructor for the
2570 // class type.
2571 Type = Context.getBaseElementType(Type);
2572 CXXRecordDecl *RD = getLangOpts().CPlusPlus
2573 ? Type.getNonReferenceType()->getAsCXXRecordDecl()
2574 : nullptr;
2575 // FIXME This code must be replaced by actual constructing/destructing of
2576 // the firstprivate variable.
2577 if (RD) {
2578 CXXConstructorDecl *CD = LookupCopyingConstructor(RD, 0);
2579 PartialDiagnostic PD =
2580 PartialDiagnostic(PartialDiagnostic::NullDiagnostic());
2581 if (!CD ||
2582 CheckConstructorAccess(ELoc, CD,
2583 InitializedEntity::InitializeTemporary(Type),
2584 CD->getAccess(), PD) == AR_inaccessible ||
2585 CD->isDeleted()) {
2586 Diag(ELoc, diag::err_omp_required_method)
2587 << getOpenMPClauseName(OMPC_firstprivate) << 1;
2588 bool IsDecl = VD->isThisDeclarationADefinition(Context) ==
2589 VarDecl::DeclarationOnly;
2590 Diag(VD->getLocation(),
2591 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
2592 << VD;
2593 Diag(RD->getLocation(), diag::note_previous_decl) << RD;
2594 continue;
2595 }
2596 MarkFunctionReferenced(ELoc, CD);
2597 DiagnoseUseOfDecl(CD, ELoc);
2598
2599 CXXDestructorDecl *DD = RD->getDestructor();
2600 if (DD) {
2601 if (CheckDestructorAccess(ELoc, DD, PD) == AR_inaccessible ||
2602 DD->isDeleted()) {
2603 Diag(ELoc, diag::err_omp_required_method)
2604 << getOpenMPClauseName(OMPC_firstprivate) << 4;
2605 bool IsDecl = VD->isThisDeclarationADefinition(Context) ==
2606 VarDecl::DeclarationOnly;
2607 Diag(VD->getLocation(),
2608 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
2609 << VD;
2610 Diag(RD->getLocation(), diag::note_previous_decl) << RD;
2611 continue;
2612 }
2613 MarkFunctionReferenced(ELoc, DD);
2614 DiagnoseUseOfDecl(DD, ELoc);
2615 }
2616 }
2617
2618 // If StartLoc and EndLoc are invalid - this is an implicit firstprivate
2619 // variable and it was checked already.
2620 if (StartLoc.isValid() && EndLoc.isValid()) {
2621 DSAStackTy::DSAVarData DVar = DSAStack->getTopDSA(VD);
2622 Type = Type.getNonReferenceType().getCanonicalType();
2623 bool IsConstant = Type.isConstant(Context);
2624 Type = Context.getBaseElementType(Type);
2625 // OpenMP [2.4.13, Data-sharing Attribute Clauses]
2626 // A list item that specifies a given variable may not appear in more
2627 // than one clause on the same directive, except that a variable may be
2628 // specified in both firstprivate and lastprivate clauses.
2629 if (DVar.CKind != OMPC_unknown && DVar.CKind != OMPC_firstprivate &&
2630 DVar.CKind != OMPC_lastprivate && DVar.RefExpr) {
2631 Diag(ELoc, diag::err_omp_wrong_dsa)
2632 << getOpenMPClauseName(DVar.CKind)
2633 << getOpenMPClauseName(OMPC_firstprivate);
2634 ReportOriginalDSA(*this, DSAStack, VD, DVar);
2635 continue;
2636 }
2637
2638 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
2639 // in a Construct]
2640 // Variables with the predetermined data-sharing attributes may not be
2641 // listed in data-sharing attributes clauses, except for the cases
2642 // listed below. For these exceptions only, listing a predetermined
2643 // variable in a data-sharing attribute clause is allowed and overrides
2644 // the variable's predetermined data-sharing attributes.
2645 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
2646 // in a Construct, C/C++, p.2]
2647 // Variables with const-qualified type having no mutable member may be
2648 // listed in a firstprivate clause, even if they are static data members.
2649 if (!(IsConstant || VD->isStaticDataMember()) && !DVar.RefExpr &&
2650 DVar.CKind != OMPC_unknown && DVar.CKind != OMPC_shared) {
2651 Diag(ELoc, diag::err_omp_wrong_dsa)
2652 << getOpenMPClauseName(DVar.CKind)
2653 << getOpenMPClauseName(OMPC_firstprivate);
2654 ReportOriginalDSA(*this, DSAStack, VD, DVar);
2655 continue;
2656 }
2657
2658 OpenMPDirectiveKind CurrDir = DSAStack->getCurrentDirective();
2659 // OpenMP [2.9.3.4, Restrictions, p.2]
2660 // A list item that is private within a parallel region must not appear
2661 // in a firstprivate clause on a worksharing construct if any of the
2662 // worksharing regions arising from the worksharing construct ever bind
2663 // to any of the parallel regions arising from the parallel construct.
2664 if (isOpenMPWorksharingDirective(CurrDir) &&
2665 !isOpenMPParallelDirective(CurrDir)) {
2666 DVar = DSAStack->getImplicitDSA(VD);
2667 if (DVar.CKind != OMPC_shared) {
2668 Diag(ELoc, diag::err_omp_required_access)
2669 << getOpenMPClauseName(OMPC_firstprivate)
2670 << getOpenMPClauseName(OMPC_shared);
2671 ReportOriginalDSA(*this, DSAStack, VD, DVar);
2672 continue;
2673 }
2674 }
2675 // OpenMP [2.9.3.4, Restrictions, p.3]
2676 // A list item that appears in a reduction clause of a parallel construct
2677 // must not appear in a firstprivate clause on a worksharing or task
2678 // construct if any of the worksharing or task regions arising from the
2679 // worksharing or task construct ever bind to any of the parallel regions
2680 // arising from the parallel construct.
2681 // TODO
2682 // OpenMP [2.9.3.4, Restrictions, p.4]
2683 // A list item that appears in a reduction clause in worksharing
2684 // construct must not appear in a firstprivate clause in a task construct
2685 // encountered during execution of any of the worksharing regions arising
2686 // from the worksharing construct.
2687 // TODO
2688 }
2689
2690 DSAStack->addDSA(VD, DE, OMPC_firstprivate);
2691 Vars.push_back(DE);
2692 }
2693
2694 if (Vars.empty())
2695 return nullptr;
2696
2697 return OMPFirstprivateClause::Create(Context, StartLoc, LParenLoc, EndLoc,
2698 Vars);
2699 }
2700
ActOnOpenMPLastprivateClause(ArrayRef<Expr * > VarList,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)2701 OMPClause *Sema::ActOnOpenMPLastprivateClause(ArrayRef<Expr *> VarList,
2702 SourceLocation StartLoc,
2703 SourceLocation LParenLoc,
2704 SourceLocation EndLoc) {
2705 SmallVector<Expr *, 8> Vars;
2706 for (auto &RefExpr : VarList) {
2707 assert(RefExpr && "NULL expr in OpenMP lastprivate clause.");
2708 if (isa<DependentScopeDeclRefExpr>(RefExpr)) {
2709 // It will be analyzed later.
2710 Vars.push_back(RefExpr);
2711 continue;
2712 }
2713
2714 SourceLocation ELoc = RefExpr->getExprLoc();
2715 // OpenMP [2.1, C/C++]
2716 // A list item is a variable name.
2717 // OpenMP [2.14.3.5, Restrictions, p.1]
2718 // A variable that is part of another variable (as an array or structure
2719 // element) cannot appear in a lastprivate clause.
2720 DeclRefExpr *DE = dyn_cast_or_null<DeclRefExpr>(RefExpr);
2721 if (!DE || !isa<VarDecl>(DE->getDecl())) {
2722 Diag(ELoc, diag::err_omp_expected_var_name) << RefExpr->getSourceRange();
2723 continue;
2724 }
2725 Decl *D = DE->getDecl();
2726 VarDecl *VD = cast<VarDecl>(D);
2727
2728 QualType Type = VD->getType();
2729 if (Type->isDependentType() || Type->isInstantiationDependentType()) {
2730 // It will be analyzed later.
2731 Vars.push_back(DE);
2732 continue;
2733 }
2734
2735 // OpenMP [2.14.3.5, Restrictions, C/C++, p.2]
2736 // A variable that appears in a lastprivate clause must not have an
2737 // incomplete type or a reference type.
2738 if (RequireCompleteType(ELoc, Type,
2739 diag::err_omp_lastprivate_incomplete_type)) {
2740 continue;
2741 }
2742 if (Type->isReferenceType()) {
2743 Diag(ELoc, diag::err_omp_clause_ref_type_arg)
2744 << getOpenMPClauseName(OMPC_lastprivate) << Type;
2745 bool IsDecl =
2746 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
2747 Diag(VD->getLocation(),
2748 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
2749 << VD;
2750 continue;
2751 }
2752
2753 // OpenMP [2.14.1.1, Data-sharing Attribute Rules for Variables Referenced
2754 // in a Construct]
2755 // Variables with the predetermined data-sharing attributes may not be
2756 // listed in data-sharing attributes clauses, except for the cases
2757 // listed below.
2758 DSAStackTy::DSAVarData DVar = DSAStack->getTopDSA(VD);
2759 if (DVar.CKind != OMPC_unknown && DVar.CKind != OMPC_lastprivate &&
2760 DVar.CKind != OMPC_firstprivate &&
2761 (DVar.CKind != OMPC_private || DVar.RefExpr != nullptr)) {
2762 Diag(ELoc, diag::err_omp_wrong_dsa)
2763 << getOpenMPClauseName(DVar.CKind)
2764 << getOpenMPClauseName(OMPC_lastprivate);
2765 ReportOriginalDSA(*this, DSAStack, VD, DVar);
2766 continue;
2767 }
2768
2769 OpenMPDirectiveKind CurrDir = DSAStack->getCurrentDirective();
2770 // OpenMP [2.14.3.5, Restrictions, p.2]
2771 // A list item that is private within a parallel region, or that appears in
2772 // the reduction clause of a parallel construct, must not appear in a
2773 // lastprivate clause on a worksharing construct if any of the corresponding
2774 // worksharing regions ever binds to any of the corresponding parallel
2775 // regions.
2776 if (isOpenMPWorksharingDirective(CurrDir) &&
2777 !isOpenMPParallelDirective(CurrDir)) {
2778 DVar = DSAStack->getImplicitDSA(VD);
2779 if (DVar.CKind != OMPC_shared) {
2780 Diag(ELoc, diag::err_omp_required_access)
2781 << getOpenMPClauseName(OMPC_lastprivate)
2782 << getOpenMPClauseName(OMPC_shared);
2783 ReportOriginalDSA(*this, DSAStack, VD, DVar);
2784 continue;
2785 }
2786 }
2787 // OpenMP [2.14.3.5, Restrictions, C++, p.1,2]
2788 // A variable of class type (or array thereof) that appears in a
2789 // lastprivate clause requires an accessible, unambiguous default
2790 // constructor for the class type, unless the list item is also specified
2791 // in a firstprivate clause.
2792 // A variable of class type (or array thereof) that appears in a
2793 // lastprivate clause requires an accessible, unambiguous copy assignment
2794 // operator for the class type.
2795 while (Type.getNonReferenceType()->isArrayType())
2796 Type = cast<ArrayType>(Type.getNonReferenceType().getTypePtr())
2797 ->getElementType();
2798 CXXRecordDecl *RD = getLangOpts().CPlusPlus
2799 ? Type.getNonReferenceType()->getAsCXXRecordDecl()
2800 : nullptr;
2801 // FIXME This code must be replaced by actual copying and destructing of the
2802 // lastprivate variable.
2803 if (RD) {
2804 CXXMethodDecl *MD = LookupCopyingAssignment(RD, 0, false, 0);
2805 DeclAccessPair FoundDecl = DeclAccessPair::make(MD, MD->getAccess());
2806 if (MD) {
2807 if (CheckMemberAccess(ELoc, RD, FoundDecl) == AR_inaccessible ||
2808 MD->isDeleted()) {
2809 Diag(ELoc, diag::err_omp_required_method)
2810 << getOpenMPClauseName(OMPC_lastprivate) << 2;
2811 bool IsDecl = VD->isThisDeclarationADefinition(Context) ==
2812 VarDecl::DeclarationOnly;
2813 Diag(VD->getLocation(),
2814 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
2815 << VD;
2816 Diag(RD->getLocation(), diag::note_previous_decl) << RD;
2817 continue;
2818 }
2819 MarkFunctionReferenced(ELoc, MD);
2820 DiagnoseUseOfDecl(MD, ELoc);
2821 }
2822
2823 CXXDestructorDecl *DD = RD->getDestructor();
2824 if (DD) {
2825 PartialDiagnostic PD =
2826 PartialDiagnostic(PartialDiagnostic::NullDiagnostic());
2827 if (CheckDestructorAccess(ELoc, DD, PD) == AR_inaccessible ||
2828 DD->isDeleted()) {
2829 Diag(ELoc, diag::err_omp_required_method)
2830 << getOpenMPClauseName(OMPC_lastprivate) << 4;
2831 bool IsDecl = VD->isThisDeclarationADefinition(Context) ==
2832 VarDecl::DeclarationOnly;
2833 Diag(VD->getLocation(),
2834 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
2835 << VD;
2836 Diag(RD->getLocation(), diag::note_previous_decl) << RD;
2837 continue;
2838 }
2839 MarkFunctionReferenced(ELoc, DD);
2840 DiagnoseUseOfDecl(DD, ELoc);
2841 }
2842 }
2843
2844 if (DVar.CKind != OMPC_firstprivate)
2845 DSAStack->addDSA(VD, DE, OMPC_lastprivate);
2846 Vars.push_back(DE);
2847 }
2848
2849 if (Vars.empty())
2850 return nullptr;
2851
2852 return OMPLastprivateClause::Create(Context, StartLoc, LParenLoc, EndLoc,
2853 Vars);
2854 }
2855
ActOnOpenMPSharedClause(ArrayRef<Expr * > VarList,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)2856 OMPClause *Sema::ActOnOpenMPSharedClause(ArrayRef<Expr *> VarList,
2857 SourceLocation StartLoc,
2858 SourceLocation LParenLoc,
2859 SourceLocation EndLoc) {
2860 SmallVector<Expr *, 8> Vars;
2861 for (auto &RefExpr : VarList) {
2862 assert(RefExpr && "NULL expr in OpenMP shared clause.");
2863 if (isa<DependentScopeDeclRefExpr>(RefExpr)) {
2864 // It will be analyzed later.
2865 Vars.push_back(RefExpr);
2866 continue;
2867 }
2868
2869 SourceLocation ELoc = RefExpr->getExprLoc();
2870 // OpenMP [2.1, C/C++]
2871 // A list item is a variable name.
2872 // OpenMP [2.14.3.2, Restrictions, p.1]
2873 // A variable that is part of another variable (as an array or structure
2874 // element) cannot appear in a shared unless it is a static data member
2875 // of a C++ class.
2876 DeclRefExpr *DE = dyn_cast<DeclRefExpr>(RefExpr);
2877 if (!DE || !isa<VarDecl>(DE->getDecl())) {
2878 Diag(ELoc, diag::err_omp_expected_var_name) << RefExpr->getSourceRange();
2879 continue;
2880 }
2881 Decl *D = DE->getDecl();
2882 VarDecl *VD = cast<VarDecl>(D);
2883
2884 QualType Type = VD->getType();
2885 if (Type->isDependentType() || Type->isInstantiationDependentType()) {
2886 // It will be analyzed later.
2887 Vars.push_back(DE);
2888 continue;
2889 }
2890
2891 // OpenMP [2.9.1.1, Data-sharing Attribute Rules for Variables Referenced
2892 // in a Construct]
2893 // Variables with the predetermined data-sharing attributes may not be
2894 // listed in data-sharing attributes clauses, except for the cases
2895 // listed below. For these exceptions only, listing a predetermined
2896 // variable in a data-sharing attribute clause is allowed and overrides
2897 // the variable's predetermined data-sharing attributes.
2898 DSAStackTy::DSAVarData DVar = DSAStack->getTopDSA(VD);
2899 if (DVar.CKind != OMPC_unknown && DVar.CKind != OMPC_shared &&
2900 DVar.RefExpr) {
2901 Diag(ELoc, diag::err_omp_wrong_dsa) << getOpenMPClauseName(DVar.CKind)
2902 << getOpenMPClauseName(OMPC_shared);
2903 ReportOriginalDSA(*this, DSAStack, VD, DVar);
2904 continue;
2905 }
2906
2907 DSAStack->addDSA(VD, DE, OMPC_shared);
2908 Vars.push_back(DE);
2909 }
2910
2911 if (Vars.empty())
2912 return nullptr;
2913
2914 return OMPSharedClause::Create(Context, StartLoc, LParenLoc, EndLoc, Vars);
2915 }
2916
2917 namespace {
2918 class DSARefChecker : public StmtVisitor<DSARefChecker, bool> {
2919 DSAStackTy *Stack;
2920
2921 public:
VisitDeclRefExpr(DeclRefExpr * E)2922 bool VisitDeclRefExpr(DeclRefExpr *E) {
2923 if (VarDecl *VD = dyn_cast<VarDecl>(E->getDecl())) {
2924 DSAStackTy::DSAVarData DVar = Stack->getTopDSA(VD);
2925 if (DVar.CKind == OMPC_shared && !DVar.RefExpr)
2926 return false;
2927 if (DVar.CKind != OMPC_unknown)
2928 return true;
2929 DSAStackTy::DSAVarData DVarPrivate =
2930 Stack->hasDSA(VD, isOpenMPPrivate, MatchesAlways());
2931 if (DVarPrivate.CKind != OMPC_unknown)
2932 return true;
2933 return false;
2934 }
2935 return false;
2936 }
VisitStmt(Stmt * S)2937 bool VisitStmt(Stmt *S) {
2938 for (auto Child : S->children()) {
2939 if (Child && Visit(Child))
2940 return true;
2941 }
2942 return false;
2943 }
DSARefChecker(DSAStackTy * S)2944 explicit DSARefChecker(DSAStackTy *S) : Stack(S) {}
2945 };
2946 } // namespace
2947
ActOnOpenMPReductionClause(ArrayRef<Expr * > VarList,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation ColonLoc,SourceLocation EndLoc,CXXScopeSpec & ReductionIdScopeSpec,const DeclarationNameInfo & ReductionId)2948 OMPClause *Sema::ActOnOpenMPReductionClause(
2949 ArrayRef<Expr *> VarList, SourceLocation StartLoc, SourceLocation LParenLoc,
2950 SourceLocation ColonLoc, SourceLocation EndLoc,
2951 CXXScopeSpec &ReductionIdScopeSpec,
2952 const DeclarationNameInfo &ReductionId) {
2953 // TODO: Allow scope specification search when 'declare reduction' is
2954 // supported.
2955 assert(ReductionIdScopeSpec.isEmpty() &&
2956 "No support for scoped reduction identifiers yet.");
2957
2958 auto DN = ReductionId.getName();
2959 auto OOK = DN.getCXXOverloadedOperator();
2960 BinaryOperatorKind BOK = BO_Comma;
2961
2962 // OpenMP [2.14.3.6, reduction clause]
2963 // C
2964 // reduction-identifier is either an identifier or one of the following
2965 // operators: +, -, *, &, |, ^, && and ||
2966 // C++
2967 // reduction-identifier is either an id-expression or one of the following
2968 // operators: +, -, *, &, |, ^, && and ||
2969 // FIXME: Only 'min' and 'max' identifiers are supported for now.
2970 switch (OOK) {
2971 case OO_Plus:
2972 case OO_Minus:
2973 BOK = BO_AddAssign;
2974 break;
2975 case OO_Star:
2976 BOK = BO_MulAssign;
2977 break;
2978 case OO_Amp:
2979 BOK = BO_AndAssign;
2980 break;
2981 case OO_Pipe:
2982 BOK = BO_OrAssign;
2983 break;
2984 case OO_Caret:
2985 BOK = BO_XorAssign;
2986 break;
2987 case OO_AmpAmp:
2988 BOK = BO_LAnd;
2989 break;
2990 case OO_PipePipe:
2991 BOK = BO_LOr;
2992 break;
2993 default:
2994 if (auto II = DN.getAsIdentifierInfo()) {
2995 if (II->isStr("max"))
2996 BOK = BO_GT;
2997 else if (II->isStr("min"))
2998 BOK = BO_LT;
2999 }
3000 break;
3001 }
3002 SourceRange ReductionIdRange;
3003 if (ReductionIdScopeSpec.isValid()) {
3004 ReductionIdRange.setBegin(ReductionIdScopeSpec.getBeginLoc());
3005 }
3006 ReductionIdRange.setEnd(ReductionId.getEndLoc());
3007 if (BOK == BO_Comma) {
3008 // Not allowed reduction identifier is found.
3009 Diag(ReductionId.getLocStart(), diag::err_omp_unknown_reduction_identifier)
3010 << ReductionIdRange;
3011 return nullptr;
3012 }
3013
3014 SmallVector<Expr *, 8> Vars;
3015 for (auto RefExpr : VarList) {
3016 assert(RefExpr && "nullptr expr in OpenMP reduction clause.");
3017 if (isa<DependentScopeDeclRefExpr>(RefExpr)) {
3018 // It will be analyzed later.
3019 Vars.push_back(RefExpr);
3020 continue;
3021 }
3022
3023 if (RefExpr->isTypeDependent() || RefExpr->isValueDependent() ||
3024 RefExpr->isInstantiationDependent() ||
3025 RefExpr->containsUnexpandedParameterPack()) {
3026 // It will be analyzed later.
3027 Vars.push_back(RefExpr);
3028 continue;
3029 }
3030
3031 auto ELoc = RefExpr->getExprLoc();
3032 auto ERange = RefExpr->getSourceRange();
3033 // OpenMP [2.1, C/C++]
3034 // A list item is a variable or array section, subject to the restrictions
3035 // specified in Section 2.4 on page 42 and in each of the sections
3036 // describing clauses and directives for which a list appears.
3037 // OpenMP [2.14.3.3, Restrictions, p.1]
3038 // A variable that is part of another variable (as an array or
3039 // structure element) cannot appear in a private clause.
3040 auto DE = dyn_cast<DeclRefExpr>(RefExpr);
3041 if (!DE || !isa<VarDecl>(DE->getDecl())) {
3042 Diag(ELoc, diag::err_omp_expected_var_name) << ERange;
3043 continue;
3044 }
3045 auto D = DE->getDecl();
3046 auto VD = cast<VarDecl>(D);
3047 auto Type = VD->getType();
3048 // OpenMP [2.9.3.3, Restrictions, C/C++, p.3]
3049 // A variable that appears in a private clause must not have an incomplete
3050 // type or a reference type.
3051 if (RequireCompleteType(ELoc, Type,
3052 diag::err_omp_reduction_incomplete_type))
3053 continue;
3054 // OpenMP [2.14.3.6, reduction clause, Restrictions]
3055 // Arrays may not appear in a reduction clause.
3056 if (Type.getNonReferenceType()->isArrayType()) {
3057 Diag(ELoc, diag::err_omp_reduction_type_array) << Type << ERange;
3058 bool IsDecl =
3059 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
3060 Diag(VD->getLocation(),
3061 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
3062 << VD;
3063 continue;
3064 }
3065 // OpenMP [2.14.3.6, reduction clause, Restrictions]
3066 // A list item that appears in a reduction clause must not be
3067 // const-qualified.
3068 if (Type.getNonReferenceType().isConstant(Context)) {
3069 Diag(ELoc, diag::err_omp_const_variable)
3070 << getOpenMPClauseName(OMPC_reduction) << Type << ERange;
3071 bool IsDecl =
3072 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
3073 Diag(VD->getLocation(),
3074 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
3075 << VD;
3076 continue;
3077 }
3078 // OpenMP [2.9.3.6, Restrictions, C/C++, p.4]
3079 // If a list-item is a reference type then it must bind to the same object
3080 // for all threads of the team.
3081 VarDecl *VDDef = VD->getDefinition();
3082 if (Type->isReferenceType() && VDDef) {
3083 DSARefChecker Check(DSAStack);
3084 if (Check.Visit(VDDef->getInit())) {
3085 Diag(ELoc, diag::err_omp_reduction_ref_type_arg) << ERange;
3086 Diag(VDDef->getLocation(), diag::note_defined_here) << VDDef;
3087 continue;
3088 }
3089 }
3090 // OpenMP [2.14.3.6, reduction clause, Restrictions]
3091 // The type of a list item that appears in a reduction clause must be valid
3092 // for the reduction-identifier. For a max or min reduction in C, the type
3093 // of the list item must be an allowed arithmetic data type: char, int,
3094 // float, double, or _Bool, possibly modified with long, short, signed, or
3095 // unsigned. For a max or min reduction in C++, the type of the list item
3096 // must be an allowed arithmetic data type: char, wchar_t, int, float,
3097 // double, or bool, possibly modified with long, short, signed, or unsigned.
3098 if ((BOK == BO_GT || BOK == BO_LT) &&
3099 !(Type->isScalarType() ||
3100 (getLangOpts().CPlusPlus && Type->isArithmeticType()))) {
3101 Diag(ELoc, diag::err_omp_clause_not_arithmetic_type_arg)
3102 << getLangOpts().CPlusPlus;
3103 bool IsDecl =
3104 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
3105 Diag(VD->getLocation(),
3106 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
3107 << VD;
3108 continue;
3109 }
3110 if ((BOK == BO_OrAssign || BOK == BO_AndAssign || BOK == BO_XorAssign) &&
3111 !getLangOpts().CPlusPlus && Type->isFloatingType()) {
3112 Diag(ELoc, diag::err_omp_clause_floating_type_arg);
3113 bool IsDecl =
3114 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
3115 Diag(VD->getLocation(),
3116 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
3117 << VD;
3118 continue;
3119 }
3120 bool Suppress = getDiagnostics().getSuppressAllDiagnostics();
3121 getDiagnostics().setSuppressAllDiagnostics(true);
3122 ExprResult ReductionOp =
3123 BuildBinOp(DSAStack->getCurScope(), ReductionId.getLocStart(), BOK,
3124 RefExpr, RefExpr);
3125 getDiagnostics().setSuppressAllDiagnostics(Suppress);
3126 if (ReductionOp.isInvalid()) {
3127 Diag(ELoc, diag::err_omp_reduction_id_not_compatible) << Type
3128 << ReductionIdRange;
3129 bool IsDecl =
3130 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
3131 Diag(VD->getLocation(),
3132 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
3133 << VD;
3134 continue;
3135 }
3136
3137 // OpenMP [2.14.1.1, Data-sharing Attribute Rules for Variables Referenced
3138 // in a Construct]
3139 // Variables with the predetermined data-sharing attributes may not be
3140 // listed in data-sharing attributes clauses, except for the cases
3141 // listed below. For these exceptions only, listing a predetermined
3142 // variable in a data-sharing attribute clause is allowed and overrides
3143 // the variable's predetermined data-sharing attributes.
3144 // OpenMP [2.14.3.6, Restrictions, p.3]
3145 // Any number of reduction clauses can be specified on the directive,
3146 // but a list item can appear only once in the reduction clauses for that
3147 // directive.
3148 DSAStackTy::DSAVarData DVar = DSAStack->getTopDSA(VD);
3149 if (DVar.CKind == OMPC_reduction) {
3150 Diag(ELoc, diag::err_omp_once_referenced)
3151 << getOpenMPClauseName(OMPC_reduction);
3152 if (DVar.RefExpr) {
3153 Diag(DVar.RefExpr->getExprLoc(), diag::note_omp_referenced);
3154 }
3155 } else if (DVar.CKind != OMPC_unknown) {
3156 Diag(ELoc, diag::err_omp_wrong_dsa)
3157 << getOpenMPClauseName(DVar.CKind)
3158 << getOpenMPClauseName(OMPC_reduction);
3159 ReportOriginalDSA(*this, DSAStack, VD, DVar);
3160 continue;
3161 }
3162
3163 // OpenMP [2.14.3.6, Restrictions, p.1]
3164 // A list item that appears in a reduction clause of a worksharing
3165 // construct must be shared in the parallel regions to which any of the
3166 // worksharing regions arising from the worksharing construct bind.
3167 OpenMPDirectiveKind CurrDir = DSAStack->getCurrentDirective();
3168 if (isOpenMPWorksharingDirective(CurrDir) &&
3169 !isOpenMPParallelDirective(CurrDir)) {
3170 DVar = DSAStack->getImplicitDSA(VD);
3171 if (DVar.CKind != OMPC_shared) {
3172 Diag(ELoc, diag::err_omp_required_access)
3173 << getOpenMPClauseName(OMPC_reduction)
3174 << getOpenMPClauseName(OMPC_shared);
3175 ReportOriginalDSA(*this, DSAStack, VD, DVar);
3176 continue;
3177 }
3178 }
3179
3180 CXXRecordDecl *RD = getLangOpts().CPlusPlus
3181 ? Type.getNonReferenceType()->getAsCXXRecordDecl()
3182 : nullptr;
3183 // FIXME This code must be replaced by actual constructing/destructing of
3184 // the reduction variable.
3185 if (RD) {
3186 CXXConstructorDecl *CD = LookupDefaultConstructor(RD);
3187 PartialDiagnostic PD =
3188 PartialDiagnostic(PartialDiagnostic::NullDiagnostic());
3189 if (!CD ||
3190 CheckConstructorAccess(ELoc, CD,
3191 InitializedEntity::InitializeTemporary(Type),
3192 CD->getAccess(), PD) == AR_inaccessible ||
3193 CD->isDeleted()) {
3194 Diag(ELoc, diag::err_omp_required_method)
3195 << getOpenMPClauseName(OMPC_reduction) << 0;
3196 bool IsDecl = VD->isThisDeclarationADefinition(Context) ==
3197 VarDecl::DeclarationOnly;
3198 Diag(VD->getLocation(),
3199 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
3200 << VD;
3201 Diag(RD->getLocation(), diag::note_previous_decl) << RD;
3202 continue;
3203 }
3204 MarkFunctionReferenced(ELoc, CD);
3205 DiagnoseUseOfDecl(CD, ELoc);
3206
3207 CXXDestructorDecl *DD = RD->getDestructor();
3208 if (DD) {
3209 if (CheckDestructorAccess(ELoc, DD, PD) == AR_inaccessible ||
3210 DD->isDeleted()) {
3211 Diag(ELoc, diag::err_omp_required_method)
3212 << getOpenMPClauseName(OMPC_reduction) << 4;
3213 bool IsDecl = VD->isThisDeclarationADefinition(Context) ==
3214 VarDecl::DeclarationOnly;
3215 Diag(VD->getLocation(),
3216 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
3217 << VD;
3218 Diag(RD->getLocation(), diag::note_previous_decl) << RD;
3219 continue;
3220 }
3221 MarkFunctionReferenced(ELoc, DD);
3222 DiagnoseUseOfDecl(DD, ELoc);
3223 }
3224 }
3225
3226 DSAStack->addDSA(VD, DE, OMPC_reduction);
3227 Vars.push_back(DE);
3228 }
3229
3230 if (Vars.empty())
3231 return nullptr;
3232
3233 return OMPReductionClause::Create(
3234 Context, StartLoc, LParenLoc, ColonLoc, EndLoc, Vars,
3235 ReductionIdScopeSpec.getWithLocInContext(Context), ReductionId);
3236 }
3237
ActOnOpenMPLinearClause(ArrayRef<Expr * > VarList,Expr * Step,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation ColonLoc,SourceLocation EndLoc)3238 OMPClause *Sema::ActOnOpenMPLinearClause(ArrayRef<Expr *> VarList, Expr *Step,
3239 SourceLocation StartLoc,
3240 SourceLocation LParenLoc,
3241 SourceLocation ColonLoc,
3242 SourceLocation EndLoc) {
3243 SmallVector<Expr *, 8> Vars;
3244 for (auto &RefExpr : VarList) {
3245 assert(RefExpr && "NULL expr in OpenMP linear clause.");
3246 if (isa<DependentScopeDeclRefExpr>(RefExpr)) {
3247 // It will be analyzed later.
3248 Vars.push_back(RefExpr);
3249 continue;
3250 }
3251
3252 // OpenMP [2.14.3.7, linear clause]
3253 // A list item that appears in a linear clause is subject to the private
3254 // clause semantics described in Section 2.14.3.3 on page 159 except as
3255 // noted. In addition, the value of the new list item on each iteration
3256 // of the associated loop(s) corresponds to the value of the original
3257 // list item before entering the construct plus the logical number of
3258 // the iteration times linear-step.
3259
3260 SourceLocation ELoc = RefExpr->getExprLoc();
3261 // OpenMP [2.1, C/C++]
3262 // A list item is a variable name.
3263 // OpenMP [2.14.3.3, Restrictions, p.1]
3264 // A variable that is part of another variable (as an array or
3265 // structure element) cannot appear in a private clause.
3266 DeclRefExpr *DE = dyn_cast<DeclRefExpr>(RefExpr);
3267 if (!DE || !isa<VarDecl>(DE->getDecl())) {
3268 Diag(ELoc, diag::err_omp_expected_var_name) << RefExpr->getSourceRange();
3269 continue;
3270 }
3271
3272 VarDecl *VD = cast<VarDecl>(DE->getDecl());
3273
3274 // OpenMP [2.14.3.7, linear clause]
3275 // A list-item cannot appear in more than one linear clause.
3276 // A list-item that appears in a linear clause cannot appear in any
3277 // other data-sharing attribute clause.
3278 DSAStackTy::DSAVarData DVar = DSAStack->getTopDSA(VD);
3279 if (DVar.RefExpr) {
3280 Diag(ELoc, diag::err_omp_wrong_dsa) << getOpenMPClauseName(DVar.CKind)
3281 << getOpenMPClauseName(OMPC_linear);
3282 ReportOriginalDSA(*this, DSAStack, VD, DVar);
3283 continue;
3284 }
3285
3286 QualType QType = VD->getType();
3287 if (QType->isDependentType() || QType->isInstantiationDependentType()) {
3288 // It will be analyzed later.
3289 Vars.push_back(DE);
3290 continue;
3291 }
3292
3293 // A variable must not have an incomplete type or a reference type.
3294 if (RequireCompleteType(ELoc, QType,
3295 diag::err_omp_linear_incomplete_type)) {
3296 continue;
3297 }
3298 if (QType->isReferenceType()) {
3299 Diag(ELoc, diag::err_omp_clause_ref_type_arg)
3300 << getOpenMPClauseName(OMPC_linear) << QType;
3301 bool IsDecl =
3302 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
3303 Diag(VD->getLocation(),
3304 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
3305 << VD;
3306 continue;
3307 }
3308
3309 // A list item must not be const-qualified.
3310 if (QType.isConstant(Context)) {
3311 Diag(ELoc, diag::err_omp_const_variable)
3312 << getOpenMPClauseName(OMPC_linear);
3313 bool IsDecl =
3314 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
3315 Diag(VD->getLocation(),
3316 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
3317 << VD;
3318 continue;
3319 }
3320
3321 // A list item must be of integral or pointer type.
3322 QType = QType.getUnqualifiedType().getCanonicalType();
3323 const Type *Ty = QType.getTypePtrOrNull();
3324 if (!Ty || (!Ty->isDependentType() && !Ty->isIntegralType(Context) &&
3325 !Ty->isPointerType())) {
3326 Diag(ELoc, diag::err_omp_linear_expected_int_or_ptr) << QType;
3327 bool IsDecl =
3328 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
3329 Diag(VD->getLocation(),
3330 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
3331 << VD;
3332 continue;
3333 }
3334
3335 DSAStack->addDSA(VD, DE, OMPC_linear);
3336 Vars.push_back(DE);
3337 }
3338
3339 if (Vars.empty())
3340 return nullptr;
3341
3342 Expr *StepExpr = Step;
3343 if (Step && !Step->isValueDependent() && !Step->isTypeDependent() &&
3344 !Step->isInstantiationDependent() &&
3345 !Step->containsUnexpandedParameterPack()) {
3346 SourceLocation StepLoc = Step->getLocStart();
3347 ExprResult Val = PerformOpenMPImplicitIntegerConversion(StepLoc, Step);
3348 if (Val.isInvalid())
3349 return nullptr;
3350 StepExpr = Val.get();
3351
3352 // Warn about zero linear step (it would be probably better specified as
3353 // making corresponding variables 'const').
3354 llvm::APSInt Result;
3355 if (StepExpr->isIntegerConstantExpr(Result, Context) &&
3356 !Result.isNegative() && !Result.isStrictlyPositive())
3357 Diag(StepLoc, diag::warn_omp_linear_step_zero) << Vars[0]
3358 << (Vars.size() > 1);
3359 }
3360
3361 return OMPLinearClause::Create(Context, StartLoc, LParenLoc, ColonLoc, EndLoc,
3362 Vars, StepExpr);
3363 }
3364
ActOnOpenMPAlignedClause(ArrayRef<Expr * > VarList,Expr * Alignment,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation ColonLoc,SourceLocation EndLoc)3365 OMPClause *Sema::ActOnOpenMPAlignedClause(
3366 ArrayRef<Expr *> VarList, Expr *Alignment, SourceLocation StartLoc,
3367 SourceLocation LParenLoc, SourceLocation ColonLoc, SourceLocation EndLoc) {
3368
3369 SmallVector<Expr *, 8> Vars;
3370 for (auto &RefExpr : VarList) {
3371 assert(RefExpr && "NULL expr in OpenMP aligned clause.");
3372 if (isa<DependentScopeDeclRefExpr>(RefExpr)) {
3373 // It will be analyzed later.
3374 Vars.push_back(RefExpr);
3375 continue;
3376 }
3377
3378 SourceLocation ELoc = RefExpr->getExprLoc();
3379 // OpenMP [2.1, C/C++]
3380 // A list item is a variable name.
3381 DeclRefExpr *DE = dyn_cast<DeclRefExpr>(RefExpr);
3382 if (!DE || !isa<VarDecl>(DE->getDecl())) {
3383 Diag(ELoc, diag::err_omp_expected_var_name) << RefExpr->getSourceRange();
3384 continue;
3385 }
3386
3387 VarDecl *VD = cast<VarDecl>(DE->getDecl());
3388
3389 // OpenMP [2.8.1, simd construct, Restrictions]
3390 // The type of list items appearing in the aligned clause must be
3391 // array, pointer, reference to array, or reference to pointer.
3392 QualType QType = DE->getType()
3393 .getNonReferenceType()
3394 .getUnqualifiedType()
3395 .getCanonicalType();
3396 const Type *Ty = QType.getTypePtrOrNull();
3397 if (!Ty || (!Ty->isDependentType() && !Ty->isArrayType() &&
3398 !Ty->isPointerType())) {
3399 Diag(ELoc, diag::err_omp_aligned_expected_array_or_ptr)
3400 << QType << getLangOpts().CPlusPlus << RefExpr->getSourceRange();
3401 bool IsDecl =
3402 VD->isThisDeclarationADefinition(Context) == VarDecl::DeclarationOnly;
3403 Diag(VD->getLocation(),
3404 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
3405 << VD;
3406 continue;
3407 }
3408
3409 // OpenMP [2.8.1, simd construct, Restrictions]
3410 // A list-item cannot appear in more than one aligned clause.
3411 if (DeclRefExpr *PrevRef = DSAStack->addUniqueAligned(VD, DE)) {
3412 Diag(ELoc, diag::err_omp_aligned_twice) << RefExpr->getSourceRange();
3413 Diag(PrevRef->getExprLoc(), diag::note_omp_explicit_dsa)
3414 << getOpenMPClauseName(OMPC_aligned);
3415 continue;
3416 }
3417
3418 Vars.push_back(DE);
3419 }
3420
3421 // OpenMP [2.8.1, simd construct, Description]
3422 // The parameter of the aligned clause, alignment, must be a constant
3423 // positive integer expression.
3424 // If no optional parameter is specified, implementation-defined default
3425 // alignments for SIMD instructions on the target platforms are assumed.
3426 if (Alignment != nullptr) {
3427 ExprResult AlignResult =
3428 VerifyPositiveIntegerConstantInClause(Alignment, OMPC_aligned);
3429 if (AlignResult.isInvalid())
3430 return nullptr;
3431 Alignment = AlignResult.get();
3432 }
3433 if (Vars.empty())
3434 return nullptr;
3435
3436 return OMPAlignedClause::Create(Context, StartLoc, LParenLoc, ColonLoc,
3437 EndLoc, Vars, Alignment);
3438 }
3439
ActOnOpenMPCopyinClause(ArrayRef<Expr * > VarList,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)3440 OMPClause *Sema::ActOnOpenMPCopyinClause(ArrayRef<Expr *> VarList,
3441 SourceLocation StartLoc,
3442 SourceLocation LParenLoc,
3443 SourceLocation EndLoc) {
3444 SmallVector<Expr *, 8> Vars;
3445 for (auto &RefExpr : VarList) {
3446 assert(RefExpr && "NULL expr in OpenMP copyin clause.");
3447 if (isa<DependentScopeDeclRefExpr>(RefExpr)) {
3448 // It will be analyzed later.
3449 Vars.push_back(RefExpr);
3450 continue;
3451 }
3452
3453 SourceLocation ELoc = RefExpr->getExprLoc();
3454 // OpenMP [2.1, C/C++]
3455 // A list item is a variable name.
3456 // OpenMP [2.14.4.1, Restrictions, p.1]
3457 // A list item that appears in a copyin clause must be threadprivate.
3458 DeclRefExpr *DE = dyn_cast<DeclRefExpr>(RefExpr);
3459 if (!DE || !isa<VarDecl>(DE->getDecl())) {
3460 Diag(ELoc, diag::err_omp_expected_var_name) << RefExpr->getSourceRange();
3461 continue;
3462 }
3463
3464 Decl *D = DE->getDecl();
3465 VarDecl *VD = cast<VarDecl>(D);
3466
3467 QualType Type = VD->getType();
3468 if (Type->isDependentType() || Type->isInstantiationDependentType()) {
3469 // It will be analyzed later.
3470 Vars.push_back(DE);
3471 continue;
3472 }
3473
3474 // OpenMP [2.14.4.1, Restrictions, C/C++, p.1]
3475 // A list item that appears in a copyin clause must be threadprivate.
3476 if (!DSAStack->isThreadPrivate(VD)) {
3477 Diag(ELoc, diag::err_omp_required_access)
3478 << getOpenMPClauseName(OMPC_copyin)
3479 << getOpenMPDirectiveName(OMPD_threadprivate);
3480 continue;
3481 }
3482
3483 // OpenMP [2.14.4.1, Restrictions, C/C++, p.2]
3484 // A variable of class type (or array thereof) that appears in a
3485 // copyin clause requires an accessible, unambiguous copy assignment
3486 // operator for the class type.
3487 Type = Context.getBaseElementType(Type);
3488 CXXRecordDecl *RD =
3489 getLangOpts().CPlusPlus ? Type->getAsCXXRecordDecl() : nullptr;
3490 // FIXME This code must be replaced by actual assignment of the
3491 // threadprivate variable.
3492 if (RD) {
3493 CXXMethodDecl *MD = LookupCopyingAssignment(RD, 0, false, 0);
3494 DeclAccessPair FoundDecl = DeclAccessPair::make(MD, MD->getAccess());
3495 if (MD) {
3496 if (CheckMemberAccess(ELoc, RD, FoundDecl) == AR_inaccessible ||
3497 MD->isDeleted()) {
3498 Diag(ELoc, diag::err_omp_required_method)
3499 << getOpenMPClauseName(OMPC_copyin) << 2;
3500 bool IsDecl = VD->isThisDeclarationADefinition(Context) ==
3501 VarDecl::DeclarationOnly;
3502 Diag(VD->getLocation(),
3503 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
3504 << VD;
3505 Diag(RD->getLocation(), diag::note_previous_decl) << RD;
3506 continue;
3507 }
3508 MarkFunctionReferenced(ELoc, MD);
3509 DiagnoseUseOfDecl(MD, ELoc);
3510 }
3511 }
3512
3513 DSAStack->addDSA(VD, DE, OMPC_copyin);
3514 Vars.push_back(DE);
3515 }
3516
3517 if (Vars.empty())
3518 return nullptr;
3519
3520 return OMPCopyinClause::Create(Context, StartLoc, LParenLoc, EndLoc, Vars);
3521 }
3522
ActOnOpenMPCopyprivateClause(ArrayRef<Expr * > VarList,SourceLocation StartLoc,SourceLocation LParenLoc,SourceLocation EndLoc)3523 OMPClause *Sema::ActOnOpenMPCopyprivateClause(ArrayRef<Expr *> VarList,
3524 SourceLocation StartLoc,
3525 SourceLocation LParenLoc,
3526 SourceLocation EndLoc) {
3527 SmallVector<Expr *, 8> Vars;
3528 for (auto &RefExpr : VarList) {
3529 assert(RefExpr && "NULL expr in OpenMP copyprivate clause.");
3530 if (isa<DependentScopeDeclRefExpr>(RefExpr)) {
3531 // It will be analyzed later.
3532 Vars.push_back(RefExpr);
3533 continue;
3534 }
3535
3536 SourceLocation ELoc = RefExpr->getExprLoc();
3537 // OpenMP [2.1, C/C++]
3538 // A list item is a variable name.
3539 // OpenMP [2.14.4.1, Restrictions, p.1]
3540 // A list item that appears in a copyin clause must be threadprivate.
3541 DeclRefExpr *DE = dyn_cast<DeclRefExpr>(RefExpr);
3542 if (!DE || !isa<VarDecl>(DE->getDecl())) {
3543 Diag(ELoc, diag::err_omp_expected_var_name) << RefExpr->getSourceRange();
3544 continue;
3545 }
3546
3547 Decl *D = DE->getDecl();
3548 VarDecl *VD = cast<VarDecl>(D);
3549
3550 QualType Type = VD->getType();
3551 if (Type->isDependentType() || Type->isInstantiationDependentType()) {
3552 // It will be analyzed later.
3553 Vars.push_back(DE);
3554 continue;
3555 }
3556
3557 // OpenMP [2.14.4.2, Restrictions, p.2]
3558 // A list item that appears in a copyprivate clause may not appear in a
3559 // private or firstprivate clause on the single construct.
3560 if (!DSAStack->isThreadPrivate(VD)) {
3561 auto DVar = DSAStack->getTopDSA(VD);
3562 if (DVar.CKind != OMPC_copyprivate && DVar.CKind != OMPC_unknown &&
3563 !(DVar.CKind == OMPC_private && !DVar.RefExpr)) {
3564 Diag(ELoc, diag::err_omp_wrong_dsa)
3565 << getOpenMPClauseName(DVar.CKind)
3566 << getOpenMPClauseName(OMPC_copyprivate);
3567 ReportOriginalDSA(*this, DSAStack, VD, DVar);
3568 continue;
3569 }
3570
3571 // OpenMP [2.11.4.2, Restrictions, p.1]
3572 // All list items that appear in a copyprivate clause must be either
3573 // threadprivate or private in the enclosing context.
3574 if (DVar.CKind == OMPC_unknown) {
3575 DVar = DSAStack->getImplicitDSA(VD);
3576 if (DVar.CKind == OMPC_shared) {
3577 Diag(ELoc, diag::err_omp_required_access)
3578 << getOpenMPClauseName(OMPC_copyprivate)
3579 << "threadprivate or private in the enclosing context";
3580 ReportOriginalDSA(*this, DSAStack, VD, DVar);
3581 continue;
3582 }
3583 }
3584 }
3585
3586 // OpenMP [2.14.4.1, Restrictions, C/C++, p.2]
3587 // A variable of class type (or array thereof) that appears in a
3588 // copyin clause requires an accessible, unambiguous copy assignment
3589 // operator for the class type.
3590 Type = Context.getBaseElementType(Type);
3591 CXXRecordDecl *RD =
3592 getLangOpts().CPlusPlus ? Type->getAsCXXRecordDecl() : nullptr;
3593 // FIXME This code must be replaced by actual assignment of the
3594 // threadprivate variable.
3595 if (RD) {
3596 CXXMethodDecl *MD = LookupCopyingAssignment(RD, 0, false, 0);
3597 DeclAccessPair FoundDecl = DeclAccessPair::make(MD, MD->getAccess());
3598 if (MD) {
3599 if (CheckMemberAccess(ELoc, RD, FoundDecl) == AR_inaccessible ||
3600 MD->isDeleted()) {
3601 Diag(ELoc, diag::err_omp_required_method)
3602 << getOpenMPClauseName(OMPC_copyprivate) << 2;
3603 bool IsDecl = VD->isThisDeclarationADefinition(Context) ==
3604 VarDecl::DeclarationOnly;
3605 Diag(VD->getLocation(),
3606 IsDecl ? diag::note_previous_decl : diag::note_defined_here)
3607 << VD;
3608 Diag(RD->getLocation(), diag::note_previous_decl) << RD;
3609 continue;
3610 }
3611 MarkFunctionReferenced(ELoc, MD);
3612 DiagnoseUseOfDecl(MD, ELoc);
3613 }
3614 }
3615
3616 // No need to mark vars as copyprivate, they are already threadprivate or
3617 // implicitly private.
3618 Vars.push_back(DE);
3619 }
3620
3621 if (Vars.empty())
3622 return nullptr;
3623
3624 return OMPCopyprivateClause::Create(Context, StartLoc, LParenLoc, EndLoc, Vars);
3625 }
3626
3627 #undef DSAStack
3628