23#include "llvm/ADT/Sequence.h"
24#include "llvm/ADT/SmallPtrSet.h"
25#include "llvm/Support/ErrorHandling.h"
38#define GEN_CLANG_CLAUSE_CLASS
39#define CLAUSE_CLASS(Enum, Str, Class) \
41 return static_cast<Class *>(this)->children();
42#include "llvm/Frontend/OpenMP/OMP.inc"
44 llvm_unreachable(
"unknown OMPClause");
49#define GEN_CLANG_CLAUSE_CLASS
50#define CLAUSE_CLASS(Enum, Str, Class) \
52 return static_cast<Class *>(this)->used_children();
53#define CLAUSE_NO_CLASS(Enum, Str) \
56#include "llvm/Frontend/OpenMP/OMP.inc"
58 llvm_unreachable(
"unknown OMPClause");
67 switch (
C->getClauseKind()) {
69 return static_cast<const OMPScheduleClause *
>(
C);
70 case OMPC_dist_schedule:
72 case OMPC_firstprivate:
73 return static_cast<const OMPFirstprivateClause *
>(
C);
74 case OMPC_lastprivate:
75 return static_cast<const OMPLastprivateClause *
>(
C);
77 return static_cast<const OMPReductionClause *
>(
C);
78 case OMPC_task_reduction:
79 return static_cast<const OMPTaskReductionClause *
>(
C);
80 case OMPC_in_reduction:
81 return static_cast<const OMPInReductionClause *
>(
C);
83 return static_cast<const OMPLinearClause *
>(
C);
86 case OMPC_num_threads:
90 case OMPC_thread_limit:
102 case OMPC_novariants:
108 case OMPC_ompx_dyn_cgroup_mem:
110 case OMPC_dyn_groupprivate:
113 return static_cast<const OMPMessageClause *
>(
C);
114 case OMPC_transparent:
115 return static_cast<const OMPTransparentClause *
>(
C);
128 case OMPC_copyprivate:
134 case OMPC_threadprivate:
135 case OMPC_groupprivate:
155 case OMPC_defaultmap:
160 case OMPC_use_device_ptr:
161 case OMPC_use_device_addr:
162 case OMPC_is_device_ptr:
163 case OMPC_has_device_addr:
164 case OMPC_unified_address:
165 case OMPC_unified_shared_memory:
166 case OMPC_reverse_offload:
167 case OMPC_dynamic_allocators:
168 case OMPC_atomic_default_mem_order:
172 case OMPC_device_type:
174 case OMPC_nontemporal:
180 case OMPC_uses_allocators:
199 switch (
C->getClauseKind()) {
200 case OMPC_lastprivate:
201 return static_cast<const OMPLastprivateClause *
>(
C);
203 return static_cast<const OMPReductionClause *
>(
C);
204 case OMPC_task_reduction:
205 return static_cast<const OMPTaskReductionClause *
>(
C);
206 case OMPC_in_reduction:
207 return static_cast<const OMPInReductionClause *
>(
C);
209 return static_cast<const OMPLinearClause *
>(
C);
211 case OMPC_dist_schedule:
212 case OMPC_firstprivate:
217 case OMPC_num_threads:
228 case OMPC_copyprivate:
233 case OMPC_threadprivate:
234 case OMPC_groupprivate:
254 case OMPC_thread_limit:
260 case OMPC_defaultmap:
265 case OMPC_use_device_ptr:
266 case OMPC_use_device_addr:
267 case OMPC_is_device_ptr:
268 case OMPC_has_device_addr:
269 case OMPC_unified_address:
270 case OMPC_unified_shared_memory:
271 case OMPC_reverse_offload:
272 case OMPC_dynamic_allocators:
273 case OMPC_atomic_default_mem_order:
278 case OMPC_device_type:
280 case OMPC_nontemporal:
283 case OMPC_novariants:
288 case OMPC_uses_allocators:
305 if (
auto *DS = dyn_cast<DeclStmt>(S)) {
306 assert(DS->isSingleDecl() &&
"Only single expression must be captured.");
307 if (
auto *OED = dyn_cast<OMPCapturedExprDecl>(DS->getSingleDecl()))
308 return OED->getInitAddress();
327 return child_range(
C,
C + 1);
328 return child_range(&Grainsize, &Grainsize + 1);
333 return child_range(
C,
C + 1);
334 return child_range(&NumTasks, &NumTasks + 1);
345 return child_range(
C,
C + 1);
346 return child_range(&Priority, &Priority + 1);
351 return child_range(
C,
C + 1);
357 return child_range(
C,
C + 1);
366 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(2 * NumLoops));
368 new (Mem) OMPOrderedClause(
Num, NumLoops, StartLoc, LParenLoc, EndLoc);
369 for (
unsigned I = 0; I < NumLoops; ++I) {
370 Clause->setLoopNumIterations(I,
nullptr);
371 Clause->setLoopCounter(I,
nullptr);
376OMPOrderedClause *OMPOrderedClause::CreateEmpty(
const ASTContext &
C,
378 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(2 * NumLoops));
379 auto *Clause =
new (Mem) OMPOrderedClause(NumLoops);
380 for (
unsigned I = 0; I < NumLoops; ++I) {
381 Clause->setLoopNumIterations(I,
nullptr);
382 Clause->setLoopCounter(I,
nullptr);
387void OMPOrderedClause::setLoopNumIterations(
unsigned NumLoop,
388 Expr *NumIterations) {
389 assert(NumLoop < NumberOfLoops &&
"out of loops number.");
390 getTrailingObjects()[NumLoop] = NumIterations;
394 return getTrailingObjects(NumberOfLoops);
397void OMPOrderedClause::setLoopCounter(
unsigned NumLoop,
Expr *Counter) {
398 assert(NumLoop < NumberOfLoops &&
"out of loops number.");
399 getTrailingObjects()[NumberOfLoops + NumLoop] = Counter;
402Expr *OMPOrderedClause::getLoopCounter(
unsigned NumLoop) {
403 assert(NumLoop < NumberOfLoops &&
"out of loops number.");
404 return getTrailingObjects()[NumberOfLoops + NumLoop];
407const Expr *OMPOrderedClause::getLoopCounter(
unsigned NumLoop)
const {
408 assert(NumLoop < NumberOfLoops &&
"out of loops number.");
409 return getTrailingObjects()[NumberOfLoops + NumLoop];
412OMPUpdateClause *OMPUpdateClause::Create(
const ASTContext &
C,
415 return new (
C) OMPUpdateClause(StartLoc, EndLoc,
false);
423 C.Allocate(totalSizeToAlloc<SourceLocation, OpenMPDependClauseKind>(2, 1),
424 alignof(OMPUpdateClause));
426 new (Mem) OMPUpdateClause(StartLoc, EndLoc,
true);
427 Clause->setLParenLoc(LParenLoc);
428 Clause->setArgumentLoc(ArgumentLoc);
429 Clause->setDependencyKind(DK);
433OMPUpdateClause *OMPUpdateClause::CreateEmpty(
const ASTContext &
C,
436 return new (
C) OMPUpdateClause(
false);
438 C.Allocate(totalSizeToAlloc<SourceLocation, OpenMPDependClauseKind>(2, 1),
439 alignof(OMPUpdateClause));
440 auto *Clause =
new (Mem) OMPUpdateClause(
true);
441 Clause->IsExtended =
true;
446 assert(VL.size() == varlist_size() &&
447 "Number of private copies is not the same as the preallocated buffer");
448 llvm::copy(VL, varlist_end());
456 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(2 * VL.size()));
457 OMPPrivateClause *Clause =
458 new (Mem) OMPPrivateClause(StartLoc, LParenLoc, EndLoc, VL.size());
459 Clause->setVarRefs(VL);
460 Clause->setPrivateCopies(PrivateVL);
464OMPPrivateClause *OMPPrivateClause::CreateEmpty(
const ASTContext &
C,
466 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(2 * N));
467 return new (Mem) OMPPrivateClause(N);
471 assert(VL.size() == varlist_size() &&
472 "Number of private copies is not the same as the preallocated buffer");
473 llvm::copy(VL, varlist_end());
477 assert(VL.size() == varlist_size() &&
478 "Number of inits is not the same as the preallocated buffer");
479 llvm::copy(VL, getPrivateCopies().end());
482OMPFirstprivateClause *
487 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(3 * VL.size()));
488 OMPFirstprivateClause *Clause =
489 new (Mem) OMPFirstprivateClause(StartLoc, LParenLoc, EndLoc, VL.size());
490 Clause->setVarRefs(VL);
491 Clause->setPrivateCopies(PrivateVL);
492 Clause->setInits(InitVL);
493 Clause->setPreInitStmt(PreInit);
497OMPFirstprivateClause *OMPFirstprivateClause::CreateEmpty(
const ASTContext &
C,
499 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(3 * N));
500 return new (Mem) OMPFirstprivateClause(N);
503void OMPLastprivateClause::setPrivateCopies(
ArrayRef<Expr *> PrivateCopies) {
504 assert(PrivateCopies.size() == varlist_size() &&
505 "Number of private copies is not the same as the preallocated buffer");
506 llvm::copy(PrivateCopies, varlist_end());
510 assert(SrcExprs.size() == varlist_size() &&
"Number of source expressions is "
511 "not the same as the "
512 "preallocated buffer");
513 llvm::copy(SrcExprs, getPrivateCopies().end());
517 assert(DstExprs.size() == varlist_size() &&
"Number of destination "
518 "expressions is not the same as "
519 "the preallocated buffer");
520 llvm::copy(DstExprs, getSourceExprs().end());
523void OMPLastprivateClause::setAssignmentOps(
ArrayRef<Expr *> AssignmentOps) {
524 assert(AssignmentOps.size() == varlist_size() &&
525 "Number of assignment expressions is not the same as the preallocated "
527 llvm::copy(AssignmentOps, getDestinationExprs().end());
530OMPLastprivateClause *OMPLastprivateClause::Create(
536 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(5 * VL.size()));
537 OMPLastprivateClause *Clause =
new (Mem) OMPLastprivateClause(
538 StartLoc, LParenLoc, EndLoc, LPKind, LPKindLoc, ColonLoc, VL.size());
539 Clause->setVarRefs(VL);
540 Clause->setSourceExprs(SrcExprs);
541 Clause->setDestinationExprs(DstExprs);
542 Clause->setAssignmentOps(AssignmentOps);
543 Clause->setPreInitStmt(PreInit);
544 Clause->setPostUpdateExpr(PostUpdate);
548OMPLastprivateClause *OMPLastprivateClause::CreateEmpty(
const ASTContext &
C,
550 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(5 * N));
551 return new (Mem) OMPLastprivateClause(N);
554OMPSharedClause *OMPSharedClause::Create(
const ASTContext &
C,
559 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(VL.size()));
560 OMPSharedClause *Clause =
561 new (Mem) OMPSharedClause(StartLoc, LParenLoc, EndLoc, VL.size());
562 Clause->setVarRefs(VL);
566OMPSharedClause *OMPSharedClause::CreateEmpty(
const ASTContext &
C,
unsigned N) {
567 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(N));
568 return new (Mem) OMPSharedClause(N);
572 assert(PL.size() == varlist_size() &&
573 "Number of privates is not the same as the preallocated buffer");
574 llvm::copy(PL, varlist_end());
578 assert(IL.size() == varlist_size() &&
579 "Number of inits is not the same as the preallocated buffer");
584 assert(UL.size() == varlist_size() &&
585 "Number of updates is not the same as the preallocated buffer");
590 assert(FL.size() == varlist_size() &&
591 "Number of final updates is not the same as the preallocated buffer");
597 UE.size() == varlist_size() + 1 &&
598 "Number of used expressions is not the same as the preallocated buffer");
602OMPLinearClause *OMPLinearClause::Create(
612 C.Allocate(totalSizeToAlloc<Expr *>(5 * VL.size() + 2 + VL.size() + 1));
613 OMPLinearClause *Clause =
614 new (Mem) OMPLinearClause(StartLoc, LParenLoc, Modifier, ModifierLoc,
615 ColonLoc, StepModifierLoc, EndLoc, VL.size());
616 Clause->setVarRefs(VL);
617 Clause->setPrivates(PL);
618 Clause->setInits(IL);
621 std::fill(Clause->getInits().end(), Clause->getInits().end() + VL.size(),
623 std::fill(Clause->getUpdates().end(), Clause->getUpdates().end() + VL.size(),
625 std::fill(Clause->getUsedExprs().begin(), Clause->getUsedExprs().end(),
627 Clause->setStep(Step);
628 Clause->setCalcStep(CalcStep);
629 Clause->setPreInitStmt(PreInit);
630 Clause->setPostUpdateExpr(PostUpdate);
634OMPLinearClause *OMPLinearClause::CreateEmpty(
const ASTContext &
C,
638 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(5 * NumVars + 2 + NumVars +1));
639 return new (Mem) OMPLinearClause(NumVars);
653 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(VL.size() + 1));
654 OMPAlignedClause *Clause =
new (Mem)
655 OMPAlignedClause(StartLoc, LParenLoc, ColonLoc, EndLoc, VL.size());
656 Clause->setVarRefs(VL);
657 Clause->setAlignment(A);
663 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(NumVars + 1));
664 return new (Mem) OMPAlignedClause(NumVars);
671 return new (
C) OMPAlignClause(A, StartLoc, LParenLoc, EndLoc);
675 assert(SrcExprs.size() == varlist_size() &&
"Number of source expressions is "
676 "not the same as the "
677 "preallocated buffer");
678 llvm::copy(SrcExprs, varlist_end());
682 assert(DstExprs.size() == varlist_size() &&
"Number of destination "
683 "expressions is not the same as "
684 "the preallocated buffer");
685 llvm::copy(DstExprs, getSourceExprs().end());
689 assert(AssignmentOps.size() == varlist_size() &&
690 "Number of assignment expressions is not the same as the preallocated "
692 llvm::copy(AssignmentOps, getDestinationExprs().end());
699 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(4 * VL.size()));
700 OMPCopyinClause *Clause =
701 new (Mem) OMPCopyinClause(StartLoc, LParenLoc, EndLoc, VL.size());
702 Clause->setVarRefs(VL);
703 Clause->setSourceExprs(SrcExprs);
704 Clause->setDestinationExprs(DstExprs);
705 Clause->setAssignmentOps(AssignmentOps);
710 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(4 * N));
711 return new (Mem) OMPCopyinClause(N);
715 assert(SrcExprs.size() == varlist_size() &&
"Number of source expressions is "
716 "not the same as the "
717 "preallocated buffer");
718 llvm::copy(SrcExprs, varlist_end());
722 assert(DstExprs.size() == varlist_size() &&
"Number of destination "
723 "expressions is not the same as "
724 "the preallocated buffer");
725 llvm::copy(DstExprs, getSourceExprs().end());
728void OMPCopyprivateClause::setAssignmentOps(
ArrayRef<Expr *> AssignmentOps) {
729 assert(AssignmentOps.size() == varlist_size() &&
730 "Number of assignment expressions is not the same as the preallocated "
732 llvm::copy(AssignmentOps, getDestinationExprs().end());
739 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(4 * VL.size()));
740 OMPCopyprivateClause *Clause =
741 new (Mem) OMPCopyprivateClause(StartLoc, LParenLoc, EndLoc, VL.size());
742 Clause->setVarRefs(VL);
743 Clause->setSourceExprs(SrcExprs);
744 Clause->setDestinationExprs(DstExprs);
745 Clause->setAssignmentOps(AssignmentOps);
751 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(4 * N));
752 return new (Mem) OMPCopyprivateClause(N);
756 assert(
Privates.size() == varlist_size() &&
757 "Number of private copies is not the same as the preallocated buffer");
758 llvm::copy(
Privates, varlist_end());
763 LHSExprs.size() == varlist_size() &&
764 "Number of LHS expressions is not the same as the preallocated buffer");
770 RHSExprs.size() == varlist_size() &&
771 "Number of RHS expressions is not the same as the preallocated buffer");
772 llvm::copy(RHSExprs, getLHSExprs().end());
776 assert(ReductionOps.size() == varlist_size() &&
"Number of reduction "
777 "expressions is not the same "
778 "as the preallocated buffer");
779 llvm::copy(ReductionOps, getRHSExprs().end());
783 assert(Modifier == OMPC_REDUCTION_inscan &&
"Expected inscan reduction.");
784 assert(Ops.size() == varlist_size() &&
"Number of copy "
785 "expressions is not the same "
786 "as the preallocated buffer");
787 llvm::copy(Ops, getReductionOps().end());
790void OMPReductionClause::setInscanCopyArrayTemps(
792 assert(Modifier == OMPC_REDUCTION_inscan &&
"Expected inscan reduction.");
793 assert(CopyArrayTemps.size() == varlist_size() &&
794 "Number of copy temp expressions is not the same as the preallocated "
796 llvm::copy(CopyArrayTemps, getInscanCopyOps().end());
799void OMPReductionClause::setInscanCopyArrayElems(
801 assert(Modifier == OMPC_REDUCTION_inscan &&
"Expected inscan reduction.");
802 assert(CopyArrayElems.size() == varlist_size() &&
803 "Number of copy temp expressions is not the same as the preallocated "
805 llvm::copy(CopyArrayElems, getInscanCopyArrayTemps().end());
808OMPReductionClause *OMPReductionClause::Create(
819 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *, bool>(
820 (Modifier == OMPC_REDUCTION_inscan ? 8 : 5) * VL.size(), VL.size()));
821 auto *Clause =
new (Mem) OMPReductionClause(
822 StartLoc, LParenLoc, ModifierLoc, EndLoc, ColonLoc, Modifier,
823 OrignalSharingModifier, VL.size(), QualifierLoc, NameInfo);
824 Clause->setVarRefs(VL);
826 Clause->setLHSExprs(LHSExprs);
827 Clause->setRHSExprs(RHSExprs);
828 Clause->setReductionOps(ReductionOps);
829 Clause->setPreInitStmt(PreInit);
830 Clause->setPostUpdateExpr(PostUpdate);
831 Clause->setPrivateVariableReductionFlags(IsPrivateVarReduction);
832 if (Modifier == OMPC_REDUCTION_inscan) {
833 Clause->setInscanCopyOps(CopyOps);
834 Clause->setInscanCopyArrayTemps(CopyArrayTemps);
835 Clause->setInscanCopyArrayElems(CopyArrayElems);
837 assert(CopyOps.empty() &&
838 "copy operations are expected in inscan reductions only.");
839 assert(CopyArrayTemps.empty() &&
840 "copy array temps are expected in inscan reductions only.");
841 assert(CopyArrayElems.empty() &&
842 "copy array temps are expected in inscan reductions only.");
848OMPReductionClause::CreateEmpty(
const ASTContext &
C,
unsigned N,
850 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *, bool>(
851 (Modifier == OMPC_REDUCTION_inscan ? 8 : 5) * N, N));
852 auto *Clause =
new (Mem) OMPReductionClause(N);
853 Clause->setModifier(Modifier);
858 assert(
Privates.size() == varlist_size() &&
859 "Number of private copies is not the same as the preallocated buffer");
860 llvm::copy(
Privates, varlist_end());
865 LHSExprs.size() == varlist_size() &&
866 "Number of LHS expressions is not the same as the preallocated buffer");
872 RHSExprs.size() == varlist_size() &&
873 "Number of RHS expressions is not the same as the preallocated buffer");
874 llvm::copy(RHSExprs, getLHSExprs().end());
877void OMPTaskReductionClause::setReductionOps(
ArrayRef<Expr *> ReductionOps) {
878 assert(ReductionOps.size() == varlist_size() &&
"Number of task reduction "
879 "expressions is not the same "
880 "as the preallocated buffer");
881 llvm::copy(ReductionOps, getRHSExprs().end());
884OMPTaskReductionClause *OMPTaskReductionClause::Create(
891 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(5 * VL.size()));
892 OMPTaskReductionClause *Clause =
new (Mem) OMPTaskReductionClause(
893 StartLoc, LParenLoc, EndLoc, ColonLoc, VL.size(), QualifierLoc, NameInfo);
894 Clause->setVarRefs(VL);
896 Clause->setLHSExprs(LHSExprs);
897 Clause->setRHSExprs(RHSExprs);
898 Clause->setReductionOps(ReductionOps);
899 Clause->setPreInitStmt(PreInit);
900 Clause->setPostUpdateExpr(PostUpdate);
904OMPTaskReductionClause *OMPTaskReductionClause::CreateEmpty(
const ASTContext &
C,
906 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(5 * N));
907 return new (Mem) OMPTaskReductionClause(N);
911 assert(
Privates.size() == varlist_size() &&
912 "Number of private copies is not the same as the preallocated buffer");
913 llvm::copy(
Privates, varlist_end());
918 LHSExprs.size() == varlist_size() &&
919 "Number of LHS expressions is not the same as the preallocated buffer");
925 RHSExprs.size() == varlist_size() &&
926 "Number of RHS expressions is not the same as the preallocated buffer");
927 llvm::copy(RHSExprs, getLHSExprs().end());
931 assert(ReductionOps.size() == varlist_size() &&
"Number of in reduction "
932 "expressions is not the same "
933 "as the preallocated buffer");
934 llvm::copy(ReductionOps, getRHSExprs().end());
937void OMPInReductionClause::setTaskgroupDescriptors(
939 assert(TaskgroupDescriptors.size() == varlist_size() &&
940 "Number of in reduction descriptors is not the same as the "
941 "preallocated buffer");
942 llvm::copy(TaskgroupDescriptors, getReductionOps().end());
945OMPInReductionClause *OMPInReductionClause::Create(
952 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(6 * VL.size()));
953 OMPInReductionClause *Clause =
new (Mem) OMPInReductionClause(
954 StartLoc, LParenLoc, EndLoc, ColonLoc, VL.size(), QualifierLoc, NameInfo);
955 Clause->setVarRefs(VL);
957 Clause->setLHSExprs(LHSExprs);
958 Clause->setRHSExprs(RHSExprs);
959 Clause->setReductionOps(ReductionOps);
960 Clause->setTaskgroupDescriptors(TaskgroupDescriptors);
961 Clause->setPreInitStmt(PreInit);
962 Clause->setPostUpdateExpr(PostUpdate);
966OMPInReductionClause *OMPInReductionClause::CreateEmpty(
const ASTContext &
C,
968 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(6 * N));
969 return new (Mem) OMPInReductionClause(N);
978 Clause->setLocStart(StartLoc);
979 Clause->setLParenLoc(LParenLoc);
980 Clause->setLocEnd(EndLoc);
981 Clause->setSizesRefs(Sizes);
987 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(NumSizes));
988 return new (Mem) OMPSizesClause(NumSizes);
995 OMPCountsClause *Clause =
CreateEmpty(
C, Counts.size());
996 Clause->setLocStart(StartLoc);
997 Clause->setLParenLoc(LParenLoc);
998 Clause->setLocEnd(EndLoc);
999 Clause->setCountsRefs(Counts);
1000 Clause->setOmpFillIndex(FillIdx);
1001 Clause->setOmpFillLoc(FillLoc);
1006 unsigned NumCounts) {
1007 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(NumCounts));
1008 return new (Mem) OMPCountsClause(NumCounts);
1016 OMPPermutationClause *Clause =
CreateEmpty(
C, Args.size());
1017 Clause->setLocStart(StartLoc);
1018 Clause->setLParenLoc(LParenLoc);
1019 Clause->setLocEnd(EndLoc);
1020 Clause->setArgRefs(Args);
1025 unsigned NumLoops) {
1026 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(NumLoops));
1027 return new (Mem) OMPPermutationClause(NumLoops);
1034 Clause->setLocStart(StartLoc);
1035 Clause->setLocEnd(EndLoc);
1040 return new (
C) OMPFullClause();
1049 Clause->setLocStart(StartLoc);
1050 Clause->setLParenLoc(LParenLoc);
1051 Clause->setLocEnd(EndLoc);
1052 Clause->setFactor(Factor);
1057 return new (
C) OMPPartialClause();
1066 Clause->setLocStart(StartLoc);
1067 Clause->setLParenLoc(LParenLoc);
1068 Clause->setFirstLoc(FirstLoc);
1069 Clause->setCountLoc(CountLoc);
1070 Clause->setLocEnd(EndLoc);
1071 Clause->setFirst(
First);
1072 Clause->setCount(Count);
1077 return new (
C) OMPLoopRangeClause();
1088 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(VL.size()));
1089 auto *Clause =
new (Mem) OMPAllocateClause(
1090 StartLoc, LParenLoc, Allocator, Alignment, ColonLoc, Modifier1,
1091 Modifier1Loc, Modifier2, Modifier2Loc, EndLoc, VL.size());
1093 Clause->setVarRefs(VL);
1099 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(N));
1100 return new (Mem) OMPAllocateClause(N);
1108 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(VL.size() + 1));
1109 OMPFlushClause *Clause =
1110 new (Mem) OMPFlushClause(StartLoc, LParenLoc, EndLoc, VL.size());
1111 Clause->setVarRefs(VL);
1116 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(N));
1117 return new (Mem) OMPFlushClause(N);
1125 auto *Clause =
new (
C) OMPDepobjClause(StartLoc, LParenLoc, RParenLoc);
1126 Clause->setDepobj(Depobj);
1131 return new (
C) OMPDepobjClause();
1139 void *Mem =
C.Allocate(
1140 totalSizeToAlloc<Expr *>(VL.size() + 1 + NumLoops),
1141 alignof(OMPDependClause));
1142 OMPDependClause *Clause =
new (Mem)
1143 OMPDependClause(StartLoc, LParenLoc, EndLoc, VL.size(), NumLoops);
1144 Clause->setDependencyKind(Data.DepKind);
1145 Clause->setDependencyLoc(Data.DepLoc);
1146 Clause->setColonLoc(Data.ColonLoc);
1147 Clause->setOmpAllMemoryLoc(Data.OmpAllMemoryLoc);
1148 Clause->setModifier(DepModifier);
1149 Clause->setVarRefs(VL);
1150 for (
unsigned I = 0 ; I < NumLoops; ++I)
1151 Clause->setLoopData(I,
nullptr);
1156 unsigned NumLoops) {
1158 C.Allocate(totalSizeToAlloc<Expr *>(N + 1 + NumLoops),
1159 alignof(OMPDependClause));
1160 return new (Mem) OMPDependClause(N, NumLoops);
1166 NumLoop < NumLoops &&
1167 "Expected sink or source depend + loop index must be less number of "
1169 auto *It = std::next(getVarRefs().end(), NumLoop + 1);
1176 NumLoop < NumLoops &&
1177 "Expected sink or source depend + loop index must be less number of "
1179 auto *It = std::next(getVarRefs().end(), NumLoop + 1);
1186 NumLoop < NumLoops &&
1187 "Expected sink or source depend + loop index must be less number of "
1189 const auto *It = std::next(getVarRefs().end(), NumLoop + 1);
1193void OMPDependClause::setModifier(
Expr *DepModifier) {
1194 *getVarRefs().end() = DepModifier;
1200 unsigned TotalNum = 0u;
1201 for (
auto &
C : ComponentLists)
1202 TotalNum +=
C.size();
1209 for (
const ValueDecl *D : Declarations) {
1211 UniqueDecls.insert(VD);
1213 return UniqueDecls.size();
1219 "Cannot get element-type from array-shaping expr.");
1233 if (
const auto *ATy = BaseType->getAsArrayTypeUnsafe())
1234 ElemTy = ATy->getElementType();
1242std::pair<const Expr *, std::optional<size_t>>
1248 if (Components.size() < 2)
1249 return {
nullptr, std::nullopt};
1254 if (Components.back().isNonContiguous() && CurDirKind == OMPD_target_update)
1255 return {
nullptr, std::nullopt};
1261 for (
auto [I, Component] : llvm::enumerate(Components)) {
1266 const Expr *CurExpr = Component.getAssociatedExpression();
1281 return {CurExpr, Components.size() - I};
1284 return {
nullptr, std::nullopt};
1311 void *Mem =
C.Allocate(
1317 OMPMapClause *Clause =
new (Mem)
1318 OMPMapClause(MapModifiers, MapModifiersLoc, UDMQualifierLoc, MapperId,
1321 Clause->setVarRefs(Vars);
1322 Clause->setUDMapperRefs(UDMapperRefs);
1323 Clause->setIteratorModifier(IteratorModifier);
1324 Clause->setClauseInfo(Declarations, ComponentLists);
1325 Clause->setMapType(
Type);
1333 void *Mem =
C.Allocate(
1339 OMPMapClause *Clause =
new (Mem) OMPMapClause(Sizes);
1340 Clause->setIteratorModifier(
nullptr);
1367 void *Mem =
C.Allocate(
1374 auto *Clause =
new (Mem) OMPToClause(MotionModifiers, MotionModifiersLoc,
1375 UDMQualifierLoc, MapperId, Locs, Sizes);
1377 Clause->setVarRefs(Vars);
1378 Clause->setUDMapperRefs(UDMapperRefs);
1379 Clause->setClauseInfo(Declarations, ComponentLists);
1380 Clause->setIteratorModifier(IteratorModifier);
1386 void *Mem =
C.Allocate(
1392 OMPToClause *Clause =
new (Mem) OMPToClause(Sizes);
1393 Clause->setIteratorModifier(
nullptr);
1420 void *Mem =
C.Allocate(
1428 new (Mem) OMPFromClause(MotionModifiers, MotionModifiersLoc,
1429 UDMQualifierLoc, MapperId, Locs, Sizes);
1431 Clause->setVarRefs(Vars);
1432 Clause->setUDMapperRefs(UDMapperRefs);
1433 Clause->setClauseInfo(Declarations, ComponentLists);
1434 Clause->setIteratorModifier(IteratorModifier);
1441 void *Mem =
C.Allocate(
1447 OMPFromClause *Clause =
new (Mem) OMPFromClause(Sizes);
1448 Clause->setIteratorModifier(
nullptr);
1453 assert(VL.size() == varlist_size() &&
1454 "Number of private copies is not the same as the preallocated buffer");
1455 llvm::copy(VL, varlist_end());
1459 assert(VL.size() == varlist_size() &&
1460 "Number of inits is not the same as the preallocated buffer");
1461 llvm::copy(VL, getPrivateCopies().end());
1487 void *Mem =
C.Allocate(
1494 OMPUseDevicePtrClause *Clause =
new (Mem)
1495 OMPUseDevicePtrClause(Locs, Sizes, FallbackModifier, FallbackModifierLoc);
1497 Clause->setVarRefs(Vars);
1498 Clause->setPrivateCopies(PrivateVars);
1499 Clause->setInits(
Inits);
1500 Clause->setClauseInfo(Declarations, ComponentLists);
1507 void *Mem =
C.Allocate(
1513 return new (Mem) OMPUseDevicePtrClause(Sizes);
1537 void *Mem =
C.Allocate(
1544 auto *Clause =
new (Mem) OMPUseDeviceAddrClause(Locs, Sizes);
1546 Clause->setVarRefs(Vars);
1547 Clause->setClauseInfo(Declarations, ComponentLists);
1554 void *Mem =
C.Allocate(
1560 return new (Mem) OMPUseDeviceAddrClause(Sizes);
1584 void *Mem =
C.Allocate(
1591 OMPIsDevicePtrClause *Clause =
new (Mem) OMPIsDevicePtrClause(Locs, Sizes);
1593 Clause->setVarRefs(Vars);
1594 Clause->setClauseInfo(Declarations, ComponentLists);
1601 void *Mem =
C.Allocate(
1607 return new (Mem) OMPIsDevicePtrClause(Sizes);
1631 void *Mem =
C.Allocate(
1638 auto *Clause =
new (Mem) OMPHasDeviceAddrClause(Locs, Sizes);
1640 Clause->setVarRefs(Vars);
1641 Clause->setClauseInfo(Declarations, ComponentLists);
1648 void *Mem =
C.Allocate(
1654 return new (Mem) OMPHasDeviceAddrClause(Sizes);
1663 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(2 * VL.size()));
1665 new (Mem) OMPNontemporalClause(StartLoc, LParenLoc, EndLoc, VL.size());
1666 Clause->setVarRefs(VL);
1672 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(2 * N));
1673 return new (Mem) OMPNontemporalClause(N);
1677 assert(VL.size() == varlist_size() &&
"Number of private references is not "
1678 "the same as the preallocated buffer");
1679 llvm::copy(VL, varlist_end());
1687 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(VL.size()));
1689 new (Mem) OMPInclusiveClause(StartLoc, LParenLoc, EndLoc, VL.size());
1690 Clause->setVarRefs(VL);
1696 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(N));
1697 return new (Mem) OMPInclusiveClause(N);
1705 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(VL.size()));
1707 new (Mem) OMPExclusiveClause(StartLoc, LParenLoc, EndLoc, VL.size());
1708 Clause->setVarRefs(VL);
1714 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(N));
1715 return new (Mem) OMPExclusiveClause(N);
1718void OMPUsesAllocatorsClause::setAllocatorsData(
1720 assert(
Data.size() == NumOfAllocators &&
1721 "Size of allocators data is not the same as the preallocated buffer.");
1722 for (
unsigned I = 0, E =
Data.size(); I < E; ++I) {
1724 getTrailingObjects<Expr *>()[I *
static_cast<int>(ExprOffsets::Total) +
1725 static_cast<int>(ExprOffsets::Allocator)] =
1727 getTrailingObjects<Expr *>()[I *
static_cast<int>(ExprOffsets::Total) +
1729 ExprOffsets::AllocatorTraits)] =
1732 SourceLocation>()[I *
static_cast<int>(ParenLocsOffsets::Total) +
1733 static_cast<int>(ParenLocsOffsets::LParen)] =
1736 SourceLocation>()[I *
static_cast<int>(ParenLocsOffsets::Total) +
1737 static_cast<int>(ParenLocsOffsets::RParen)] =
1742OMPUsesAllocatorsClause::Data
1746 getTrailingObjects<Expr *>()[I *
static_cast<int>(ExprOffsets::Total) +
1747 static_cast<int>(ExprOffsets::Allocator)];
1749 getTrailingObjects<Expr *>()[I *
static_cast<int>(ExprOffsets::Total) +
1751 ExprOffsets::AllocatorTraits)];
1753 SourceLocation>()[I *
static_cast<int>(ParenLocsOffsets::Total) +
1754 static_cast<int>(ParenLocsOffsets::LParen)];
1756 SourceLocation>()[I *
static_cast<int>(ParenLocsOffsets::Total) +
1757 static_cast<int>(ParenLocsOffsets::RParen)];
1765 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *, SourceLocation>(
1766 static_cast<int>(ExprOffsets::Total) *
Data.size(),
1767 static_cast<int>(ParenLocsOffsets::Total) *
Data.size()));
1768 auto *Clause =
new (Mem)
1769 OMPUsesAllocatorsClause(StartLoc, LParenLoc, EndLoc,
Data.size());
1770 Clause->setAllocatorsData(
Data);
1776 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *, SourceLocation>(
1777 static_cast<int>(ExprOffsets::Total) * N,
1778 static_cast<int>(ParenLocsOffsets::Total) * N));
1779 return new (Mem) OMPUsesAllocatorsClause(N);
1787 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(Locators.size() + 1));
1788 auto *Clause =
new (Mem)
1789 OMPAffinityClause(StartLoc, LParenLoc, ColonLoc, EndLoc, Locators.size());
1790 Clause->setModifier(Modifier);
1791 Clause->setVarRefs(Locators);
1797 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(N + 1));
1798 return new (Mem) OMPAffinityClause(N);
1808 unsigned NumPrefs = InteropInfo.
Prefs.size();
1809 unsigned NumAttrs = 0;
1811 NumAttrs += P.
Attrs.size();
1814 void *Mem =
C.Allocate(
1815 totalSizeToAlloc<Expr *, unsigned>(1 + NumPrefs + NumAttrs, NumPrefs));
1816 auto *Clause =
new (Mem)
1818 LParenLoc, VarLoc, EndLoc, 1 + NumPrefs);
1819 Clause->NumAttrs = NumAttrs;
1822 Expr **E = Clause->getTrailingObjects<
Expr *>();
1824 for (
unsigned I = 0; I < NumPrefs; ++I)
1825 E[1 + I] = InteropInfo.
Prefs[I].Fr;
1826 unsigned *AttrEnds = Clause->getTrailingObjects<
unsigned>();
1827 unsigned AttrBase = 1 + NumPrefs;
1828 unsigned AttrPos = AttrBase;
1829 for (
unsigned I = 0; I < NumPrefs; ++I) {
1830 for (
Expr *A : InteropInfo.
Prefs[I].Attrs)
1832 AttrEnds[I] = AttrPos - AttrBase;
1839 unsigned NumAttrs) {
1840 void *Mem =
C.Allocate(
1841 totalSizeToAlloc<Expr *, unsigned>(1 + NumPrefs + NumAttrs, NumPrefs));
1842 auto *Clause =
new (Mem) OMPInitClause(1 + NumPrefs);
1843 Clause->NumAttrs = NumAttrs;
1849 assert(Counts.size() == getNumPrefs() &&
1850 "attr-count vector size must match number of pref-specs");
1851 assert(Attrs.size() == NumAttrs &&
1852 "attr-expr count must match preallocated NumAttrs");
1854 unsigned *AttrEnds = getTrailingObjects<unsigned>();
1856 for (
unsigned I = 0, E = Counts.size(); I < E; ++I) {
1860 llvm::copy(Attrs, getTrailingObjects<Expr *>() + varlist_size());
1867 return new (
C) OMPBindClause(K, KLoc, StartLoc, LParenLoc, EndLoc);
1871 return new (
C) OMPBindClause();
1880 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(VL.size() + NumLoops),
1881 alignof(OMPDoacrossClause));
1882 OMPDoacrossClause *Clause =
new (Mem)
1883 OMPDoacrossClause(StartLoc, LParenLoc, EndLoc, VL.size(), NumLoops);
1884 Clause->setDependenceType(DepType);
1885 Clause->setDependenceLoc(DepLoc);
1886 Clause->setColonLoc(ColonLoc);
1887 Clause->setVarRefs(VL);
1888 for (
unsigned I = 0; I < NumLoops; ++I)
1889 Clause->setLoopData(I,
nullptr);
1895 unsigned NumLoops) {
1896 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(N + NumLoops),
1897 alignof(OMPDoacrossClause));
1898 return new (Mem) OMPDoacrossClause(N, NumLoops);
1902 assert(NumLoop < NumLoops &&
"Loop index must be less number of loops.");
1903 auto *It = std::next(getVarRefs().end(), NumLoop);
1908 assert(NumLoop < NumLoops &&
"Loop index must be less number of loops.");
1909 auto *It = std::next(getVarRefs().end(), NumLoop);
1914 assert(NumLoop < NumLoops &&
"Loop index must be less number of loops.");
1915 const auto *It = std::next(getVarRefs().end(), NumLoop);
1919OMPAbsentClause *OMPAbsentClause::Create(
const ASTContext &
C,
1924 void *Mem =
C.Allocate(totalSizeToAlloc<OpenMPDirectiveKind>(DKVec.size()),
1925 alignof(OMPAbsentClause));
1926 auto *AC =
new (Mem) OMPAbsentClause(Loc, LLoc, RLoc, DKVec.size());
1927 AC->setDirectiveKinds(DKVec);
1931OMPAbsentClause *OMPAbsentClause::CreateEmpty(
const ASTContext &
C,
unsigned K) {
1932 void *Mem =
C.Allocate(totalSizeToAlloc<OpenMPDirectiveKind>(K),
1933 alignof(OMPAbsentClause));
1934 return new (Mem) OMPAbsentClause(K);
1937OMPContainsClause *OMPContainsClause::Create(
1940 void *Mem =
C.Allocate(totalSizeToAlloc<OpenMPDirectiveKind>(DKVec.size()),
1941 alignof(OMPContainsClause));
1942 auto *CC =
new (Mem) OMPContainsClause(Loc, LLoc, RLoc, DKVec.size());
1943 CC->setDirectiveKinds(DKVec);
1947OMPContainsClause *OMPContainsClause::CreateEmpty(
const ASTContext &
C,
1949 void *Mem =
C.Allocate(totalSizeToAlloc<OpenMPDirectiveKind>(K),
1950 alignof(OMPContainsClause));
1951 return new (Mem) OMPContainsClause(K);
1958 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(VL.size()));
1959 OMPNumTeamsClause *Clause =
1960 new (Mem) OMPNumTeamsClause(
C, StartLoc, LParenLoc, EndLoc, VL.size());
1961 Clause->setVarRefs(VL);
1962 Clause->setPreInitStmt(PreInit, CaptureRegion);
1968 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(N));
1969 return new (Mem) OMPNumTeamsClause(N);
1976 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(VL.size()));
1977 OMPThreadLimitClause *Clause =
1978 new (Mem) OMPThreadLimitClause(
C, StartLoc, LParenLoc, EndLoc, VL.size());
1979 Clause->setVarRefs(VL);
1980 Clause->setPreInitStmt(PreInit, CaptureRegion);
1986 void *Mem =
C.Allocate(totalSizeToAlloc<Expr *>(N));
1987 return new (Mem) OMPThreadLimitClause(N);
1994void OMPClausePrinter::VisitOMPIfClause(
OMPIfClause *Node) {
1997 OS << getOpenMPDirectiveName(Node->
getNameModifier(), Version) <<
": ";
2002void OMPClausePrinter::VisitOMPFinalClause(
OMPFinalClause *Node) {
2009 OS <<
"num_threads(";
2019void OMPClausePrinter::VisitOMPAlignClause(
OMPAlignClause *Node) {
2037void OMPClausePrinter::VisitOMPSizesClause(
OMPSizesClause *Node) {
2043 Size->printPretty(OS,
nullptr, Policy, 0);
2053 llvm::interleaveComma(llvm::seq<unsigned>(Refs.size()), OS, [&](
unsigned I) {
2054 if (FillIdx && I == *FillIdx)
2057 Refs[I]->printPretty(OS, nullptr, Policy, 0);
2063 OS <<
"permutation(";
2065 E->printPretty(OS, nullptr, Policy, 0);
2070void OMPClausePrinter::VisitOMPFullClause(
OMPFullClause *Node) {
OS <<
"full"; }
2077 Factor->printPretty(OS,
nullptr, Policy, 0);
2088 if (
First && Count) {
2090 First->printPretty(OS,
nullptr, Policy, 0);
2109void OMPClausePrinter::VisitOMPDetachClause(OMPDetachClause *Node) {
2119 if (Version >= 60 && Node->
getDefaultVC() != OMPC_DEFAULT_VC_all) {
2134void OMPClausePrinter::VisitOMPTransparentClause(OMPTransparentClause *Node) {
2135 OS <<
"transparent(";
2136 if (Node->getImpexType())
2137 Node->getImpexType()->printPretty(OS,
nullptr, Policy, 0);
2143void OMPClausePrinter::VisitOMPProcBindClause(OMPProcBindClause *Node) {
2146 unsigned(Node->getProcBindKind()))
2150void OMPClausePrinter::VisitOMPUnifiedAddressClause(OMPUnifiedAddressClause *) {
2151 OS <<
"unified_address";
2154void OMPClausePrinter::VisitOMPUnifiedSharedMemoryClause(
2155 OMPUnifiedSharedMemoryClause *) {
2156 OS <<
"unified_shared_memory";
2159void OMPClausePrinter::VisitOMPReverseOffloadClause(OMPReverseOffloadClause *) {
2160 OS <<
"reverse_offload";
2163void OMPClausePrinter::VisitOMPDynamicAllocatorsClause(
2164 OMPDynamicAllocatorsClause *) {
2165 OS <<
"dynamic_allocators";
2168void OMPClausePrinter::VisitOMPAtomicDefaultMemOrderClause(
2169 OMPAtomicDefaultMemOrderClause *Node) {
2170 OS <<
"atomic_default_mem_order("
2172 Node->getAtomicDefaultMemOrderKind())
2176void OMPClausePrinter::VisitOMPSelfMapsClause(OMPSelfMapsClause *) {
2180void OMPClausePrinter::VisitOMPAtClause(OMPAtClause *Node) {
2185void OMPClausePrinter::VisitOMPSeverityClause(OMPSeverityClause *Node) {
2191void OMPClausePrinter::VisitOMPMessageClause(OMPMessageClause *Node) {
2193 if (
Expr *E = Node->getMessageString())
2194 E->printPretty(OS,
nullptr, Policy);
2198void OMPClausePrinter::VisitOMPScheduleClause(OMPScheduleClause *Node) {
2202 Node->getFirstScheduleModifier());
2206 Node->getSecondScheduleModifier());
2211 if (
auto *E = Node->getChunkSize()) {
2213 E->printPretty(OS,
nullptr, Policy);
2218void OMPClausePrinter::VisitOMPOrderedClause(OMPOrderedClause *Node) {
2220 if (
auto *
Num = Node->getNumForLoops()) {
2222 Num->printPretty(OS,
nullptr, Policy, 0);
2227void OMPClausePrinter::VisitOMPNowaitClause(OMPNowaitClause *Node) {
2229 if (
auto *
Cond = Node->getCondition()) {
2231 Cond->printPretty(OS,
nullptr, Policy, 0);
2236void OMPClausePrinter::VisitOMPUntiedClause(OMPUntiedClause *) {
2240void OMPClausePrinter::VisitOMPNogroupClause(OMPNogroupClause *) {
2244void OMPClausePrinter::VisitOMPMergeableClause(OMPMergeableClause *) {
2248void OMPClausePrinter::VisitOMPReadClause(OMPReadClause *) {
OS <<
"read"; }
2250void OMPClausePrinter::VisitOMPWriteClause(OMPWriteClause *) {
OS <<
"write"; }
2252void OMPClausePrinter::VisitOMPUpdateClause(OMPUpdateClause *Node) {
2254 if (Node->isExtended()) {
2257 Node->getDependencyKind());
2262void OMPClausePrinter::VisitOMPCaptureClause(OMPCaptureClause *) {
2266void OMPClausePrinter::VisitOMPCompareClause(OMPCompareClause *) {
2270void OMPClausePrinter::VisitOMPFailClause(OMPFailClause *Node) {
2275 Node->getClauseKind(),
static_cast<int>(Node->getFailParameter()));
2280void OMPClausePrinter::VisitOMPAbsentClause(OMPAbsentClause *Node) {
2283 for (
auto &D : Node->getDirectiveKinds()) {
2286 OS << getOpenMPDirectiveName(D, Version);
2292void OMPClausePrinter::VisitOMPHoldsClause(OMPHoldsClause *Node) {
2294 Node->getExpr()->printPretty(OS,
nullptr, Policy, 0);
2298void OMPClausePrinter::VisitOMPContainsClause(OMPContainsClause *Node) {
2301 for (
auto &D : Node->getDirectiveKinds()) {
2304 OS << getOpenMPDirectiveName(D, Version);
2310void OMPClausePrinter::VisitOMPNoOpenMPClause(OMPNoOpenMPClause *) {
2314void OMPClausePrinter::VisitOMPNoOpenMPRoutinesClause(
2315 OMPNoOpenMPRoutinesClause *) {
2316 OS <<
"no_openmp_routines";
2319void OMPClausePrinter::VisitOMPNoOpenMPConstructsClause(
2320 OMPNoOpenMPConstructsClause *) {
2321 OS <<
"no_openmp_constructs";
2324void OMPClausePrinter::VisitOMPNoParallelismClause(OMPNoParallelismClause *) {
2325 OS <<
"no_parallelism";
2328void OMPClausePrinter::VisitOMPSeqCstClause(OMPSeqCstClause *) {
2332void OMPClausePrinter::VisitOMPAcqRelClause(OMPAcqRelClause *) {
2336void OMPClausePrinter::VisitOMPAcquireClause(OMPAcquireClause *) {
2340void OMPClausePrinter::VisitOMPReleaseClause(OMPReleaseClause *) {
2344void OMPClausePrinter::VisitOMPRelaxedClause(OMPRelaxedClause *) {
2348void OMPClausePrinter::VisitOMPWeakClause(OMPWeakClause *) {
OS <<
"weak"; }
2350void OMPClausePrinter::VisitOMPThreadsClause(OMPThreadsClause *) {
2354void OMPClausePrinter::VisitOMPSIMDClause(OMPSIMDClause *) {
OS <<
"simd"; }
2356void OMPClausePrinter::VisitOMPDeviceClause(OMPDeviceClause *Node) {
2367void OMPClausePrinter::VisitOMPNumTeamsClause(OMPNumTeamsClause *Node) {
2368 if (!Node->varlist_empty()) {
2372 if (Node->varlist_size() == 2) {
2374 Node->varlist(), OS,
2375 [&](
const auto *
Expr) { Expr->printPretty(OS, nullptr, Policy, 0); },
2379 llvm::interleaveComma(Node->varlist(), OS, [&](
const auto *
Expr) {
2380 Expr->printPretty(OS, nullptr, Policy, 0);
2387void OMPClausePrinter::VisitOMPThreadLimitClause(OMPThreadLimitClause *Node) {
2388 if (!Node->varlist_empty()) {
2389 OS <<
"thread_limit";
2390 VisitOMPClauseList(Node,
'(');
2395void OMPClausePrinter::VisitOMPPriorityClause(OMPPriorityClause *Node) {
2401void OMPClausePrinter::VisitOMPGrainsizeClause(OMPGrainsizeClause *Node) {
2412void OMPClausePrinter::VisitOMPNumTasksClause(OMPNumTasksClause *Node) {
2423void OMPClausePrinter::VisitOMPHintClause(OMPHintClause *Node) {
2429void OMPClausePrinter::VisitOMPInitClause(OMPInitClause *Node) {
2431 if (!Node->
prefs().empty()) {
2432 OS <<
"prefer_type(";
2435 llvm::interleaveComma(Node->
prefs(), OS, [&](OMPInitClause::PrefView P) {
2439 P.Fr->printPretty(OS, nullptr, Policy);
2441 if (!P.Attrs.empty())
2446 llvm::interleaveComma(P.Attrs, OS, [&](const Expr *A) {
2447 A->printPretty(OS, nullptr, Policy);
2456 [&](OMPInitClause::PrefView P) {
2458 P.Fr->printPretty(OS, nullptr, Policy);
2476void OMPClausePrinter::VisitOMPUseClause(OMPUseClause *Node) {
2482void OMPClausePrinter::VisitOMPDestroyClause(OMPDestroyClause *Node) {
2486 E->printPretty(OS,
nullptr, Policy);
2491void OMPClausePrinter::VisitOMPNovariantsClause(OMPNovariantsClause *Node) {
2495 E->printPretty(OS,
nullptr, Policy, 0);
2500void OMPClausePrinter::VisitOMPNocontextClause(OMPNocontextClause *Node) {
2504 E->printPretty(OS,
nullptr, Policy, 0);
2510void OMPClausePrinter::VisitOMPClauseList(T *Node,
char StartSym) {
2511 for (
typename T::varlist_iterator I = Node->varlist_begin(),
2512 E = Node->varlist_end();
2514 assert(*I &&
"Expected non-null Stmt");
2515 OS << (I == Node->varlist_begin() ? StartSym :
',');
2516 if (
auto *DRE = dyn_cast<DeclRefExpr>(*I)) {
2518 DRE->printPretty(OS,
nullptr, Policy, 0);
2520 DRE->getDecl()->printQualifiedName(OS);
2522 (*I)->printPretty(OS,
nullptr, Policy, 0);
2530 Expr *FirstModifier =
nullptr;
2531 Expr *SecondModifier =
nullptr;
2536 if (FirstAllocMod == OMPC_ALLOCATE_allocator ||
2547 if (FirstModifier) {
2549 if (!FirstUnknown) {
2553 FirstModifier->
printPretty(OS,
nullptr, Policy, 0);
2556 if (SecondModifier) {
2558 if (!SecondUnknown) {
2563 SecondModifier->
printPretty(OS,
nullptr, Policy, 0);
2568 VisitOMPClauseList(Node,
' ');
2571 VisitOMPClauseList(Node,
'(');
2576void OMPClausePrinter::VisitOMPPrivateClause(OMPPrivateClause *Node) {
2577 if (!Node->varlist_empty()) {
2579 VisitOMPClauseList(Node,
'(');
2584void OMPClausePrinter::VisitOMPFirstprivateClause(OMPFirstprivateClause *Node) {
2585 if (!Node->varlist_empty()) {
2586 OS <<
"firstprivate";
2587 VisitOMPClauseList(Node,
'(');
2592void OMPClausePrinter::VisitOMPLastprivateClause(OMPLastprivateClause *Node) {
2593 if (!Node->varlist_empty()) {
2594 OS <<
"lastprivate";
2606void OMPClausePrinter::VisitOMPSharedClause(OMPSharedClause *Node) {
2607 if (!Node->varlist_empty()) {
2609 VisitOMPClauseList(Node,
'(');
2614void OMPClausePrinter::VisitOMPReductionClause(OMPReductionClause *Node) {
2615 if (!Node->varlist_empty()) {
2617 if (Node->getModifierLoc().isValid())
2621 Node->getQualifierLoc().getNestedNameSpecifier();
2623 Node->getNameInfo().getName().getCXXOverloadedOperator();
2624 if (!Qualifier && OOK !=
OO_None) {
2630 OS << Node->getNameInfo();
2633 VisitOMPClauseList(Node,
' ');
2638void OMPClausePrinter::VisitOMPTaskReductionClause(
2639 OMPTaskReductionClause *Node) {
2640 if (!Node->varlist_empty()) {
2641 OS <<
"task_reduction(";
2643 Node->getQualifierLoc().getNestedNameSpecifier();
2645 Node->getNameInfo().getName().getCXXOverloadedOperator();
2646 if (!Qualifier && OOK !=
OO_None) {
2652 OS << Node->getNameInfo();
2655 VisitOMPClauseList(Node,
' ');
2660void OMPClausePrinter::VisitOMPInReductionClause(OMPInReductionClause *Node) {
2661 if (!Node->varlist_empty()) {
2662 OS <<
"in_reduction(";
2664 Node->getQualifierLoc().getNestedNameSpecifier();
2666 Node->getNameInfo().getName().getCXXOverloadedOperator();
2667 if (!Qualifier && OOK !=
OO_None) {
2673 OS << Node->getNameInfo();
2676 VisitOMPClauseList(Node,
' ');
2681void OMPClausePrinter::VisitOMPLinearClause(OMPLinearClause *Node) {
2682 if (!Node->varlist_empty()) {
2684 VisitOMPClauseList(Node,
'(');
2685 if (Node->getModifierLoc().isValid() || Node->getStep() !=
nullptr) {
2688 if (Node->getModifierLoc().isValid()) {
2691 if (Node->getStep() !=
nullptr) {
2692 if (Node->getModifierLoc().isValid()) {
2696 Node->getStep()->printPretty(OS,
nullptr, Policy, 0);
2703void OMPClausePrinter::VisitOMPAlignedClause(OMPAlignedClause *Node) {
2704 if (!Node->varlist_empty()) {
2706 VisitOMPClauseList(Node,
'(');
2715void OMPClausePrinter::VisitOMPCopyinClause(OMPCopyinClause *Node) {
2716 if (!Node->varlist_empty()) {
2718 VisitOMPClauseList(Node,
'(');
2723void OMPClausePrinter::VisitOMPCopyprivateClause(OMPCopyprivateClause *Node) {
2724 if (!Node->varlist_empty()) {
2725 OS <<
"copyprivate";
2726 VisitOMPClauseList(Node,
'(');
2731void OMPClausePrinter::VisitOMPFlushClause(OMPFlushClause *Node) {
2732 if (!Node->varlist_empty()) {
2733 VisitOMPClauseList(Node,
'(');
2738void OMPClausePrinter::VisitOMPDepobjClause(OMPDepobjClause *Node) {
2744void OMPClausePrinter::VisitOMPDependClause(OMPDependClause *Node) {
2752 bool IsOmpAllMemory =
false;
2753 if (PrintKind == OMPC_DEPEND_outallmemory) {
2754 PrintKind = OMPC_DEPEND_out;
2755 IsOmpAllMemory =
true;
2756 }
else if (PrintKind == OMPC_DEPEND_inoutallmemory) {
2757 PrintKind = OMPC_DEPEND_inout;
2758 IsOmpAllMemory =
true;
2761 if (!Node->varlist_empty() || IsOmpAllMemory)
2763 VisitOMPClauseList(Node,
' ');
2764 if (IsOmpAllMemory) {
2765 OS << (Node->varlist_empty() ?
" " :
",");
2766 OS <<
"omp_all_memory";
2771template <
typename T>
2776 Node->getMapperQualifierLoc().getNestedNameSpecifier();
2777 MapperNNS.
print(OS, Policy);
2778 OS << Node->getMapperIdInfo() <<
')';
2781template <
typename T>
2784 if (
Expr *IteratorModifier = Node->getIteratorModifier())
2785 IteratorModifier->printPretty(OS,
nullptr, Policy);
2788void OMPClausePrinter::VisitOMPMapClause(OMPMapClause *Node) {
2789 if (!Node->varlist_empty()) {
2808 VisitOMPClauseList(Node,
' ');
2813template <
typename T>
void OMPClausePrinter::VisitOMPMotionClause(T *Node) {
2814 if (Node->varlist_empty())
2816 OS << getOpenMPClauseName(Node->getClauseKind());
2817 unsigned ModifierCount = 0;
2822 if (ModifierCount) {
2826 if (Node->getMotionModifier(I) == OMPC_MOTION_MODIFIER_iterator) {
2830 Node->getMotionModifier(I));
2831 if (Node->getMotionModifier(I) == OMPC_MOTION_MODIFIER_mapper)
2833 if (I < ModifierCount - 1)
2839 VisitOMPClauseList(Node,
' ');
2841 VisitOMPClauseList(Node,
'(');
2846void OMPClausePrinter::VisitOMPToClause(OMPToClause *Node) {
2847 VisitOMPMotionClause(Node);
2850void OMPClausePrinter::VisitOMPFromClause(OMPFromClause *Node) {
2851 VisitOMPMotionClause(Node);
2854void OMPClausePrinter::VisitOMPDistScheduleClause(OMPDistScheduleClause *Node) {
2859 E->printPretty(OS,
nullptr, Policy);
2864void OMPClausePrinter::VisitOMPDefaultmapClause(OMPDefaultmapClause *Node) {
2865 OS <<
"defaultmap(";
2876void OMPClausePrinter::VisitOMPUseDevicePtrClause(OMPUseDevicePtrClause *Node) {
2877 if (!Node->varlist_empty()) {
2878 OS <<
"use_device_ptr";
2884 VisitOMPClauseList(Node,
' ');
2886 VisitOMPClauseList(Node,
'(');
2892void OMPClausePrinter::VisitOMPUseDeviceAddrClause(
2893 OMPUseDeviceAddrClause *Node) {
2894 if (!Node->varlist_empty()) {
2895 OS <<
"use_device_addr";
2896 VisitOMPClauseList(Node,
'(');
2901void OMPClausePrinter::VisitOMPIsDevicePtrClause(OMPIsDevicePtrClause *Node) {
2902 if (!Node->varlist_empty()) {
2903 OS <<
"is_device_ptr";
2904 VisitOMPClauseList(Node,
'(');
2909void OMPClausePrinter::VisitOMPHasDeviceAddrClause(OMPHasDeviceAddrClause *Node) {
2910 if (!Node->varlist_empty()) {
2911 OS <<
"has_device_addr";
2912 VisitOMPClauseList(Node,
'(');
2917void OMPClausePrinter::VisitOMPNontemporalClause(OMPNontemporalClause *Node) {
2918 if (!Node->varlist_empty()) {
2919 OS <<
"nontemporal";
2920 VisitOMPClauseList(Node,
'(');
2925void OMPClausePrinter::VisitOMPOrderClause(OMPOrderClause *Node) {
2934void OMPClausePrinter::VisitOMPInclusiveClause(OMPInclusiveClause *Node) {
2935 if (!Node->varlist_empty()) {
2937 VisitOMPClauseList(Node,
'(');
2942void OMPClausePrinter::VisitOMPExclusiveClause(OMPExclusiveClause *Node) {
2943 if (!Node->varlist_empty()) {
2945 VisitOMPClauseList(Node,
'(');
2950void OMPClausePrinter::VisitOMPUsesAllocatorsClause(
2951 OMPUsesAllocatorsClause *Node) {
2954 OS <<
"uses_allocators(";
2957 Data.Allocator->printPretty(OS,
nullptr, Policy);
2958 if (
Data.AllocatorTraits) {
2960 Data.AllocatorTraits->printPretty(OS,
nullptr, Policy);
2969void OMPClausePrinter::VisitOMPAffinityClause(OMPAffinityClause *Node) {
2970 if (Node->varlist_empty())
2973 char StartSym =
'(';
2976 Modifier->printPretty(OS,
nullptr, Policy);
2980 VisitOMPClauseList(Node, StartSym);
2984void OMPClausePrinter::VisitOMPFilterClause(OMPFilterClause *Node) {
2990void OMPClausePrinter::VisitOMPBindClause(OMPBindClause *Node) {
2996void OMPClausePrinter::VisitOMPXDynCGroupMemClause(
2997 OMPXDynCGroupMemClause *Node) {
2998 OS <<
"ompx_dyn_cgroup_mem(";
3003void OMPClausePrinter::VisitOMPDynGroupprivateClause(
3004 OMPDynGroupprivateClause *Node) {
3005 OS <<
"dyn_groupprivate(";
3021void OMPClausePrinter::VisitOMPDoacrossClause(OMPDoacrossClause *Node) {
3026 case OMPC_DOACROSS_source:
3029 case OMPC_DOACROSS_sink:
3032 case OMPC_DOACROSS_source_omp_cur_iteration:
3033 OS <<
"source: omp_cur_iteration";
3035 case OMPC_DOACROSS_sink_omp_cur_iteration:
3036 OS <<
"sink: omp_cur_iteration - 1";
3039 llvm_unreachable(
"unknown docaross modifier");
3041 VisitOMPClauseList(Node,
' ');
3045void OMPClausePrinter::VisitOMPXAttributeClause(OMPXAttributeClause *Node) {
3046 OS <<
"ompx_attribute(";
3057void OMPClausePrinter::VisitOMPXBareClause(OMPXBareClause *Node) {
3062 VariantMatchInfo &VMI)
const {
3067 if (
Selector.Kind == TraitSelector::user_condition) {
3068 assert(
Selector.ScoreOrCondition &&
3069 "Ill-formed user condition, expected condition expression!");
3070 assert(
Selector.Properties.size() == 1 &&
3071 Selector.Properties.front().Kind ==
3072 TraitProperty::user_condition_unknown &&
3073 "Ill-formed user condition, expected unknown trait property!");
3075 if (std::optional<APSInt> CondVal =
3076 Selector.ScoreOrCondition->getIntegerConstantExpr(ASTCtx))
3077 VMI.addTrait(CondVal->isZero() ? TraitProperty::user_condition_false
3078 : TraitProperty::user_condition_true,
3081 VMI.addTrait(TraitProperty::user_condition_false,
"<condition>");
3085 std::optional<llvm::APSInt> Score;
3086 llvm::APInt *ScorePtr =
nullptr;
3088 if ((Score =
Selector.ScoreOrCondition->getIntegerConstantExpr(ASTCtx)))
3091 VMI.addTrait(TraitProperty::user_condition_false,
3092 "<non-constant-score>");
3096 VMI.addTrait(
Set.Kind, Property.Kind, Property.RawString, ScorePtr);
3098 if (
Set.Kind != TraitSet::construct)
3102 assert(
Selector.Properties.size() == 1 &&
3103 Selector.Properties.front().Kind ==
3104 getOpenMPContextTraitPropertyForSelector(
3106 "Ill-formed construct selector!");
3113 bool FirstSet =
true;
3118 OS << getOpenMPContextTraitSetName(
Set.Kind) <<
"={";
3120 bool FirstSelector =
true;
3124 FirstSelector =
false;
3125 OS << getOpenMPContextTraitSelectorName(
Selector.Kind);
3127 bool AllowsTraitScore =
false;
3128 bool RequiresProperty =
false;
3129 isValidTraitSelectorForTraitSet(
3130 Selector.Kind,
Set.Kind, AllowsTraitScore, RequiresProperty);
3132 if (!RequiresProperty)
3136 if (
Selector.Kind == TraitSelector::user_condition) {
3138 Selector.ScoreOrCondition->printPretty(OS,
nullptr, Policy);
3145 Selector.ScoreOrCondition->printPretty(OS,
nullptr, Policy);
3149 bool FirstProperty =
true;
3153 FirstProperty =
false;
3154 OS << getOpenMPContextTraitPropertyName(Property.Kind,
3155 Property.RawString);
3165 std::string MangledName;
3166 llvm::raw_string_ostream OS(MangledName);
3171 bool AllowsTraitScore =
false;
3172 bool RequiresProperty =
false;
3173 isValidTraitSelectorForTraitSet(
3174 Selector.Kind,
Set.Kind, AllowsTraitScore, RequiresProperty);
3177 if (!RequiresProperty ||
3178 Selector.Kind == TraitSelector::user_condition)
3183 << getOpenMPContextTraitPropertyName(Property.Kind,
3184 Property.RawString);
3190OMPTraitInfo::OMPTraitInfo(StringRef MangledName) {
3193 if (!MangledName.consume_front(
"$S"))
3195 if (MangledName.consumeInteger(10,
U))
3199 Set.Kind = TraitSet(
U);
3201 if (!MangledName.consume_front(
"$s"))
3203 if (MangledName.consumeInteger(10,
U))
3209 if (!MangledName.consume_front(
"$P"))
3213 std::pair<StringRef, StringRef> PropRestPair = MangledName.split(
'$');
3214 Property.RawString = PropRestPair.first;
3215 Property.Kind = getOpenMPContextTraitPropertyKind(
3217 MangledName = MangledName.drop_front(PropRestPair.first.size());
3227 TI.
print(OS, Policy);
3232 return TI ? OS << *TI : OS;
3239 : OMPContext(ASTCtx.getLangOpts().OpenMPIsTargetDevice,
3241 ASTCtx.getLangOpts().OMPTargetTriples.empty()
3243 : ASTCtx.getLangOpts().OMPTargetTriples[0],
3245 FeatureValidityCheck([&](StringRef FeatureName) {
3246 return ASTCtx.
getTargetInfo().isValidFeatureName(FeatureName);
3248 DiagUnknownTrait(std::move(DiagUnknownTrait)) {
3251 for (llvm::omp::TraitProperty Property : ConstructTraits)
3256 auto It = FeatureMap.find(RawString);
3257 if (It != FeatureMap.end())
3259 if (!FeatureValidityCheck(RawString))
3260 DiagUnknownTrait(RawString);
Defines the clang::ASTContext interface.
This file defines OpenMP nodes for declarative directives.
Forward-declares and imports various common LLVM datatypes that clang wants to use unqualified.
static StringRef getTriple(const Command &Job)
static Stmt ** getAddrOfExprAsWritten(Stmt *S)
Gets the address of the original, non-captured, expression used in the clause as the preinitializer.
static void PrintIterator(raw_ostream &OS, T *Node, const PrintingPolicy &Policy)
static void PrintMapper(raw_ostream &OS, T *Node, const PrintingPolicy &Policy)
This file defines OpenMP AST classes for clauses.
Defines some OpenMP-specific enums and functions.
This represents clause 'affinity' in the 'pragma omp task'-based directives.
static OMPAffinityClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation ColonLoc, SourceLocation EndLoc, Expr *Modifier, ArrayRef< Expr * > Locators)
Creates clause with a modifier a list of locator items.
Expr * getModifier()
Gets affinity modifier.
static OMPAffinityClause * CreateEmpty(const ASTContext &C, unsigned N)
Creates an empty clause with the place for N locator items.
static OMPAlignedClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation ColonLoc, SourceLocation EndLoc, ArrayRef< Expr * > VL, Expr *A)
Creates clause with a list of variables VL and alignment A.
static OMPAlignedClause * CreateEmpty(const ASTContext &C, unsigned NumVars)
Creates an empty clause with the place for NumVars variables.
Expr * getAlignment()
Returns alignment.
static OMPBindClause * Create(const ASTContext &C, OpenMPBindClauseKind K, SourceLocation KLoc, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc)
Build 'bind' clause with kind K ('teams', 'parallel', or 'thread').
static OMPBindClause * CreateEmpty(const ASTContext &C)
Build an empty 'bind' clause.
OpenMPBindClauseKind getBindKind() const
Returns kind of the clause.
Class that represents a component of a mappable expression. E.g. for an expression S....
static unsigned getUniqueDeclarationsTotalNumber(ArrayRef< const ValueDecl * > Declarations)
static unsigned getComponentsTotalNumber(MappableExprComponentListsRef ComponentLists)
ArrayRef< MappableExprComponentList > MappableExprComponentListsRef
static std::pair< const Expr *, std::optional< size_t > > findAttachPtrExpr(MappableExprComponentListRef Components, OpenMPDirectiveKind CurDirKind)
Find the attach pointer expression from a list of mappable expression components.
static QualType getComponentExprElementType(const Expr *Exp)
Get the type of an element of a ComponentList Expr Exp.
ArrayRef< MappableComponent > MappableExprComponentListRef
static OMPCopyinClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, ArrayRef< Expr * > VL, ArrayRef< Expr * > SrcExprs, ArrayRef< Expr * > DstExprs, ArrayRef< Expr * > AssignmentOps)
Creates clause with a list of variables VL.
static OMPCopyinClause * CreateEmpty(const ASTContext &C, unsigned N)
Creates an empty clause with N variables.
static OMPCopyprivateClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, ArrayRef< Expr * > VL, ArrayRef< Expr * > SrcExprs, ArrayRef< Expr * > DstExprs, ArrayRef< Expr * > AssignmentOps)
Creates clause with a list of variables VL.
static OMPCopyprivateClause * CreateEmpty(const ASTContext &C, unsigned N)
Creates an empty clause with N variables.
OpenMPDefaultmapClauseKind getDefaultmapKind() const
Get kind of the clause.
OpenMPDefaultmapClauseModifier getDefaultmapModifier() const
Get the modifier of the clause.
This represents implicit clause 'depend' for the 'pragma omp task' directive.
static OMPDependClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, DependDataTy Data, Expr *DepModifier, ArrayRef< Expr * > VL, unsigned NumLoops)
Creates clause with a list of variables VL.
Expr * getModifier()
Return optional depend modifier.
Expr * getLoopData(unsigned NumLoop)
Get the loop data.
void setLoopData(unsigned NumLoop, Expr *Cnt)
Set the loop data for the depend clauses with 'sink|source' kind of dependency.
static OMPDependClause * CreateEmpty(const ASTContext &C, unsigned N, unsigned NumLoops)
Creates an empty clause with N variables.
OpenMPDependClauseKind getDependencyKind() const
Get dependency type.
static OMPDepobjClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, Expr *Depobj)
Creates clause.
Expr * getDepobj()
Returns depobj expression associated with the clause.
static OMPDepobjClause * CreateEmpty(const ASTContext &C)
Creates an empty clause.
Expr * getInteropVar() const
Returns the interop variable.
Expr * getEventHandler() const
Returns event-handler expression.
This represents 'device' clause in the 'pragma omp ...' directive.
OpenMPDeviceClauseModifier getModifier() const
Gets modifier.
Expr * getDevice()
Return device number.
This represents 'dist_schedule' clause in the 'pragma omp ...' directive.
Expr * getChunkSize()
Get chunk size.
OpenMPDistScheduleClauseKind getDistScheduleKind() const
Get kind of the clause.
This represents the 'doacross' clause for the 'pragma omp ordered' directive.
void setLoopData(unsigned NumLoop, Expr *Cnt)
Set the loop data.
OpenMPDoacrossClauseModifier getDependenceType() const
Get dependence type.
Expr * getLoopData(unsigned NumLoop)
Get the loop data.
static OMPDoacrossClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, OpenMPDoacrossClauseModifier DepType, SourceLocation DepLoc, SourceLocation ColonLoc, ArrayRef< Expr * > VL, unsigned NumLoops)
Creates clause with a list of expressions VL.
static OMPDoacrossClause * CreateEmpty(const ASTContext &C, unsigned N, unsigned NumLoops)
Creates an empty clause with N expressions.
This represents 'dyn_groupprivate' clause in 'pragma omp target ...' and 'pragma omp teams ....
Expr * getSize()
Get size.
OpenMPDynGroupprivateClauseFallbackModifier getDynGroupprivateFallbackModifier() const
Get the second modifier of the clause.
OpenMPDynGroupprivateClauseModifier getDynGroupprivateModifier() const
Get the first modifier of the clause.
static OMPExclusiveClause * CreateEmpty(const ASTContext &C, unsigned N)
Creates an empty clause with the place for N variables.
static OMPExclusiveClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, ArrayRef< Expr * > VL)
Creates clause with a list of variables VL.
This represents 'filter' clause in the 'pragma omp ...' directive.
Expr * getThreadID() const
Return thread identifier.
static OMPFlushClause * CreateEmpty(const ASTContext &C, unsigned N)
Creates an empty clause with N variables.
static OMPFlushClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, ArrayRef< Expr * > VL)
Creates clause with a list of variables VL.
This represents clause 'from' in the 'pragma omp ...' directives.
static OMPFromClause * Create(const ASTContext &C, const OMPVarListLocTy &Locs, ArrayRef< Expr * > Vars, ArrayRef< ValueDecl * > Declarations, MappableExprComponentListsRef ComponentLists, ArrayRef< Expr * > UDMapperRefs, Expr *IteratorExpr, ArrayRef< OpenMPMotionModifierKind > MotionModifiers, ArrayRef< SourceLocation > MotionModifiersLoc, NestedNameSpecifierLoc UDMQualifierLoc, DeclarationNameInfo MapperId)
Creates clause with a list of variables Vars.
static OMPFromClause * CreateEmpty(const ASTContext &C, const OMPMappableExprListSizeTy &Sizes)
Creates an empty clause with the place for NumVars variables.
This represents 'grainsize' clause in the 'pragma omp ...' directive.
OpenMPGrainsizeClauseModifier getModifier() const
Gets modifier.
Expr * getGrainsize() const
Return safe iteration space distance.
child_range used_children()
This represents clause 'has_device_ptr' in the 'pragma omp ...' directives.
static OMPHasDeviceAddrClause * Create(const ASTContext &C, const OMPVarListLocTy &Locs, ArrayRef< Expr * > Vars, ArrayRef< ValueDecl * > Declarations, MappableExprComponentListsRef ComponentLists)
Creates clause with a list of variables Vars.
static OMPHasDeviceAddrClause * CreateEmpty(const ASTContext &C, const OMPMappableExprListSizeTy &Sizes)
Creates an empty clause with the place for NumVars variables.
Expr * getHint() const
Returns number of threads.
static OMPInclusiveClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, ArrayRef< Expr * > VL)
Creates clause with a list of variables VL.
static OMPInclusiveClause * CreateEmpty(const ASTContext &C, unsigned N)
Creates an empty clause with the place for N variables.
bool getIsTarget() const
Returns true is interop-type 'target' is used.
static OMPInitClause * CreateEmpty(const ASTContext &C, unsigned NumPrefs, unsigned NumAttrs)
Creates an empty clause sized for NumPrefs pref-specs and NumAttrs total attr() exprs across them.
bool hasPreferAttrs() const
Returns true if OMP 6.0 {fr/attr} syntax is used.
Expr * getInteropVar()
Returns the interop variable.
static OMPInitClause * Create(const ASTContext &C, Expr *InteropVar, OMPInteropInfo &InteropInfo, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation VarLoc, SourceLocation EndLoc)
Creates a fully specified clause.
bool getIsTargetSync() const
Returns true is interop-type 'targetsync' is used.
auto prefs() const
Returns a range of PrefView objects, one per preference-specification, each carrying the fr() express...
This represents clause 'is_device_ptr' in the 'pragma omp ...' directives.
static OMPIsDevicePtrClause * Create(const ASTContext &C, const OMPVarListLocTy &Locs, ArrayRef< Expr * > Vars, ArrayRef< ValueDecl * > Declarations, MappableExprComponentListsRef ComponentLists)
Creates clause with a list of variables Vars.
static OMPIsDevicePtrClause * CreateEmpty(const ASTContext &C, const OMPMappableExprListSizeTy &Sizes)
Creates an empty clause with the place for NumVars variables.
This represents clause 'map' in the 'pragma omp ...' directives.
OpenMPMapClauseKind getMapType() const LLVM_READONLY
Fetches mapping kind for the clause.
OpenMPMapModifierKind getMapTypeModifier(unsigned Cnt) const LLVM_READONLY
Fetches the map-type-modifier at 'Cnt' index of array of modifiers.
static OMPMapClause * Create(const ASTContext &C, const OMPVarListLocTy &Locs, ArrayRef< Expr * > Vars, ArrayRef< ValueDecl * > Declarations, MappableExprComponentListsRef ComponentLists, ArrayRef< Expr * > UDMapperRefs, Expr *IteratorModifier, ArrayRef< OpenMPMapModifierKind > MapModifiers, ArrayRef< SourceLocation > MapModifiersLoc, NestedNameSpecifierLoc UDMQualifierLoc, DeclarationNameInfo MapperId, OpenMPMapClauseKind Type, bool TypeIsImplicit, SourceLocation TypeLoc)
Creates clause with a list of variables VL.
static OMPMapClause * CreateEmpty(const ASTContext &C, const OMPMappableExprListSizeTy &Sizes)
Creates an empty clause with the place for NumVars original expressions, NumUniqueDeclarations declar...
This represents 'nocontext' clause in the 'pragma omp ...' directive.
Expr * getCondition() const
Returns condition.
child_range used_children()
static OMPNontemporalClause * CreateEmpty(const ASTContext &C, unsigned N)
Creates an empty clause with the place for N variables.
static OMPNontemporalClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, ArrayRef< Expr * > VL)
Creates clause with a list of variables VL.
void setPrivateRefs(ArrayRef< Expr * > VL)
Sets the list of references to private copies created in private clauses.
This represents 'novariants' clause in the 'pragma omp ...' directive.
Expr * getCondition() const
Returns condition.
child_range used_children()
This represents 'num_tasks' clause in the 'pragma omp ...' directive.
OpenMPNumTasksClauseModifier getModifier() const
Gets modifier.
child_range used_children()
Expr * getNumTasks() const
Return safe iteration space distance.
This represents 'num_teams' clause in the 'pragma omp ...' directive.
static OMPNumTeamsClause * Create(const ASTContext &C, OpenMPDirectiveKind CaptureRegion, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, ArrayRef< Expr * > VL, Stmt *PreInit)
Creates clause with a list of variables VL.
static OMPNumTeamsClause * CreateEmpty(const ASTContext &C, unsigned N)
Creates an empty clause with N variables.
OpenMPOrderClauseKind getKind() const
Returns kind of the clause.
OpenMPOrderClauseModifier getModifier() const
Returns Modifier of the clause.
This represents 'priority' clause in the 'pragma omp ...' directive.
child_range used_children()
Expr * getPriority()
Return Priority number.
This represents 'thread_limit' clause in the 'pragma omp ...' directive.
static OMPThreadLimitClause * Create(const ASTContext &C, OpenMPDirectiveKind CaptureRegion, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, ArrayRef< Expr * > VL, Stmt *PreInit)
Creates clause with a list of variables VL.
static OMPThreadLimitClause * CreateEmpty(const ASTContext &C, unsigned N)
Creates an empty clause with N variables.
static OMPToClause * CreateEmpty(const ASTContext &C, const OMPMappableExprListSizeTy &Sizes)
Creates an empty clause with the place for NumVars variables.
static OMPToClause * Create(const ASTContext &C, const OMPVarListLocTy &Locs, ArrayRef< Expr * > Vars, ArrayRef< ValueDecl * > Declarations, MappableExprComponentListsRef ComponentLists, ArrayRef< Expr * > UDMapperRefs, Expr *IteratorModifier, ArrayRef< OpenMPMotionModifierKind > MotionModifiers, ArrayRef< SourceLocation > MotionModifiersLoc, NestedNameSpecifierLoc UDMQualifierLoc, DeclarationNameInfo MapperId)
Creates clause with a list of variables Vars.
std::string getMangledName() const
Return a string representation identifying this context selector.
void print(llvm::raw_ostream &OS, const PrintingPolicy &Policy) const
Print a human readable representation into OS.
void getAsVariantMatchInfo(ASTContext &ASTCtx, llvm::omp::VariantMatchInfo &VMI) const
Create a variant match info object from this trait info object.
llvm::SmallVector< OMPTraitSet, 2 > Sets
The outermost level of selector sets.
Expr * getInteropVar() const
Returns the interop variable.
This represents clause 'use_device_addr' in the 'pragma omp ...' directives.
static OMPUseDeviceAddrClause * Create(const ASTContext &C, const OMPVarListLocTy &Locs, ArrayRef< Expr * > Vars, ArrayRef< ValueDecl * > Declarations, MappableExprComponentListsRef ComponentLists)
Creates clause with a list of variables Vars.
static OMPUseDeviceAddrClause * CreateEmpty(const ASTContext &C, const OMPMappableExprListSizeTy &Sizes)
Creates an empty clause with the place for NumVars variables.
This represents clause 'use_device_ptr' in the 'pragma omp ...' directives.
static OMPUseDevicePtrClause * Create(const ASTContext &C, const OMPVarListLocTy &Locs, ArrayRef< Expr * > Vars, ArrayRef< Expr * > PrivateVars, ArrayRef< Expr * > Inits, ArrayRef< ValueDecl * > Declarations, MappableExprComponentListsRef ComponentLists, OpenMPUseDevicePtrFallbackModifier FallbackModifier, SourceLocation FallbackModifierLoc)
Creates clause with a list of variables Vars.
OpenMPUseDevicePtrFallbackModifier getFallbackModifier() const
Get the fallback modifier for the clause.
static OMPUseDevicePtrClause * CreateEmpty(const ASTContext &C, const OMPMappableExprListSizeTy &Sizes)
Creates an empty clause with the place for NumVars variables.
This represents clause 'uses_allocators' in the 'pragma omp target'-based directives.
OMPUsesAllocatorsClause::Data getAllocatorData(unsigned I) const
Returns data for the specified allocator.
static OMPUsesAllocatorsClause * CreateEmpty(const ASTContext &C, unsigned N)
Creates an empty clause with the place for N allocators.
static OMPUsesAllocatorsClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, ArrayRef< OMPUsesAllocatorsClause::Data > Data)
Creates clause with a list of allocators Data.
unsigned getNumberOfAllocators() const
Returns number of allocators associated with the clause.
ArrayRef< const Attr * > getAttrs() const
Returned the attributes parsed from this clause.
This represents 'ompx_dyn_cgroup_mem' clause in the 'pragma omp target ...' directive.
Expr * getSize()
Return the size expression.
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
const TargetInfo & getTargetInfo() const
void getFunctionFeatureMap(llvm::StringMap< bool > &FeatureMap, const FunctionDecl *) const
static QualType getBaseOriginalType(const Expr *Base)
Return original type of the base expression for array section.
Attr - This represents one attribute.
void printPretty(raw_ostream &OS, const PrintingPolicy &Policy) const
This represents one expression.
Represents a function declaration or definition.
Keeps track of the various options that can be enabled, which controls the dialect of C or C++ that i...
A C++ nested-name-specifier augmented with source location information.
Represents a C++ nested name specifier, such as "\::std::vector<int>::".
void print(raw_ostream &OS, const PrintingPolicy &Policy, bool ResolveTemplateArguments=false, bool PrintFinalScopeResOp=true) const
Print this nested name specifier to the given output stream.
This represents the 'align' clause in the 'pragma omp allocate' directive.
Expr * getAlignment() const
Returns alignment.
static OMPAlignClause * Create(const ASTContext &C, Expr *A, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc)
Build 'align' clause with the given alignment.
This represents clause 'allocate' in the 'pragma omp ...' directives.
static OMPAllocateClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, Expr *Allocator, Expr *Alignment, SourceLocation ColonLoc, OpenMPAllocateClauseModifier Modifier1, SourceLocation Modifier1Loc, OpenMPAllocateClauseModifier Modifier2, SourceLocation Modifier2Loc, SourceLocation EndLoc, ArrayRef< Expr * > VL)
Creates clause with a list of variables VL.
OpenMPAllocateClauseModifier getSecondAllocateModifier() const
Get the second modifier of the clause.
Expr * getAlignment() const
Returns the alignment expression or nullptr, if no alignment specified.
OpenMPAllocateClauseModifier getFirstAllocateModifier() const
Get the first modifier of the clause.
Expr * getAllocator() const
Returns the allocator expression or nullptr, if no allocator is specified.
static OMPAllocateClause * CreateEmpty(const ASTContext &C, unsigned N)
Creates an empty clause with the place for N variables.
This represents 'allocator' clause in the 'pragma omp ...' directive.
Expr * getAllocator() const
Returns allocator.
static OMPClauseWithPostUpdate * get(OMPClause *C)
OMPClauseWithPostUpdate(const OMPClause *This)
const Stmt * getPreInitStmt() const
Get pre-initialization statement for the clause.
OMPClauseWithPreInit(const OMPClause *This)
static OMPClauseWithPreInit * get(OMPClause *C)
This is a basic class for representing single OpenMP clause.
child_range used_children()
Get the iterator range for the expressions used in the clauses.
llvm::iterator_range< child_iterator > child_range
OpenMPClauseKind getClauseKind() const
Returns kind of OpenMP clause (private, shared, reduction, etc.).
This represents 'collapse' clause in the 'pragma omp ...' directive.
Expr * getNumForLoops() const
Return the number of associated for-loops.
This represents the 'counts' clause in the 'pragma omp split' directive.
std::optional< unsigned > getOmpFillIndex() const
static OMPCountsClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, ArrayRef< Expr * > Counts, std::optional< unsigned > FillIdx, SourceLocation FillLoc)
Build a 'counts' AST node.
static OMPCountsClause * CreateEmpty(const ASTContext &C, unsigned NumCounts)
Build an empty 'counts' AST node for deserialization.
MutableArrayRef< Expr * > getCountsRefs()
Returns the count expressions.
This represents 'default' clause in the 'pragma omp ...' directive.
llvm::omp::DefaultKind getDefaultKind() const
Returns kind of the clause.
OpenMPDefaultClauseVariableCategory getDefaultVC() const
This represents 'final' clause in the 'pragma omp ...' directive.
child_range used_children()
Expr * getCondition() const
Returns condition.
Representation of the 'full' clause of the 'pragma omp unroll' directive.
static OMPFullClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc)
Build an AST node for a 'full' clause.
static OMPFullClause * CreateEmpty(const ASTContext &C)
Build an empty 'full' AST node for deserialization.
This represents 'if' clause in the 'pragma omp ...' directive.
child_range used_children()
Expr * getCondition() const
Returns condition.
OpenMPDirectiveKind getNameModifier() const
Return directive name modifier associated with the clause.
This class represents the 'looprange' clause in the 'pragma omp fuse' directive.
Expr * getFirst() const
Get looprange 'first' expression.
static OMPLoopRangeClause * CreateEmpty(const ASTContext &C)
Build an empty 'looprange' clause node.
static OMPLoopRangeClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation FirstLoc, SourceLocation CountLoc, SourceLocation EndLoc, Expr *First, Expr *Count)
Build a 'looprange' clause AST node.
Expr * getCount() const
Get looprange 'count' expression.
This represents 'num_threads' clause in the 'pragma omp ...' directive.
OpenMPNumThreadsClauseModifier getModifier() const
Gets modifier.
Expr * getNumThreads() const
Returns number of threads.
llvm::iterator_range< child_iterator > child_range
Representation of the 'partial' clause of the 'pragma omp unroll' directive.
static OMPPartialClause * CreateEmpty(const ASTContext &C)
Build an empty 'partial' AST node for deserialization.
static OMPPartialClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, Expr *Factor)
Build an AST node for a 'partial' clause.
Expr * getFactor() const
Returns the argument of the clause or nullptr if not set.
This class represents the 'permutation' clause in the 'pragma omp interchange' directive.
MutableArrayRef< Expr * > getArgsRefs()
Returns the permutation index expressions.
static OMPPermutationClause * CreateEmpty(const ASTContext &C, unsigned NumLoops)
Build an empty 'permutation' AST node for deserialization.
static OMPPermutationClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, ArrayRef< Expr * > Args)
Build a 'permutation' clause AST node.
This represents 'safelen' clause in the 'pragma omp ...' directive.
Expr * getSafelen() const
Return safe iteration space distance.
This represents 'simdlen' clause in the 'pragma omp ...' directive.
Expr * getSimdlen() const
Return safe iteration space distance.
This represents the 'sizes' clause in the 'pragma omp tile' directive.
static OMPSizesClause * Create(const ASTContext &C, SourceLocation StartLoc, SourceLocation LParenLoc, SourceLocation EndLoc, ArrayRef< Expr * > Sizes)
Build a 'sizes' AST node.
MutableArrayRef< Expr * > getSizesRefs()
Returns the tile size expressions.
static OMPSizesClause * CreateEmpty(const ASTContext &C, unsigned NumSizes)
Build an empty 'sizes' AST node for deserialization.
This represents 'threadset' clause in the 'pragma omp task ...' directive.
OpenMPThreadsetKind getThreadsetKind() const
Returns kind of the clause.
bool varlist_empty() const
A (possibly-)qualified type.
QualType getNonReferenceType() const
If Type is a reference type (e.g., const int&), returns the type that the reference refers to ("const...
QualType getCanonicalType() const
Smart pointer class that efficiently represents Objective-C method names.
Encodes a location in the source.
Stmt - This represents one statement.
void printPretty(raw_ostream &OS, PrinterHelper *Helper, const PrintingPolicy &Policy, unsigned Indentation=0, StringRef NewlineSymbol="\n", const ASTContext *Context=nullptr) const
Base wrapper for a particular "section" of type source info.
The base class of the type hierarchy.
bool isPointerType() const
QualType getPointeeType() const
If this is a pointer, ObjC object pointer, or block pointer, this returns the respective pointee.
Represent the declaration of a variable (in which case it is an lvalue) a function (in which case it ...
Defines the clang::TargetInfo interface.
@ OS
Indicates that the tracking object is a descendant of a referenced-counted OSObject,...
The JSON file list parser is used to communicate input to InstallAPI.
OpenMPOriginalSharingModifier
OpenMP 6.0 original sharing modifiers.
OverloadedOperatorKind
Enumeration specifying the different kinds of C++ overloaded operators.
@ OO_None
Not an overloaded operator.
Privates[]
This class represents the 'transparent' clause in the 'pragma omp task' directive.
bool isa(CodeGen::Address addr)
MutableArrayRef< Expr * > getFinals()
Sets the list of final update expressions for linear variables.
if(T->getSizeExpr()) TRY_TO(TraverseStmt(const_cast< Expr * >(T -> getSizeExpr())))
@ OMPC_ORDER_MODIFIER_unknown
MutableArrayRef< Expr * > getPrivates()
Finals[]; Step; CalcStep; }.
OpenMPReductionClauseModifier
OpenMP modifiers for 'reduction' clause.
@ DeviceNum
'device_num' clause, allowed on 'init', 'shutdown', and 'set' constructs.
@ OMPC_SCHEDULE_MODIFIER_unknown
const char * getOpenMPSimpleClauseTypeName(OpenMPClauseKind Kind, unsigned Type)
OpenMPDoacrossClauseModifier
OpenMP dependence types for 'doacross' clause.
static constexpr unsigned NumberOfOMPMapClauseModifiers
Number of allowed map-type-modifiers.
@ OMPC_DYN_GROUPPRIVATE_FALLBACK_unknown
OpenMPBindClauseKind
OpenMP bindings for the 'bind' clause.
OpenMPLastprivateModifier
OpenMP 'lastprivate' clause modifier.
@ OMPC_LASTPRIVATE_unknown
OpenMPDependClauseKind
OpenMP attributes for 'depend' clause.
OpenMPGrainsizeClauseModifier
OpenMPNumTasksClauseModifier
OpenMPUseDevicePtrFallbackModifier
OpenMP 6.1 use_device_ptr fallback modifier.
@ OMPC_USE_DEVICE_PTR_FALLBACK_unknown
MutableArrayRef< Expr * > getUsedExprs()
Gets the list of used expressions for linear variables.
static constexpr unsigned NumberOfOMPMotionModifiers
Number of allowed motion-modifiers.
@ OMPC_MOTION_MODIFIER_unknown
@ OMPC_DEFAULTMAP_unknown
OpenMPAllocateClauseModifier
OpenMP modifiers for 'allocate' clause.
OpenMPLinearClauseKind
OpenMP attributes for 'linear' clause.
llvm::omp::Directive OpenMPDirectiveKind
OpenMP directives.
@ OMPC_DYN_GROUPPRIVATE_unknown
MutableArrayRef< Expr * > getUpdates()
Sets the list of update expressions for linear variables.
MutableArrayRef< Expr * > getInits()
OpenMPNumThreadsClauseModifier
@ OMPC_NUMTHREADS_unknown
const StreamingDiagnostic & operator<<(const StreamingDiagnostic &DB, const ConceptReference *C)
Insertion operator for diagnostics.
const char * getOperatorSpelling(OverloadedOperatorKind Operator)
Retrieve the spelling of the given overloaded operator, without the preceding "operator" keyword.
U cast(CodeGen::Address addr)
const char * getOpenMPDefaultVariableCategoryName(unsigned VC)
OpenMPDeviceClauseModifier
OpenMP modifiers for 'device' clause.
@ OMPC_MAP_MODIFIER_unknown
OpenMPMapClauseKind
OpenMP mapping kind for 'map' clause.
Diagnostic wrappers for TextAPI types for error reporting.
int const char * function
ArrayRef< Expr * > Attrs
attr() string-literal expressions. Empty for fr-only or OMP 5.1 flat specs.
This structure contains all sizes needed for by an OMPMappableExprListClause.
unsigned NumComponents
Total number of expression components.
unsigned NumUniqueDeclarations
Number of unique base declarations.
unsigned NumVars
Number of expressions listed.
unsigned NumComponentLists
Number of component lists.
Data for list of allocators.
Expr * AllocatorTraits
Allocator traits.
Expr * Allocator
Allocator.
SourceLocation LParenLoc
Locations of '(' and ')' symbols.
TargetOMPContext(ASTContext &ASTCtx, std::function< void(StringRef)> &&DiagUnknownTrait, const FunctionDecl *CurrentFunctionDecl, ArrayRef< llvm::omp::TraitProperty > ConstructTraits, int DeviceNum)
bool matchesISATrait(StringRef RawString) const override
See llvm::omp::OMPContext::matchesISATrait.
DeclarationNameInfo - A collector data type for bundling together a DeclarationName and the correspon...
llvm::SmallVector< OMPInteropPref, 4 > Prefs
One entry of a prefer_type list.
llvm::SmallVector< Expr *, 2 > Attrs
This structure contains most locations needed for by an OMPVarListClause.
Describes how types, statements, expressions, and declarations should be printed.