15#include "llvm/ADT/StringRef.h"
16#include "llvm/ADT/StringSwitch.h"
17#include "llvm/Support/ErrorHandling.h"
21using namespace llvm::omp;
26 return llvm::StringSwitch<OpenMPDefaultClauseVariableCategory>(Str)
27#define OPENMP_DEFAULT_VARIABLE_CATEGORY(Name) \
28 .Case(#Name, OMPC_DEFAULT_VC_##Name)
29#include "clang/Basic/OpenMPKinds.def"
35#define OPENMP_DEFAULT_VARIABLE_CATEGORY(Name) \
36 case OMPC_DEFAULT_VC_##Name: \
38#include "clang/Basic/OpenMPKinds.def"
40 llvm_unreachable(
"Invalid Variable Category in the default clause");
47 return llvm::StringSwitch<unsigned>(Str)
48#define OMP_DEFAULT_KIND(Enum, Name) .Case(Name, unsigned(Enum))
49#include "llvm/Frontend/OpenMP/OMPKinds.def"
50 .Default(
unsigned(llvm::omp::OMP_DEFAULT_unknown));
52 return llvm::StringSwitch<unsigned>(Str)
53#define OMP_PROC_BIND_KIND(Enum, Name, Value) .Case(Name, Value)
54#include "llvm/Frontend/OpenMP/OMPKinds.def"
55 .Default(
unsigned(llvm::omp::OMP_PROC_BIND_unknown));
57 return llvm::StringSwitch<unsigned>(Str)
58#define OPENMP_SCHEDULE_KIND(Name) \
59 .Case(#Name, static_cast<unsigned>(OMPC_SCHEDULE_##Name))
60#define OPENMP_SCHEDULE_MODIFIER(Name) \
61 .Case(#Name, static_cast<unsigned>(OMPC_SCHEDULE_MODIFIER_##Name))
62#include "clang/Basic/OpenMPKinds.def"
65 unsigned Type = llvm::StringSwitch<unsigned>(Str)
66#define OPENMP_DEPEND_KIND(Name) .Case(#Name, OMPC_DEPEND_##Name)
67#include "clang/Basic/OpenMPKinds.def"
69 if (LangOpts.OpenMP < 51 &&
Type == OMPC_DEPEND_inoutset)
74 return llvm::StringSwitch<OpenMPDoacrossClauseModifier>(Str)
75#define OPENMP_DOACROSS_MODIFIER(Name) .Case(#Name, OMPC_DOACROSS_##Name)
76#include "clang/Basic/OpenMPKinds.def"
79 return llvm::StringSwitch<OpenMPLinearClauseKind>(Str)
80#define OPENMP_LINEAR_KIND(Name) .Case(#Name, OMPC_LINEAR_##Name)
81#include "clang/Basic/OpenMPKinds.def"
84 unsigned Type = llvm::StringSwitch<unsigned>(Str)
85#define OPENMP_MAP_KIND(Name) \
86 .Case(#Name, static_cast<unsigned>(OMPC_MAP_##Name))
87#define OPENMP_MAP_MODIFIER_KIND(Name) \
88 .Case(#Name, static_cast<unsigned>(OMPC_MAP_MODIFIER_##Name))
89#include "clang/Basic/OpenMPKinds.def"
91 if (LangOpts.OpenMP < 51 &&
Type == OMPC_MAP_MODIFIER_present)
93 if (!LangOpts.OpenMPExtensions &&
Type == OMPC_MAP_MODIFIER_ompx_hold)
99 unsigned Type = llvm::StringSwitch<unsigned>(Str)
100#define OPENMP_MOTION_MODIFIER_KIND(Name) \
101 .Case(#Name, static_cast<unsigned>(OMPC_MOTION_MODIFIER_##Name))
102#include "clang/Basic/OpenMPKinds.def"
104 if (LangOpts.OpenMP < 51 &&
Type == OMPC_MOTION_MODIFIER_present)
108 case OMPC_dist_schedule:
109 return llvm::StringSwitch<OpenMPDistScheduleClauseKind>(Str)
110#define OPENMP_DIST_SCHEDULE_KIND(Name) .Case(#Name, OMPC_DIST_SCHEDULE_##Name)
111#include "clang/Basic/OpenMPKinds.def"
113 case OMPC_defaultmap: {
114 unsigned Type = llvm::StringSwitch<unsigned>(Str)
115#define OPENMP_DEFAULTMAP_KIND(Name) \
116 .Case(#Name, static_cast<unsigned>(OMPC_DEFAULTMAP_##Name))
117#define OPENMP_DEFAULTMAP_MODIFIER(Name) \
118 .Case(#Name, static_cast<unsigned>(OMPC_DEFAULTMAP_MODIFIER_##Name))
119#include "clang/Basic/OpenMPKinds.def"
121 if (LangOpts.OpenMP < 60 && (
Type == OMPC_DEFAULTMAP_MODIFIER_storage ||
122 Type == OMPC_DEFAULTMAP_MODIFIER_private))
126 case OMPC_atomic_default_mem_order:
127 return llvm::StringSwitch<OpenMPAtomicDefaultMemOrderClauseKind>(Str)
128#define OPENMP_ATOMIC_DEFAULT_MEM_ORDER_KIND(Name) \
129 .Case(#Name, OMPC_ATOMIC_DEFAULT_MEM_ORDER_##Name)
130#include "clang/Basic/OpenMPKinds.def"
133 return static_cast<unsigned int>(llvm::StringSwitch<llvm::omp::Clause>(Str)
134#define OPENMP_ATOMIC_FAIL_MODIFIER(Name) .Case(#Name, OMPC_##Name)
135#include "clang/Basic/OpenMPKinds.def"
136 .Default(OMPC_unknown));
137 case OMPC_device_type:
138 return llvm::StringSwitch<OpenMPDeviceType>(Str)
139#define OPENMP_DEVICE_TYPE_KIND(Name) .Case(#Name, OMPC_DEVICE_TYPE_##Name)
140#include "clang/Basic/OpenMPKinds.def"
143 return llvm::StringSwitch<OpenMPAtClauseKind>(Str)
144#define OPENMP_AT_KIND(Name) .Case(#Name, OMPC_AT_##Name)
145#include "clang/Basic/OpenMPKinds.def"
148 return llvm::StringSwitch<OpenMPSeverityClauseKind>(Str)
149#define OPENMP_SEVERITY_KIND(Name) .Case(#Name, OMPC_SEVERITY_##Name)
150#include "clang/Basic/OpenMPKinds.def"
152 case OMPC_lastprivate:
153 return llvm::StringSwitch<OpenMPLastprivateModifier>(Str)
154#define OPENMP_LASTPRIVATE_KIND(Name) .Case(#Name, OMPC_LASTPRIVATE_##Name)
155#include "clang/Basic/OpenMPKinds.def"
158 return llvm::StringSwitch<unsigned>(Str)
159#define OPENMP_ORDER_KIND(Name) \
160 .Case(#Name, static_cast<unsigned>(OMPC_ORDER_##Name))
161#define OPENMP_ORDER_MODIFIER(Name) \
162 .Case(#Name, static_cast<unsigned>(OMPC_ORDER_MODIFIER_##Name))
163#include "clang/Basic/OpenMPKinds.def"
166 return llvm::StringSwitch<OpenMPDependClauseKind>(Str)
167#define OPENMP_DEPEND_KIND(Name) .Case(#Name, OMPC_DEPEND_##Name)
168#include "clang/Basic/OpenMPKinds.def"
171 return llvm::StringSwitch<OpenMPDeviceClauseModifier>(Str)
172#define OPENMP_DEVICE_MODIFIER(Name) .Case(#Name, OMPC_DEVICE_##Name)
173#include "clang/Basic/OpenMPKinds.def"
176 return llvm::StringSwitch<OpenMPReductionClauseModifier>(Str)
177#define OPENMP_REDUCTION_MODIFIER(Name) .Case(#Name, OMPC_REDUCTION_##Name)
178#include "clang/Basic/OpenMPKinds.def"
180 case OMPC_adjust_args:
181 return llvm::StringSwitch<OpenMPAdjustArgsOpKind>(Str)
182#define OPENMP_ADJUST_ARGS_KIND(Name) .Case(#Name, OMPC_ADJUST_ARGS_##Name)
183#include "clang/Basic/OpenMPKinds.def"
186 return llvm::StringSwitch<unsigned>(Str)
187#define OPENMP_BIND_KIND(Name) .Case(#Name, OMPC_BIND_##Name)
188#include "clang/Basic/OpenMPKinds.def"
190 case OMPC_grainsize: {
191 unsigned Type = llvm::StringSwitch<unsigned>(Str)
192#define OPENMP_GRAINSIZE_MODIFIER(Name) .Case(#Name, OMPC_GRAINSIZE_##Name)
193#include "clang/Basic/OpenMPKinds.def"
195 if (LangOpts.OpenMP < 51)
199 case OMPC_dyn_groupprivate: {
200 return llvm::StringSwitch<unsigned>(Str)
201#define OPENMP_DYN_GROUPPRIVATE_MODIFIER(Name) \
202 .Case(#Name, OMPC_DYN_GROUPPRIVATE_##Name)
203#define OPENMP_DYN_GROUPPRIVATE_FALLBACK_MODIFIER(Name) \
204 .Case(#Name, OMPC_DYN_GROUPPRIVATE_FALLBACK_##Name) \
205 .Case("fallback(" #Name ")", OMPC_DYN_GROUPPRIVATE_FALLBACK_##Name)
206#include "clang/Basic/OpenMPKinds.def"
209 case OMPC_num_tasks: {
210 unsigned Type = llvm::StringSwitch<unsigned>(Str)
211#define OPENMP_NUMTASKS_MODIFIER(Name) .Case(#Name, OMPC_NUMTASKS_##Name)
212#include "clang/Basic/OpenMPKinds.def"
214 if (LangOpts.OpenMP < 51)
219 return llvm::StringSwitch<OpenMPAllocateClauseModifier>(Str)
220#define OPENMP_ALLOCATE_MODIFIER(Name) .Case(#Name, OMPC_ALLOCATE_##Name)
221#include "clang/Basic/OpenMPKinds.def"
223 case OMPC_threadset: {
224 unsigned Type = llvm::StringSwitch<unsigned>(Str)
225#define OPENMP_THREADSET_KIND(Name) .Case(#Name, OMPC_THREADSET_##Name)
226#include "clang/Basic/OpenMPKinds.def"
228 if (LangOpts.OpenMP < 60)
232 case OMPC_num_threads: {
233 unsigned Type = llvm::StringSwitch<unsigned>(Str)
234#define OPENMP_NUMTHREADS_MODIFIER(Name) .Case(#Name, OMPC_NUMTHREADS_##Name)
235#include "clang/Basic/OpenMPKinds.def"
237 if (LangOpts.OpenMP < 60)
241 case OMPC_use_device_ptr: {
242 unsigned Type = llvm::StringSwitch<unsigned>(Str)
243#define OPENMP_USE_DEVICE_PTR_FALLBACK_MODIFIER(Name) \
244 .Case(#Name, OMPC_USE_DEVICE_PTR_FALLBACK_##Name)
245#include "clang/Basic/OpenMPKinds.def"
247 if (LangOpts.OpenMP < 61)
252 case OMPC_threadprivate:
253 case OMPC_groupprivate:
260 case OMPC_permutation:
264 case OMPC_firstprivate:
266 case OMPC_task_reduction:
267 case OMPC_in_reduction:
270 case OMPC_copyprivate:
289 case OMPC_thread_limit:
294 case OMPC_use_device_addr:
295 case OMPC_is_device_ptr:
296 case OMPC_has_device_addr:
297 case OMPC_unified_address:
298 case OMPC_unified_shared_memory:
299 case OMPC_reverse_offload:
300 case OMPC_dynamic_allocators:
303 case OMPC_nontemporal:
305 case OMPC_novariants:
310 case OMPC_uses_allocators:
313 case OMPC_append_args:
319 llvm_unreachable(
"Invalid OpenMP simple clause kind");
326 switch (llvm::omp::DefaultKind(
Type)) {
327#define OMP_DEFAULT_KIND(Enum, Name) \
330#include "llvm/Frontend/OpenMP/OMPKinds.def"
332 llvm_unreachable(
"Invalid OpenMP 'default' clause type");
335#define OMP_PROC_BIND_KIND(Enum, Name, Value) \
338#include "llvm/Frontend/OpenMP/OMPKinds.def"
340 llvm_unreachable(
"Invalid OpenMP 'proc_bind' clause type");
346#define OPENMP_SCHEDULE_KIND(Name) \
347 case OMPC_SCHEDULE_##Name: \
349#define OPENMP_SCHEDULE_MODIFIER(Name) \
350 case OMPC_SCHEDULE_MODIFIER_##Name: \
352#include "clang/Basic/OpenMPKinds.def"
354 llvm_unreachable(
"Invalid OpenMP 'schedule' clause type");
359#define OPENMP_DEPEND_KIND(Name) \
360 case OMPC_DEPEND_##Name: \
362#include "clang/Basic/OpenMPKinds.def"
364 llvm_unreachable(
"Invalid OpenMP 'depend' clause type");
369#define OPENMP_DOACROSS_MODIFIER(Name) \
370 case OMPC_DOACROSS_##Name: \
372#include "clang/Basic/OpenMPKinds.def"
374 llvm_unreachable(
"Invalid OpenMP 'doacross' clause type");
379#define OPENMP_LINEAR_KIND(Name) \
380 case OMPC_LINEAR_##Name: \
382#include "clang/Basic/OpenMPKinds.def"
384 llvm_unreachable(
"Invalid OpenMP 'linear' clause type");
390#define OPENMP_MAP_KIND(Name) \
391 case OMPC_MAP_##Name: \
393#define OPENMP_MAP_MODIFIER_KIND(Name) \
394 case OMPC_MAP_MODIFIER_##Name: \
396#include "clang/Basic/OpenMPKinds.def"
400 llvm_unreachable(
"Invalid OpenMP 'map' clause type");
406#define OPENMP_MOTION_MODIFIER_KIND(Name) \
407 case OMPC_MOTION_MODIFIER_##Name: \
409#include "clang/Basic/OpenMPKinds.def"
413 llvm_unreachable(
"Invalid OpenMP 'to' or 'from' clause type");
414 case OMPC_dist_schedule:
418#define OPENMP_DIST_SCHEDULE_KIND(Name) \
419 case OMPC_DIST_SCHEDULE_##Name: \
421#include "clang/Basic/OpenMPKinds.def"
423 llvm_unreachable(
"Invalid OpenMP 'dist_schedule' clause type");
424 case OMPC_defaultmap:
429#define OPENMP_DEFAULTMAP_KIND(Name) \
430 case OMPC_DEFAULTMAP_##Name: \
432#define OPENMP_DEFAULTMAP_MODIFIER(Name) \
433 case OMPC_DEFAULTMAP_MODIFIER_##Name: \
435#include "clang/Basic/OpenMPKinds.def"
437 llvm_unreachable(
"Invalid OpenMP 'defaultmap' clause type");
438 case OMPC_atomic_default_mem_order:
442#define OPENMP_ATOMIC_DEFAULT_MEM_ORDER_KIND(Name) \
443 case OMPC_ATOMIC_DEFAULT_MEM_ORDER_##Name: \
445#include "clang/Basic/OpenMPKinds.def"
447 llvm_unreachable(
"Invalid OpenMP 'atomic_default_mem_order' clause type");
448 case OMPC_device_type:
452#define OPENMP_DEVICE_TYPE_KIND(Name) \
453 case OMPC_DEVICE_TYPE_##Name: \
455#include "clang/Basic/OpenMPKinds.def"
457 llvm_unreachable(
"Invalid OpenMP 'device_type' clause type");
462#define OPENMP_AT_KIND(Name) \
463 case OMPC_AT_##Name: \
465#include "clang/Basic/OpenMPKinds.def"
467 llvm_unreachable(
"Invalid OpenMP 'at' clause type");
472#define OPENMP_SEVERITY_KIND(Name) \
473 case OMPC_SEVERITY_##Name: \
475#include "clang/Basic/OpenMPKinds.def"
477 llvm_unreachable(
"Invalid OpenMP 'severity' clause type");
478 case OMPC_lastprivate:
482#define OPENMP_LASTPRIVATE_KIND(Name) \
483 case OMPC_LASTPRIVATE_##Name: \
485#include "clang/Basic/OpenMPKinds.def"
487 llvm_unreachable(
"Invalid OpenMP 'lastprivate' clause type");
493#define OPENMP_ORDER_KIND(Name) \
494 case OMPC_ORDER_##Name: \
496#define OPENMP_ORDER_MODIFIER(Name) \
497 case OMPC_ORDER_MODIFIER_##Name: \
499#include "clang/Basic/OpenMPKinds.def"
501 llvm_unreachable(
"Invalid OpenMP 'order' clause type");
506#define OPENMP_DEPEND_KIND(Name) \
507 case OMPC_DEPEND_##Name: \
509#include "clang/Basic/OpenMPKinds.def"
511 llvm_unreachable(
"Invalid OpenMP 'depend' clause type");
514 return getOpenMPClauseName(CK).data();
515 llvm_unreachable(
"Invalid OpenMP 'fail' clause modifier");
521#define OPENMP_DEVICE_MODIFIER(Name) \
522 case OMPC_DEVICE_##Name: \
524#include "clang/Basic/OpenMPKinds.def"
526 llvm_unreachable(
"Invalid OpenMP 'device' clause modifier");
531#define OPENMP_REDUCTION_MODIFIER(Name) \
532 case OMPC_REDUCTION_##Name: \
534#include "clang/Basic/OpenMPKinds.def"
536 llvm_unreachable(
"Invalid OpenMP 'reduction' clause modifier");
537 case OMPC_adjust_args:
541#define OPENMP_ADJUST_ARGS_KIND(Name) \
542 case OMPC_ADJUST_ARGS_##Name: \
544#include "clang/Basic/OpenMPKinds.def"
546 llvm_unreachable(
"Invalid OpenMP 'adjust_args' clause kind");
551#define OPENMP_BIND_KIND(Name) \
552 case OMPC_BIND_##Name: \
554#include "clang/Basic/OpenMPKinds.def"
556 llvm_unreachable(
"Invalid OpenMP 'bind' clause type");
561#define OPENMP_GRAINSIZE_MODIFIER(Name) \
562 case OMPC_GRAINSIZE_##Name: \
564#include "clang/Basic/OpenMPKinds.def"
566 llvm_unreachable(
"Invalid OpenMP 'grainsize' clause modifier");
567 case OMPC_dyn_groupprivate:
572#define OPENMP_DYN_GROUPPRIVATE_MODIFIER(Name) \
573 case OMPC_DYN_GROUPPRIVATE_##Name: \
575#define OPENMP_DYN_GROUPPRIVATE_FALLBACK_MODIFIER(Name) \
576 case OMPC_DYN_GROUPPRIVATE_FALLBACK_##Name: \
577 return "fallback(" #Name ")";
578#include "clang/Basic/OpenMPKinds.def"
580 llvm_unreachable(
"Invalid OpenMP 'dyn_groupprivate' clause modifier");
585#define OPENMP_NUMTASKS_MODIFIER(Name) \
586 case OMPC_NUMTASKS_##Name: \
588#include "clang/Basic/OpenMPKinds.def"
590 llvm_unreachable(
"Invalid OpenMP 'num_tasks' clause modifier");
595#define OPENMP_ALLOCATE_MODIFIER(Name) \
596 case OMPC_ALLOCATE_##Name: \
598#include "clang/Basic/OpenMPKinds.def"
600 llvm_unreachable(
"Invalid OpenMP 'allocate' clause modifier");
601 case OMPC_num_threads:
605#define OPENMP_NUMTHREADS_MODIFIER(Name) \
606 case OMPC_NUMTHREADS_##Name: \
608#include "clang/Basic/OpenMPKinds.def"
610 llvm_unreachable(
"Invalid OpenMP 'num_threads' clause modifier");
615#define OPENMP_THREADSET_KIND(Name) \
616 case OMPC_THREADSET_##Name: \
618#include "clang/Basic/OpenMPKinds.def"
620 llvm_unreachable(
"Invalid OpenMP 'threadset' clause modifier");
621 case OMPC_use_device_ptr:
625#define OPENMP_USE_DEVICE_PTR_FALLBACK_MODIFIER(Name) \
626 case OMPC_USE_DEVICE_PTR_FALLBACK_##Name: \
628#include "clang/Basic/OpenMPKinds.def"
630 llvm_unreachable(
"Invalid OpenMP 'use_device_ptr' clause modifier");
632 case OMPC_threadprivate:
633 case OMPC_groupprivate:
640 case OMPC_permutation:
644 case OMPC_firstprivate:
646 case OMPC_task_reduction:
647 case OMPC_in_reduction:
650 case OMPC_copyprivate:
669 case OMPC_thread_limit:
674 case OMPC_use_device_addr:
675 case OMPC_is_device_ptr:
676 case OMPC_has_device_addr:
677 case OMPC_unified_address:
678 case OMPC_unified_shared_memory:
679 case OMPC_reverse_offload:
680 case OMPC_dynamic_allocators:
683 case OMPC_nontemporal:
686 case OMPC_novariants:
690 case OMPC_uses_allocators:
693 case OMPC_append_args:
699 llvm_unreachable(
"Invalid OpenMP simple clause kind");
703 return getDirectiveAssociation(DKind) == Association::LoopNest;
707 return DKind == OMPD_for || DKind == OMPD_for_simd ||
708 DKind == OMPD_sections || DKind == OMPD_section ||
709 DKind == OMPD_single || DKind == OMPD_parallel_for ||
710 DKind == OMPD_parallel_for_simd || DKind == OMPD_parallel_sections ||
711 DKind == OMPD_target_parallel_for ||
712 DKind == OMPD_distribute_parallel_for ||
713 DKind == OMPD_distribute_parallel_for_simd ||
714 DKind == OMPD_target_parallel_for_simd ||
715 DKind == OMPD_teams_distribute_parallel_for_simd ||
716 DKind == OMPD_teams_distribute_parallel_for ||
717 DKind == OMPD_target_teams_distribute_parallel_for ||
718 DKind == OMPD_target_teams_distribute_parallel_for_simd ||
719 DKind == OMPD_parallel_loop || DKind == OMPD_teams_loop ||
720 DKind == OMPD_target_parallel_loop || DKind == OMPD_target_teams_loop;
724 return DKind == OMPD_taskloop ||
725 llvm::is_contained(getLeafConstructs(DKind), OMPD_taskloop);
729 if (DKind == OMPD_teams_loop)
731 return DKind == OMPD_parallel ||
732 llvm::is_contained(getLeafConstructs(DKind), OMPD_parallel);
736 return DKind == OMPD_target ||
737 llvm::is_contained(getLeafConstructs(DKind), OMPD_target);
741 return DKind == OMPD_target_data || DKind == OMPD_target_enter_data ||
742 DKind == OMPD_target_exit_data || DKind == OMPD_target_update;
746 return DKind == OMPD_target_data || DKind == OMPD_target_enter_data ||
751 if (DKind == OMPD_teams)
754 return !Leaves.empty() && Leaves.front() == OMPD_teams;
758 return DKind == OMPD_teams ||
759 llvm::is_contained(getLeafConstructs(DKind), OMPD_teams);
764 if (getDirectiveAssociation(DKind) != Association::LoopNest)
769 return DKind == OMPD_simd ||
770 llvm::is_contained(getLeafConstructs(DKind), OMPD_simd);
774 if (Kind == OMPD_distribute)
777 return !Leaves.empty() && Leaves.front() == OMPD_distribute;
781 return Kind == OMPD_distribute ||
782 llvm::is_contained(getLeafConstructs(Kind), OMPD_distribute);
786 if (Kind == OMPD_loop)
789 return !Leaves.empty() && Leaves.back() == OMPD_loop;
793 return Kind == OMPC_private || Kind == OMPC_firstprivate ||
794 Kind == OMPC_lastprivate || Kind == OMPC_linear ||
795 Kind == OMPC_reduction || Kind == OMPC_task_reduction ||
796 Kind == OMPC_in_reduction;
800 return Kind == OMPC_threadprivate || Kind == OMPC_copyin;
808 return Kind == OMPD_distribute_parallel_for ||
809 Kind == OMPD_distribute_parallel_for_simd ||
810 Kind == OMPD_teams_distribute_parallel_for_simd ||
811 Kind == OMPD_teams_distribute_parallel_for ||
812 Kind == OMPD_target_teams_distribute_parallel_for ||
813 Kind == OMPD_target_teams_distribute_parallel_for_simd ||
814 Kind == OMPD_teams_loop || Kind == OMPD_target_teams_loop;
819 return DKind == OMPD_tile || DKind == OMPD_unroll || DKind == OMPD_reverse ||
820 DKind == OMPD_split || DKind == OMPD_interchange ||
821 DKind == OMPD_stripe;
826 return DKind == OMPD_fuse;
835 return DKind == OMPD_parallel_for || DKind == OMPD_parallel_for_simd ||
836 DKind == OMPD_parallel_master ||
837 DKind == OMPD_parallel_master_taskloop ||
838 DKind == OMPD_parallel_master_taskloop_simd ||
839 DKind == OMPD_parallel_sections;
843 return DKind == OMPD_target || DKind == OMPD_target_parallel ||
844 DKind == OMPD_target_parallel_for ||
845 DKind == OMPD_target_parallel_for_simd || DKind == OMPD_target_simd ||
846 DKind == OMPD_target_parallel_loop;
850 if (DKind == OMPD_error)
852 Category Cat = getDirectiveCategory(DKind);
853 return Cat == Category::Executable || Cat == Category::Subsidiary;
857 if (DKind == OMPD_error)
859 Category Cat = getDirectiveCategory(DKind);
860 return Cat == Category::Informational;
869 case OMPD_cancellation_point:
887 case OMPD_metadirective:
902 if (DKind == OMPD_loop || DKind == OMPD_parallel || DKind == OMPD_simd ||
906 if (LangOpts.OpenMP >= 60)
907 return DKind == OMPD_atomic ||
916 assert(
unsigned(DKind) < llvm::omp::Directive_enumSize);
920 assert(isLeafConstruct(LKind) &&
"Epecting leaf directive");
923 case OMPD_metadirective:
924 CaptureRegions.push_back(OMPD_metadirective);
927 CaptureRegions.push_back(OMPD_nothing);
930 CaptureRegions.push_back(OMPD_parallel);
933 CaptureRegions.push_back(OMPD_task);
934 CaptureRegions.push_back(OMPD_target);
937 case OMPD_target_enter_data:
938 case OMPD_target_exit_data:
939 case OMPD_target_update:
940 CaptureRegions.push_back(OMPD_task);
943 CaptureRegions.push_back(OMPD_teams);
946 CaptureRegions.push_back(OMPD_taskloop);
953 if (!CaptureRegions.empty() &&
954 !llvm::is_contained(CaptureRegions, OMPD_parallel))
955 CaptureRegions.push_back(OMPD_parallel);
960 case OMPD_distribute:
967 case OMPD_target_data:
979 llvm::errs() << getOpenMPDirectiveName(LKind, llvm::omp::FallbackVersion)
981 llvm_unreachable(
"Unexpected directive");
986 bool MayNeedUnknownRegion =
false;
988 MayNeedUnknownRegion |= GetRegionsForLeaf(L);
993 if (CaptureRegions.empty() && MayNeedUnknownRegion)
994 CaptureRegions.push_back(OMPD_unknown);
998 assert((CaptureRegions[0] == OMPD_unknown ||
999 !llvm::is_contained(CaptureRegions, OMPD_unknown)) &&
1000 "Misplaced OMPD_unknown");
1004 return FailClauseParameter == llvm::omp::OMPC_acquire ||
1005 FailClauseParameter == llvm::omp::OMPC_relaxed ||
1006 FailClauseParameter == llvm::omp::OMPC_seq_cst;
Defines the clang::IdentifierInfo, clang::IdentifierTable, and clang::Selector interfaces.
Defines some OpenMP-specific enums and functions.
Keeps track of the various options that can be enabled, which controls the dialect of C or C++ that i...
The base class of the type hierarchy.
The JSON file list parser is used to communicate input to InstallAPI.
bool isOpenMPWorksharingDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a worksharing directive.
bool needsTaskBasedThreadLimit(OpenMPDirectiveKind DKind)
Checks if the specified target directive, combined or not, needs task based thread_limit.
bool isOpenMPNestingTeamsDirective(OpenMPDirectiveKind DKind)
Checks if the specified composite/combined directive constitutes a teams directive in the outermost n...
bool checkFailClauseParameter(OpenMPClauseKind FailClauseParameter)
Checks if the parameter to the fail clause in "#pragma atomic compare fail" is restricted only to mem...
bool isOpenMPTargetDataManagementDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a target data offload directive.
OpenMPDefaultClauseVariableCategory
OpenMP variable-category for 'default' clause.
@ OMPC_DEFAULT_VC_unknown
bool isOpenMPLoopTransformationDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a loop transformation directive.
@ OMPC_DEFAULTMAP_MODIFIER_last
@ OMPC_DEFAULTMAP_MODIFIER_unknown
@ OMPC_ORDER_MODIFIER_last
@ OMPC_ADJUST_ARGS_unknown
bool isOpenMPDistributeDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a distribute directive.
@ OMPC_DEVICE_TYPE_unknown
@ OMPC_SCHEDULE_MODIFIER_last
const char * getOpenMPSimpleClauseTypeName(OpenMPClauseKind Kind, unsigned Type)
bool isOpenMPParallelDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a parallel-kind directive.
bool isOpenMPPrivate(OpenMPClauseKind Kind)
Checks if the specified clause is one of private clauses like 'private', 'firstprivate',...
@ OMPC_DIST_SCHEDULE_unknown
bool isOpenMPTaskingDirective(OpenMPDirectiveKind Kind)
Checks if the specified directive kind is one of tasking directives - task, taskloop,...
bool isOpenMPTargetExecutionDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a target code offload directive.
@ OMPC_DYN_GROUPPRIVATE_FALLBACK_last
bool isOpenMPTeamsDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a teams-kind directive.
bool isOpenMPGenericLoopDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive constitutes a 'loop' directive in the outermost nest.
@ OMPC_LASTPRIVATE_unknown
bool isOpenMPCanonicalLoopSequenceTransformationDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a loop transformation directive that applies to a canonical loop...
unsigned getOpenMPSimpleClauseType(OpenMPClauseKind Kind, llvm::StringRef Str, const LangOptions &LangOpts)
bool isOpenMPCanonicalLoopNestTransformationDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a loop transformation directive that applies to a canonical loop...
bool isOpenMPTargetMapEnteringDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a map-entering target directive.
@ OMPC_USE_DEVICE_PTR_FALLBACK_unknown
bool isOpenMPOrderConcurrentNestableDirective(OpenMPDirectiveKind DKind, const LangOptions &LangOpts)
Checks if the specified directive is an order concurrent nestable directive that can be nested within...
bool isOpenMPLoopDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a directive with an associated loop construct.
bool isOpenMPCapturingDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive can capture variables.
bool isOpenMPLoopBoundSharingDirective(OpenMPDirectiveKind Kind)
Checks if the specified directive kind is one of the composite or combined directives that need loop ...
@ OMPC_MOTION_MODIFIER_unknown
@ OMPC_DEFAULTMAP_unknown
bool isOpenMPThreadPrivate(OpenMPClauseKind Kind)
Checks if the specified clause is one of threadprivate clauses like 'threadprivate',...
bool isOpenMPExecutableDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is considered as "executable".
llvm::omp::Directive OpenMPDirectiveKind
OpenMP directives.
@ OMPC_DYN_GROUPPRIVATE_unknown
bool isOpenMPInformationalDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is considered as "informational".
bool isOpenMPSimdDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a simd directive.
void getOpenMPCaptureRegions(llvm::SmallVectorImpl< OpenMPDirectiveKind > &CaptureRegions, OpenMPDirectiveKind DKind)
Return the captured regions of an OpenMP directive.
@ OMPC_NUMTHREADS_unknown
@ OMPC_ATOMIC_DEFAULT_MEM_ORDER_unknown
const char * getOpenMPDefaultVariableCategoryName(unsigned VC)
@ OMPC_MAP_MODIFIER_unknown
bool isOpenMPCombinedParallelADirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a combined construct for which the first construct is a parallel...
llvm::omp::Clause OpenMPClauseKind
OpenMP clauses.
bool isOpenMPNestingDistributeDirective(OpenMPDirectiveKind DKind)
Checks if the specified composite/combined directive constitutes a distribute directive in the outerm...
bool isOpenMPTaskLoopDirective(OpenMPDirectiveKind DKind)
Checks if the specified directive is a taskloop directive.
OpenMPDefaultClauseVariableCategory getOpenMPDefaultVariableCategory(StringRef Str, const LangOptions &LangOpts)