• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1//===--- OMPKinds.def - OpenMP directives, clauses, rt-calls -*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8/// \file
9///
10/// This file defines the list of supported OpenMP runtime
11/// calls, and other things that need to be listed in enums.
12///
13/// This file is under transition to OMP.td with TableGen code generation.
14///
15//===----------------------------------------------------------------------===//
16
17/// OpenMP Directives, combined directives and Clauses
18/// - Moved to OMP.td
19
20/// Types used in runtime structs or runtime functions
21///
22///{
23
24#ifndef OMP_TYPE
25#define OMP_TYPE(VarName, InitValue)
26#endif
27
28#define __OMP_TYPE(VarName) OMP_TYPE(VarName, Type::get##VarName##Ty(Ctx))
29#define __OMP_PTR_TYPE(VarName) OMP_TYPE(VarName, PointerType::get(Ctx, 0))
30
31__OMP_TYPE(Void)
32__OMP_TYPE(Int1)
33__OMP_TYPE(Int8)
34__OMP_TYPE(Int16)
35__OMP_TYPE(Int32)
36__OMP_TYPE(Int64)
37__OMP_PTR_TYPE(Int8Ptr)
38__OMP_PTR_TYPE(Int16Ptr)
39__OMP_PTR_TYPE(Int32Ptr)
40__OMP_PTR_TYPE(Int64Ptr)
41__OMP_TYPE(Double)
42
43OMP_TYPE(SizeTy, M.getDataLayout().getIntPtrType(Ctx))
44OMP_TYPE(Int63, Type::getIntNTy(Ctx, 63))
45
46__OMP_PTR_TYPE(VoidPtr)
47__OMP_PTR_TYPE(VoidPtrPtr)
48__OMP_PTR_TYPE(VoidPtrPtrPtr)
49
50__OMP_PTR_TYPE(Int8PtrPtr)
51__OMP_PTR_TYPE(Int8PtrPtrPtr)
52
53#undef __OMP_PTR_TYPE
54
55#undef __OMP_TYPE
56#undef OMP_TYPE
57
58///}
59
60/// array types
61///
62///{
63
64#ifndef OMP_ARRAY_TYPE
65#define OMP_ARRAY_TYPE(VarName, ElemTy, ArraySize)
66#endif
67
68#define __OMP_ARRAY_TYPE(VarName, ElemTy, ArraySize)                           \
69  OMP_ARRAY_TYPE(VarName, ElemTy, ArraySize)
70
71__OMP_ARRAY_TYPE(KmpCriticalName, Int32, 8)
72__OMP_ARRAY_TYPE(Int32Arr3, Int32, 3)
73
74#undef __OMP_ARRAY_TYPE
75#undef OMP_ARRAY_TYPE
76
77///}
78
79/// Struct and function types
80///
81///{
82
83#ifndef OMP_STRUCT_TYPE
84#define OMP_STRUCT_TYPE(VarName, StructName, Packed, ...)
85#endif
86
87#define __OMP_STRUCT_TYPE(VarName, Name, Packed, ...)                                  \
88  OMP_STRUCT_TYPE(VarName, "struct." #Name, Packed, __VA_ARGS__)
89
90__OMP_STRUCT_TYPE(Ident, ident_t, false, Int32, Int32, Int32, Int32, Int8Ptr)
91__OMP_STRUCT_TYPE(KernelArgs, __tgt_kernel_arguments, false, Int32, Int32, VoidPtrPtr,
92		  VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr,
93		  Int64, Int64, Int32Arr3Ty, Int32Arr3Ty, Int32)
94__OMP_STRUCT_TYPE(AsyncInfo, __tgt_async_info, false, Int8Ptr)
95__OMP_STRUCT_TYPE(DependInfo, kmp_dep_info, false, SizeTy, SizeTy, Int8)
96__OMP_STRUCT_TYPE(Task, kmp_task_ompbuilder_t, false, VoidPtr, VoidPtr, Int32, VoidPtr, VoidPtr)
97__OMP_STRUCT_TYPE(ConfigurationEnvironment, ConfigurationEnvironmentTy, false,
98                  Int8, Int8, Int8, Int32, Int32, Int32, Int32, Int32, Int32)
99__OMP_STRUCT_TYPE(DynamicEnvironment, DynamicEnvironmentTy, false, Int16)
100__OMP_STRUCT_TYPE(KernelEnvironment, KernelEnvironmentTy, false,
101                  ConfigurationEnvironment, IdentPtr, DynamicEnvironmentPtr)
102__OMP_STRUCT_TYPE(KernelLaunchEnvironment, KernelLaunchEnvironmentTy, false,
103                  Int32, Int32)
104
105#undef __OMP_STRUCT_TYPE
106#undef OMP_STRUCT_TYPE
107
108#ifndef OMP_FUNCTION_TYPE
109#define OMP_FUNCTION_TYPE(VarName, IsVarArg, ReturnType, ...)
110#endif
111
112#define __OMP_FUNCTION_TYPE(VarName, IsVarArg, ReturnType, ...)                \
113  OMP_FUNCTION_TYPE(VarName, IsVarArg, ReturnType, __VA_ARGS__)
114
115__OMP_FUNCTION_TYPE(ParallelTask, true, Void, Int32Ptr, Int32Ptr)
116__OMP_FUNCTION_TYPE(ReduceFunction, false, Void, VoidPtr, VoidPtr)
117__OMP_FUNCTION_TYPE(CopyFunction, false, Void, VoidPtr, VoidPtr)
118__OMP_FUNCTION_TYPE(KmpcCtor, false, VoidPtr, VoidPtr)
119__OMP_FUNCTION_TYPE(KmpcDtor, false, Void, VoidPtr)
120__OMP_FUNCTION_TYPE(KmpcCopyCtor, false, VoidPtr, VoidPtr, VoidPtr)
121__OMP_FUNCTION_TYPE(TaskRoutineEntry, false, Int32, Int32,
122                    /* kmp_task_t */ VoidPtr)
123__OMP_FUNCTION_TYPE(ShuffleReduce, false, Void, VoidPtr, Int16, Int16, Int16)
124__OMP_FUNCTION_TYPE(InterWarpCopy, false, Void, VoidPtr, Int32)
125__OMP_FUNCTION_TYPE(GlobalList, false, Void, VoidPtr, Int32, VoidPtr)
126
127#undef __OMP_FUNCTION_TYPE
128#undef OMP_FUNCTION_TYPE
129
130///}
131
132/// Internal Control Variables information
133///
134///{
135
136#ifndef ICV_INIT_VALUE
137#define ICV_INIT_VALUE(Enum, Name)
138#endif
139
140#define __ICV_INIT_VALUE(Name) ICV_INIT_VALUE(ICV_##Name, #Name)
141
142__ICV_INIT_VALUE(ZERO)
143__ICV_INIT_VALUE(FALSE)
144__ICV_INIT_VALUE(IMPLEMENTATION_DEFINED)
145__ICV_INIT_VALUE(LAST)
146
147#undef __ICV_INIT_VALUE
148#undef ICV_INIT_VALUE
149
150#ifndef ICV_DATA_ENV
151#define ICV_DATA_ENV(Enum, Name, EnvVarName, Init)
152#endif
153
154#define __ICV_DATA_ENV(Name, EnvVarName, Init)                                 \
155  ICV_DATA_ENV(ICV_##Name, #Name, #EnvVarName, Init)
156
157__ICV_DATA_ENV(nthreads, OMP_NUM_THREADS, ICV_IMPLEMENTATION_DEFINED)
158__ICV_DATA_ENV(active_levels, NONE, ICV_ZERO)
159__ICV_DATA_ENV(cancel, OMP_CANCELLATION, ICV_FALSE)
160__ICV_DATA_ENV(proc_bind, OMP_PROC_BIND, ICV_IMPLEMENTATION_DEFINED)
161__ICV_DATA_ENV(__last, last, ICV_LAST)
162
163#undef __ICV_DATA_ENV
164#undef ICV_DATA_ENV
165
166#ifndef ICV_RT_SET
167#define ICV_RT_SET(Name, RTL)
168#endif
169
170#define __ICV_RT_SET(Name, RTL) ICV_RT_SET(ICV_##Name, OMPRTL_##RTL)
171
172__ICV_RT_SET(nthreads, omp_set_num_threads)
173
174#undef __ICV_RT_SET
175#undef ICV_RT_SET
176
177#ifndef ICV_RT_GET
178#define ICV_RT_GET(Name, RTL)
179#endif
180
181#define __ICV_RT_GET(Name, RTL) ICV_RT_GET(ICV_##Name, OMPRTL_##RTL)
182
183__ICV_RT_GET(nthreads, omp_get_max_threads)
184__ICV_RT_GET(active_levels, omp_get_active_level)
185__ICV_RT_GET(cancel, omp_get_cancellation)
186__ICV_RT_GET(proc_bind, omp_get_proc_bind)
187
188#undef __ICV_RT_GET
189#undef ICV_RT_GET
190
191///}
192
193/// Runtime library function (and their attributes)
194///
195///{
196
197#ifndef OMP_RTL
198#define OMP_RTL(Enum, Str, IsVarArg, ReturnType, ...)
199#endif
200
201#define __OMP_RTL(Name, IsVarArg, ReturnType, ...)                             \
202  OMP_RTL(OMPRTL_##Name, #Name, IsVarArg, ReturnType, __VA_ARGS__)
203
204
205
206__OMP_RTL(__kmpc_barrier, false, Void, IdentPtr, Int32)
207__OMP_RTL(__kmpc_cancel, false, Int32, IdentPtr, Int32, Int32)
208__OMP_RTL(__kmpc_cancel_barrier, false, Int32, IdentPtr, Int32)
209__OMP_RTL(__kmpc_error, false, Void, IdentPtr, Int32, Int8Ptr)
210__OMP_RTL(__kmpc_flush, false, Void, IdentPtr)
211__OMP_RTL(__kmpc_global_thread_num, false, Int32, IdentPtr)
212__OMP_RTL(__kmpc_get_hardware_thread_id_in_block, false, Int32, )
213__OMP_RTL(__kmpc_fork_call, true, Void, IdentPtr, Int32, ParallelTaskPtr)
214__OMP_RTL(__kmpc_fork_call_if, false, Void, IdentPtr, Int32, ParallelTaskPtr,
215          Int32, VoidPtr)
216__OMP_RTL(__kmpc_omp_taskwait, false, Int32, IdentPtr, Int32)
217__OMP_RTL(__kmpc_omp_taskyield, false, Int32, IdentPtr, Int32, /* Int */ Int32)
218__OMP_RTL(__kmpc_push_num_threads, false, Void, IdentPtr, Int32,
219          /* Int */ Int32)
220__OMP_RTL(__kmpc_push_proc_bind, false, Void, IdentPtr, Int32, /* Int */ Int32)
221__OMP_RTL(__kmpc_omp_reg_task_with_affinity, false, Int32, IdentPtr, Int32,
222          /* kmp_task_t */ VoidPtr, Int32,
223          /* kmp_task_affinity_info_t */ VoidPtr)
224
225__OMP_RTL(__kmpc_get_hardware_num_blocks, false, Int32, )
226__OMP_RTL(__kmpc_get_hardware_num_threads_in_block, false, Int32, )
227__OMP_RTL(__kmpc_get_warp_size, false, Int32, )
228
229__OMP_RTL(omp_get_thread_num, false, Int32, )
230__OMP_RTL(omp_get_num_threads, false, Int32, )
231__OMP_RTL(omp_get_max_threads, false, Int32, )
232__OMP_RTL(omp_in_parallel, false, Int32, )
233__OMP_RTL(omp_get_dynamic, false, Int32, )
234__OMP_RTL(omp_get_cancellation, false, Int32, )
235__OMP_RTL(omp_get_nested, false, Int32, )
236__OMP_RTL(omp_get_schedule, false, Void, Int32Ptr, Int32Ptr)
237__OMP_RTL(omp_get_thread_limit, false, Int32, )
238__OMP_RTL(omp_get_supported_active_levels, false, Int32, )
239__OMP_RTL(omp_get_max_active_levels, false, Int32, )
240__OMP_RTL(omp_get_level, false, Int32, )
241__OMP_RTL(omp_get_ancestor_thread_num, false, Int32, Int32)
242__OMP_RTL(omp_get_team_size, false, Int32, Int32)
243__OMP_RTL(omp_get_active_level, false, Int32, )
244__OMP_RTL(omp_in_final, false, Int32, )
245__OMP_RTL(omp_get_proc_bind, false, Int32, )
246__OMP_RTL(omp_get_num_places, false, Int32, )
247__OMP_RTL(omp_get_num_procs, false, Int32, )
248__OMP_RTL(omp_get_place_proc_ids, false, Void, Int32, Int32Ptr)
249__OMP_RTL(omp_get_place_num, false, Int32, )
250__OMP_RTL(omp_get_partition_num_places, false, Int32, )
251__OMP_RTL(omp_get_partition_place_nums, false, Void, Int32Ptr)
252__OMP_RTL(omp_get_wtime, false, Double,)
253
254__OMP_RTL(omp_set_num_threads, false, Void, Int32)
255__OMP_RTL(omp_set_dynamic, false, Void, Int32)
256__OMP_RTL(omp_set_nested, false, Void, Int32)
257__OMP_RTL(omp_set_schedule, false, Void, Int32, Int32)
258__OMP_RTL(omp_set_max_active_levels, false, Void, Int32)
259
260__OMP_RTL(__kmpc_master, false, Int32, IdentPtr, Int32)
261__OMP_RTL(__kmpc_end_master, false, Void, IdentPtr, Int32)
262__OMP_RTL(__kmpc_masked, false, Int32, IdentPtr, Int32, Int32)
263__OMP_RTL(__kmpc_end_masked, false, Void, IdentPtr, Int32)
264__OMP_RTL(__kmpc_critical, false, Void, IdentPtr, Int32, KmpCriticalNamePtrTy)
265__OMP_RTL(__kmpc_critical_with_hint, false, Void, IdentPtr, Int32,
266          KmpCriticalNamePtrTy, Int32)
267__OMP_RTL(__kmpc_end_critical, false, Void, IdentPtr, Int32,
268          KmpCriticalNamePtrTy)
269
270__OMP_RTL(__kmpc_begin, false, Void, IdentPtr, Int32)
271__OMP_RTL(__kmpc_end, false, Void, IdentPtr)
272
273__OMP_RTL(__kmpc_reduce, false, Int32, IdentPtr, Int32, Int32, SizeTy, VoidPtr,
274          ReduceFunctionPtr, KmpCriticalNamePtrTy)
275__OMP_RTL(__kmpc_reduce_nowait, false, Int32, IdentPtr, Int32, Int32, SizeTy,
276          VoidPtr, ReduceFunctionPtr, KmpCriticalNamePtrTy)
277__OMP_RTL(__kmpc_end_reduce, false, Void, IdentPtr, Int32, KmpCriticalNamePtrTy)
278__OMP_RTL(__kmpc_end_reduce_nowait, false, Void, IdentPtr, Int32,
279          KmpCriticalNamePtrTy)
280
281__OMP_RTL(__kmpc_ordered, false, Void, IdentPtr, Int32)
282__OMP_RTL(__kmpc_end_ordered, false, Void, IdentPtr, Int32)
283
284__OMP_RTL(__kmpc_for_static_init_4, false, Void, IdentPtr, Int32, Int32,
285          Int32Ptr, Int32Ptr, Int32Ptr, Int32Ptr, Int32, Int32)
286__OMP_RTL(__kmpc_for_static_init_4u, false, Void, IdentPtr, Int32, Int32,
287          Int32Ptr, Int32Ptr, Int32Ptr, Int32Ptr, Int32, Int32)
288__OMP_RTL(__kmpc_for_static_init_8, false, Void, IdentPtr, Int32, Int32,
289          Int32Ptr, Int64Ptr, Int64Ptr, Int64Ptr, Int64, Int64)
290__OMP_RTL(__kmpc_for_static_init_8u, false, Void, IdentPtr, Int32, Int32,
291          Int32Ptr, Int64Ptr, Int64Ptr, Int64Ptr, Int64, Int64)
292__OMP_RTL(__kmpc_for_static_fini, false, Void, IdentPtr, Int32)
293__OMP_RTL(__kmpc_distribute_static_init_4, false, Void, IdentPtr, Int32, Int32,
294          Int32Ptr, Int32Ptr, Int32Ptr, Int32Ptr, Int32, Int32)
295__OMP_RTL(__kmpc_distribute_static_init_4u, false, Void, IdentPtr, Int32, Int32,
296          Int32Ptr, Int32Ptr, Int32Ptr, Int32Ptr, Int32, Int32)
297__OMP_RTL(__kmpc_distribute_static_init_8, false, Void, IdentPtr, Int32, Int32,
298          Int32Ptr, Int64Ptr, Int64Ptr, Int64Ptr, Int64, Int64)
299__OMP_RTL(__kmpc_distribute_static_init_8u, false, Void, IdentPtr, Int32, Int32,
300          Int32Ptr, Int64Ptr, Int64Ptr, Int64Ptr, Int64, Int64)
301__OMP_RTL(__kmpc_distribute_static_fini, false, Void, IdentPtr, Int32)
302__OMP_RTL(__kmpc_dist_dispatch_init_4, false, Void, IdentPtr, Int32, Int32,
303          Int32Ptr, Int32, Int32, Int32, Int32)
304__OMP_RTL(__kmpc_dist_dispatch_init_4u, false, Void, IdentPtr, Int32, Int32,
305          Int32Ptr, Int32, Int32, Int32, Int32)
306__OMP_RTL(__kmpc_dist_dispatch_init_8, false, Void, IdentPtr, Int32, Int32,
307          Int32Ptr, Int64, Int64, Int64, Int64)
308__OMP_RTL(__kmpc_dist_dispatch_init_8u, false, Void, IdentPtr, Int32, Int32,
309          Int32Ptr, Int64, Int64, Int64, Int64)
310__OMP_RTL(__kmpc_dispatch_init_4, false, Void, IdentPtr, Int32, Int32, Int32,
311          Int32, Int32, Int32)
312__OMP_RTL(__kmpc_dispatch_init_4u, false, Void, IdentPtr, Int32, Int32, Int32,
313          Int32, Int32, Int32)
314__OMP_RTL(__kmpc_dispatch_init_8, false, Void, IdentPtr, Int32, Int32, Int64,
315          Int64, Int64, Int64)
316__OMP_RTL(__kmpc_dispatch_init_8u, false, Void, IdentPtr, Int32, Int32, Int64,
317          Int64, Int64, Int64)
318__OMP_RTL(__kmpc_dispatch_next_4, false, Int32, IdentPtr, Int32, Int32Ptr,
319          Int32Ptr, Int32Ptr, Int32Ptr)
320__OMP_RTL(__kmpc_dispatch_next_4u, false, Int32, IdentPtr, Int32, Int32Ptr,
321          Int32Ptr, Int32Ptr, Int32Ptr)
322__OMP_RTL(__kmpc_dispatch_next_8, false, Int32, IdentPtr, Int32, Int32Ptr,
323          Int64Ptr, Int64Ptr, Int64Ptr)
324__OMP_RTL(__kmpc_dispatch_next_8u, false, Int32, IdentPtr, Int32, Int32Ptr,
325          Int64Ptr, Int64Ptr, Int64Ptr)
326__OMP_RTL(__kmpc_dispatch_fini_4, false, Void, IdentPtr, Int32)
327__OMP_RTL(__kmpc_dispatch_fini_4u, false, Void, IdentPtr, Int32)
328__OMP_RTL(__kmpc_dispatch_fini_8, false, Void, IdentPtr, Int32)
329__OMP_RTL(__kmpc_dispatch_fini_8u, false, Void, IdentPtr, Int32)
330__OMP_RTL(__kmpc_team_static_init_4, false, Void, IdentPtr, Int32, Int32Ptr,
331          Int32Ptr, Int32Ptr, Int32Ptr, Int32, Int32)
332__OMP_RTL(__kmpc_team_static_init_4u, false, Void, IdentPtr, Int32, Int32Ptr,
333          Int32Ptr, Int32Ptr, Int32Ptr, Int32, Int32)
334__OMP_RTL(__kmpc_team_static_init_8, false, Void, IdentPtr, Int32, Int32Ptr,
335          Int64Ptr, Int64Ptr, Int64Ptr, Int64, Int64)
336__OMP_RTL(__kmpc_team_static_init_8u, false, Void, IdentPtr, Int32, Int32Ptr,
337          Int64Ptr, Int64Ptr, Int64Ptr, Int64, Int64)
338__OMP_RTL(__kmpc_dist_for_static_init_4, false, Void, IdentPtr, Int32, Int32,
339          Int32Ptr, Int32Ptr, Int32Ptr, Int32Ptr, Int32Ptr, Int32, Int32)
340__OMP_RTL(__kmpc_dist_for_static_init_4u, false, Void, IdentPtr, Int32, Int32,
341          Int32Ptr, Int32Ptr, Int32Ptr, Int32Ptr, Int32Ptr, Int32, Int32)
342__OMP_RTL(__kmpc_dist_for_static_init_8, false, Void, IdentPtr, Int32, Int32,
343          Int32Ptr, Int64Ptr, Int64Ptr, Int64Ptr, Int64Ptr, Int64, Int64)
344__OMP_RTL(__kmpc_dist_for_static_init_8u, false, Void, IdentPtr, Int32, Int32,
345          Int32Ptr, Int64Ptr, Int64Ptr, Int64Ptr, Int64Ptr, Int64, Int64)
346
347__OMP_RTL(__kmpc_single, false, Int32, IdentPtr, Int32)
348__OMP_RTL(__kmpc_end_single, false, Void, IdentPtr, Int32)
349
350__OMP_RTL(__kmpc_omp_task_alloc, false, /* kmp_task_t */ VoidPtr, IdentPtr,
351          Int32, Int32, SizeTy, SizeTy, TaskRoutineEntryPtr)
352__OMP_RTL(__kmpc_omp_task, false, Int32, IdentPtr, Int32,
353          /* kmp_task_t */ VoidPtr)
354__OMP_RTL(__kmpc_end_taskgroup, false, Void, IdentPtr, Int32)
355__OMP_RTL(__kmpc_taskgroup, false, Void, IdentPtr, Int32)
356__OMP_RTL(__kmpc_omp_task_begin_if0, false, Void, IdentPtr, Int32,
357          /* kmp_task_t */ VoidPtr)
358__OMP_RTL(__kmpc_omp_task_complete_if0, false, Void, IdentPtr, Int32,
359          /* kmp_tasK_t */ VoidPtr)
360__OMP_RTL(__kmpc_omp_task_with_deps, false, Int32, IdentPtr, Int32,
361          /* kmp_task_t */ VoidPtr, Int32,
362          /* kmp_depend_info_t */ VoidPtr, Int32,
363          /* kmp_depend_info_t */ VoidPtr)
364__OMP_RTL(__kmpc_taskloop, false, Void, IdentPtr, /* Int */ Int32, VoidPtr,
365          /* Int */ Int32, Int64Ptr, Int64Ptr, Int64, /* Int */ Int32,
366          /* Int */ Int32, Int64, VoidPtr)
367__OMP_RTL(__kmpc_omp_target_task_alloc, false, /* kmp_task_t */ VoidPtr,
368          IdentPtr, Int32, Int32, SizeTy, SizeTy, TaskRoutineEntryPtr, Int64)
369__OMP_RTL(__kmpc_taskred_modifier_init, false, /* kmp_taskgroup */ VoidPtr,
370          IdentPtr, /* Int */ Int32, /* Int */ Int32, /* Int */ Int32, VoidPtr)
371__OMP_RTL(__kmpc_taskred_init, false, /* kmp_taskgroup */ VoidPtr,
372          /* Int */ Int32, /* Int */ Int32, VoidPtr)
373__OMP_RTL(__kmpc_task_reduction_modifier_fini, false, Void, IdentPtr,
374          /* Int */ Int32, /* Int */ Int32)
375__OMP_RTL(__kmpc_task_reduction_get_th_data, false, VoidPtr, Int32, VoidPtr,
376          VoidPtr)
377__OMP_RTL(__kmpc_task_reduction_init, false, VoidPtr, Int32, Int32, VoidPtr)
378__OMP_RTL(__kmpc_task_reduction_modifier_init, false, VoidPtr, VoidPtr, Int32,
379          Int32, Int32, VoidPtr)
380__OMP_RTL(__kmpc_proxy_task_completed_ooo, false, Void, VoidPtr)
381
382__OMP_RTL(__kmpc_omp_wait_deps, false, Void, IdentPtr, Int32, Int32,
383          /* kmp_depend_info_t */ VoidPtr, Int32, VoidPtr)
384__OMP_RTL(__kmpc_omp_taskwait_deps_51, false, Void, IdentPtr, Int32, Int32,
385          /* kmp_depend_info_t */ VoidPtr, Int32, VoidPtr, Int32)
386__OMP_RTL(__kmpc_cancellationpoint, false, Int32, IdentPtr, Int32, Int32)
387
388__OMP_RTL(__kmpc_fork_teams, true, Void, IdentPtr, Int32, ParallelTaskPtr)
389__OMP_RTL(__kmpc_push_num_teams, false, Void, IdentPtr, Int32, Int32, Int32)
390__OMP_RTL(__kmpc_push_num_teams_51, false, Void, IdentPtr, Int32, Int32, Int32, Int32)
391__OMP_RTL(__kmpc_set_thread_limit, false, Void, IdentPtr, Int32, Int32)
392
393__OMP_RTL(__kmpc_copyprivate, false, Void, IdentPtr, Int32, SizeTy, VoidPtr,
394          CopyFunctionPtr, Int32)
395__OMP_RTL(__kmpc_threadprivate_cached, false, VoidPtr, IdentPtr, Int32, VoidPtr,
396          SizeTy, VoidPtrPtrPtr)
397__OMP_RTL(__kmpc_threadprivate_register, false, Void, IdentPtr, VoidPtr,
398          KmpcCtorPtr, KmpcCopyCtorPtr, KmpcDtorPtr)
399
400__OMP_RTL(__kmpc_doacross_init, false, Void, IdentPtr, Int32, Int32,
401          /* kmp_dim */ VoidPtr)
402__OMP_RTL(__kmpc_doacross_post, false, Void, IdentPtr, Int32, Int64Ptr)
403__OMP_RTL(__kmpc_doacross_wait, false, Void, IdentPtr, Int32, Int64Ptr)
404__OMP_RTL(__kmpc_doacross_fini, false, Void, IdentPtr, Int32)
405
406__OMP_RTL(__kmpc_alloc, false, VoidPtr, /* Int */ Int32, SizeTy, VoidPtr)
407__OMP_RTL(__kmpc_aligned_alloc, false, VoidPtr, /* Int */ Int32, SizeTy, SizeTy,
408          VoidPtr)
409__OMP_RTL(__kmpc_free, false, Void, /* Int */ Int32, VoidPtr, VoidPtr)
410
411__OMP_RTL(__tgt_interop_init, false, Void, IdentPtr, Int32, VoidPtrPtr, Int32,
412          Int32, Int32, VoidPtr, Int32)
413__OMP_RTL(__tgt_interop_destroy, false, Void, IdentPtr, Int32, VoidPtrPtr,
414          Int32, Int32, VoidPtr, Int32)
415__OMP_RTL(__tgt_interop_use, false, Void, IdentPtr, Int32, VoidPtrPtr, Int32,
416          Int32, VoidPtr, Int32)
417
418__OMP_RTL(__kmpc_init_allocator, false, /* omp_allocator_handle_t */ VoidPtr,
419          /* Int */ Int32, /* omp_memespace_handle_t */ VoidPtr,
420          /* Int */ Int32, /* omp_alloctrait_t */ VoidPtr)
421__OMP_RTL(__kmpc_destroy_allocator, false, Void, /* Int */ Int32,
422          /* omp_allocator_handle_t */ VoidPtr)
423
424__OMP_RTL(__kmpc_push_target_tripcount_mapper, false, Void, IdentPtr, Int64, Int64)
425__OMP_RTL(__tgt_target_mapper, false, Int32, IdentPtr, Int64, VoidPtr, Int32, VoidPtrPtr,
426          VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr)
427__OMP_RTL(__tgt_target_nowait_mapper, false, Int32, IdentPtr, Int64, VoidPtr,
428          Int32, VoidPtrPtr, VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr,
429          VoidPtrPtr, Int32, VoidPtr, Int32, VoidPtr)
430__OMP_RTL(__tgt_target_teams_mapper, false, Int32, IdentPtr, Int64, VoidPtr, Int32,
431          VoidPtrPtr, VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr, Int32, Int32)
432__OMP_RTL(__tgt_target_teams_nowait_mapper, false, Int32, IdentPtr, Int64,
433          VoidPtr, Int32, VoidPtrPtr, VoidPtrPtr, Int64Ptr, Int64Ptr,
434          VoidPtrPtr, VoidPtrPtr, Int32, Int32, Int32, VoidPtr, Int32, VoidPtr)
435__OMP_RTL(__tgt_target_kernel, false, Int32, IdentPtr, Int64, Int32, Int32,
436          VoidPtr, KernelArgsPtr)
437__OMP_RTL(__tgt_target_kernel_nowait, false, Int32, IdentPtr, Int64, Int32,
438          Int32, VoidPtr, KernelArgsPtr, Int32, VoidPtr, Int32, VoidPtr)
439__OMP_RTL(__tgt_target_data_begin_mapper, false, Void, IdentPtr, Int64, Int32, VoidPtrPtr,
440          VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr)
441__OMP_RTL(__tgt_target_data_begin_nowait_mapper, false, Void, IdentPtr, Int64, Int32,
442          VoidPtrPtr, VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr)
443__OMP_RTL(__tgt_target_data_begin_mapper_issue, false, Void, IdentPtr, Int64, Int32,
444          VoidPtrPtr, VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr, AsyncInfoPtr)
445__OMP_RTL(__tgt_target_data_begin_mapper_wait, false, Void, Int64, AsyncInfoPtr)
446__OMP_RTL(__tgt_target_data_end_mapper, false, Void, IdentPtr, Int64, Int32, VoidPtrPtr,
447          VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr)
448__OMP_RTL(__tgt_target_data_end_nowait_mapper, false, Void, IdentPtr, Int64, Int32,
449          VoidPtrPtr, VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr)
450__OMP_RTL(__tgt_target_data_update_mapper, false, Void, IdentPtr, Int64, Int32,
451          VoidPtrPtr, VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr)
452__OMP_RTL(__tgt_target_data_update_nowait_mapper, false, Void, IdentPtr, Int64, Int32,
453          VoidPtrPtr, VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr)
454__OMP_RTL(__tgt_mapper_num_components, false, Int64, VoidPtr)
455__OMP_RTL(__tgt_push_mapper_component, false, Void, VoidPtr, VoidPtr, VoidPtr,
456          Int64, Int64, VoidPtr)
457__OMP_RTL(__kmpc_task_allow_completion_event, false, VoidPtr, IdentPtr,
458          /* Int */ Int32, /* kmp_task_t */ VoidPtr)
459
460/// OpenMP Device runtime functions
461__OMP_RTL(__kmpc_target_init, false, Int32, KernelEnvironmentPtr, KernelLaunchEnvironmentPtr)
462__OMP_RTL(__kmpc_target_deinit, false, Void,)
463__OMP_RTL(__kmpc_kernel_prepare_parallel, false, Void, VoidPtr)
464__OMP_RTL(__kmpc_parallel_51, false, Void, IdentPtr, Int32, Int32, Int32, Int32,
465          VoidPtr, VoidPtr, VoidPtrPtr, SizeTy)
466__OMP_RTL(__kmpc_for_static_loop_4, false, Void, IdentPtr, VoidPtr, VoidPtr, Int32, Int32, Int32)
467__OMP_RTL(__kmpc_for_static_loop_4u, false, Void, IdentPtr, VoidPtr, VoidPtr, Int32, Int32, Int32)
468__OMP_RTL(__kmpc_for_static_loop_8, false, Void, IdentPtr, VoidPtr, VoidPtr, Int64, Int64, Int64)
469__OMP_RTL(__kmpc_for_static_loop_8u, false, Void, IdentPtr, VoidPtr, VoidPtr, Int64, Int64, Int64)
470__OMP_RTL(__kmpc_distribute_static_loop_4, false, Void, IdentPtr, VoidPtr, VoidPtr, Int32, Int32)
471__OMP_RTL(__kmpc_distribute_static_loop_4u, false, Void, IdentPtr, VoidPtr, VoidPtr, Int32, Int32)
472__OMP_RTL(__kmpc_distribute_static_loop_8, false, Void, IdentPtr, VoidPtr, VoidPtr, Int64, Int64)
473__OMP_RTL(__kmpc_distribute_static_loop_8u, false, Void, IdentPtr, VoidPtr, VoidPtr, Int64, Int64)
474__OMP_RTL(__kmpc_distribute_for_static_loop_4, false, Void, IdentPtr, VoidPtr, VoidPtr, Int32, Int32, Int32, Int32)
475__OMP_RTL(__kmpc_distribute_for_static_loop_4u, false, Void, IdentPtr, VoidPtr, VoidPtr, Int32, Int32, Int32, Int32)
476__OMP_RTL(__kmpc_distribute_for_static_loop_8, false, Void, IdentPtr, VoidPtr, VoidPtr, Int64, Int64, Int64, Int64)
477__OMP_RTL(__kmpc_distribute_for_static_loop_8u, false, Void, IdentPtr, VoidPtr, VoidPtr, Int64, Int64, Int64, Int64)
478__OMP_RTL(__kmpc_kernel_parallel, false, Int1, VoidPtrPtr)
479__OMP_RTL(__kmpc_kernel_end_parallel, false, Void, )
480__OMP_RTL(__kmpc_serialized_parallel, false, Void, IdentPtr, Int32)
481__OMP_RTL(__kmpc_end_serialized_parallel, false, Void, IdentPtr, Int32)
482__OMP_RTL(__kmpc_shuffle_int32, false, Int32, Int32, Int16, Int16)
483__OMP_RTL(__kmpc_nvptx_parallel_reduce_nowait_v2, false, Int32, IdentPtr,
484	  Int64, VoidPtr, ShuffleReducePtr, InterWarpCopyPtr)
485__OMP_RTL(__kmpc_nvptx_teams_reduce_nowait_v2, false, Int32, IdentPtr,
486          VoidPtr, Int32, Int64, VoidPtr, ShuffleReducePtr, InterWarpCopyPtr,
487          GlobalListPtr, GlobalListPtr, GlobalListPtr, GlobalListPtr)
488__OMP_RTL(__kmpc_reduction_get_fixed_buffer, false, VoidPtr, )
489
490__OMP_RTL(__kmpc_shuffle_int64, false, Int64, Int64, Int16, Int16)
491
492__OMP_RTL(__kmpc_alloc_shared, false, VoidPtr, SizeTy)
493__OMP_RTL(__kmpc_free_shared, false, Void, VoidPtr, SizeTy)
494__OMP_RTL(__kmpc_begin_sharing_variables, false, Void, VoidPtrPtrPtr, SizeTy)
495__OMP_RTL(__kmpc_end_sharing_variables, false, Void, )
496__OMP_RTL(__kmpc_get_shared_variables, false, Void, VoidPtrPtrPtr)
497__OMP_RTL(__kmpc_parallel_level, false, Int16, IdentPtr, Int32)
498__OMP_RTL(__kmpc_is_spmd_exec_mode, false, Int8, )
499__OMP_RTL(__kmpc_barrier_simple_spmd, false, Void, IdentPtr, Int32)
500__OMP_RTL(__kmpc_barrier_simple_generic, false, Void, IdentPtr, Int32)
501
502__OMP_RTL(__kmpc_warp_active_thread_mask, false, Int64,)
503__OMP_RTL(__kmpc_syncwarp, false, Void, Int64)
504
505__OMP_RTL(__last, false, Void, )
506
507#undef __OMP_RTL
508#undef OMP_RTL
509
510#define ParamAttrs(...) ArrayRef<AttributeSet>({__VA_ARGS__})
511#define EnumAttr(Kind) Attribute::get(Ctx, Attribute::AttrKind::Kind)
512#define EnumAttrInt(Kind, N) Attribute::get(Ctx, Attribute::AttrKind::Kind, N)
513#define AllocSizeAttr(N, M) Attribute::getWithAllocSizeArgs(Ctx, N, M)
514#define MemoryAttr(ME) Attribute::getWithMemoryEffects(Ctx, ME)
515#define AttributeSet(...)                                                      \
516  AttributeSet::get(Ctx, ArrayRef<Attribute>({__VA_ARGS__}))
517
518#ifndef OMP_ATTRS_SET
519#define OMP_ATTRS_SET(VarName, AttrSet)
520#endif
521
522#define __OMP_ATTRS_SET(VarName, AttrSet) OMP_ATTRS_SET(VarName, AttrSet)
523
524__OMP_ATTRS_SET(
525    GetterAttrs,
526    OptimisticAttributes
527        ? AttributeSet(
528              EnumAttr(NoUnwind), EnumAttr(NoSync), EnumAttr(NoFree),
529              EnumAttr(WillReturn),
530              MemoryAttr(MemoryEffects::inaccessibleMemOnly(ModRefInfo::Ref)))
531        : AttributeSet(EnumAttr(NoUnwind)))
532__OMP_ATTRS_SET(
533    GetterArgReadAttrs,
534    OptimisticAttributes
535        ? AttributeSet(
536              EnumAttr(NoUnwind), EnumAttr(NoSync), EnumAttr(NoFree),
537              EnumAttr(WillReturn),
538              MemoryAttr(MemoryEffects::inaccessibleOrArgMemOnly(ModRefInfo::Ref)))
539        : AttributeSet(EnumAttr(NoUnwind)))
540__OMP_ATTRS_SET(
541    GetterArgWriteAttrs,
542    OptimisticAttributes
543        ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync), EnumAttr(NoFree),
544                       EnumAttr(WillReturn),
545                       MemoryAttr(MemoryEffects::argMemOnly() | MemoryEffects::inaccessibleMemOnly(ModRefInfo::Ref)))
546        : AttributeSet(EnumAttr(NoUnwind)))
547__OMP_ATTRS_SET(
548  SetterAttrs,
549  OptimisticAttributes
550      ? AttributeSet(
551            EnumAttr(NoUnwind), EnumAttr(NoSync), EnumAttr(NoFree),
552            EnumAttr(WillReturn),
553            MemoryAttr(MemoryEffects::inaccessibleMemOnly(ModRefInfo::Mod)))
554      : AttributeSet(EnumAttr(NoUnwind)))
555
556__OMP_ATTRS_SET(DefaultAttrs,
557                OptimisticAttributes
558                    ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync),
559                                   EnumAttr(WillReturn), EnumAttr(NoFree))
560                    : AttributeSet(EnumAttr(NoUnwind)))
561
562__OMP_ATTRS_SET(BarrierAttrs,
563                OptimisticAttributes
564                    ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(Convergent))
565                    : AttributeSet(EnumAttr(NoUnwind), EnumAttr(Convergent)))
566
567__OMP_ATTRS_SET(
568    InaccessibleArgOnlyAttrs,
569    OptimisticAttributes
570         ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync), EnumAttr(NoFree),
571                        EnumAttr(WillReturn),
572                        MemoryAttr(MemoryEffects::inaccessibleOrArgMemOnly()))
573         : AttributeSet(EnumAttr(NoUnwind)))
574
575__OMP_ATTRS_SET(AlwaysInlineAttrs,
576                OptimisticAttributes
577                    ? AttributeSet(EnumAttr(AlwaysInline))
578                    : AttributeSet(EnumAttr(AlwaysInline)))
579
580#if 0
581__OMP_ATTRS_SET(
582    InaccessibleOnlyAttrs,
583    OptimisticAttributes
584        ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync), EnumAttr(NoFree),
585                       EnumAttr(WillReturn),
586                       MemoryAttr(MemoryEffects::inaccessibleMemOnly()))
587        : AttributeSet(EnumAttr(NoUnwind)))
588#endif
589
590__OMP_ATTRS_SET(AllocAttrs,
591                OptimisticAttributes
592                    ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync),
593                                   EnumAttr(WillReturn))
594                    : AttributeSet(EnumAttr(NoUnwind)))
595
596__OMP_ATTRS_SET(ForkAttrs, OptimisticAttributes
597                               ? AttributeSet(EnumAttr(NoUnwind))
598                               : AttributeSet(EnumAttr(NoUnwind)))
599
600__OMP_ATTRS_SET(ReadOnlyPtrAttrs,
601                OptimisticAttributes
602                    ? AttributeSet(EnumAttr(ReadOnly), EnumAttr(NoFree),
603                                   EnumAttr(NoCapture))
604                    : AttributeSet())
605
606__OMP_ATTRS_SET(DeviceAllocAttrs,
607                OptimisticAttributes
608                    ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync))
609                    : AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync)))
610
611#if 0
612__OMP_ATTRS_SET(WriteOnlyPtrAttrs,
613                OptimisticAttributes
614                    ? AttributeSet(EnumAttr(WriteOnly), EnumAttr(NoFree),
615                                   EnumAttr(NoCapture))
616                    : AttributeSet())
617#endif
618
619__OMP_ATTRS_SET(ArgPtrAttrs,
620                OptimisticAttributes
621                    ? AttributeSet(EnumAttr(NoCapture), EnumAttr(NoFree))
622                    : AttributeSet())
623
624__OMP_ATTRS_SET(ReturnPtrAttrs, AttributeSet(EnumAttr(NoAlias)))
625
626__OMP_ATTRS_SET(ZExt, AttributeSet(EnumAttr(ZExt)))
627__OMP_ATTRS_SET(SExt, AttributeSet(EnumAttr(SExt)))
628__OMP_ATTRS_SET(SizeTyExt,
629                M.getDataLayout().getIntPtrType(Ctx)->getBitWidth() < 64
630                    ? AttributeSet(EnumAttr(ZExt))
631                    : AttributeSet())
632
633#if 0
634__OMP_ATTRS_SET(ReturnAlignedPtrAttrs,
635                OptimisticAttributes
636                    ? AttributeSet(EnumAttr(NoAlias), EnumAttrInt(Alignment, 8),
637                                   EnumAttrInt(DereferenceableOrNull, 8))
638                    : AttributeSet())
639#endif
640
641#undef __OMP_ATTRS_SET
642#undef OMP_ATTRS_SET
643
644#ifndef OMP_RTL_ATTRS
645#define OMP_RTL_ATTRS(Enum, FnAttrSet, RetAttrSet, ArgAttrSets)
646#endif
647
648#define __OMP_RTL_ATTRS(Name, FnAttrSet, RetAttrSet, ArgAttrSets)              \
649  OMP_RTL_ATTRS(OMPRTL_##Name, FnAttrSet, RetAttrSet, ArgAttrSets)
650
651__OMP_RTL_ATTRS(__kmpc_barrier, BarrierAttrs, AttributeSet(),
652                ParamAttrs(ReadOnlyPtrAttrs, SExt))
653__OMP_RTL_ATTRS(__kmpc_barrier_simple_spmd, BarrierAttrs, AttributeSet(),
654                ParamAttrs(ReadOnlyPtrAttrs, SExt))
655__OMP_RTL_ATTRS(__kmpc_barrier_simple_generic, BarrierAttrs, AttributeSet(),
656                ParamAttrs(ReadOnlyPtrAttrs, SExt))
657__OMP_RTL_ATTRS(__kmpc_warp_active_thread_mask, BarrierAttrs, AttributeSet(),
658                ParamAttrs())
659__OMP_RTL_ATTRS(__kmpc_syncwarp, BarrierAttrs, AttributeSet(), ParamAttrs())
660__OMP_RTL_ATTRS(__kmpc_cancel, InaccessibleArgOnlyAttrs, SExt,
661                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
662__OMP_RTL_ATTRS(__kmpc_cancel_barrier, BarrierAttrs, SExt,
663                ParamAttrs(ReadOnlyPtrAttrs, SExt))
664__OMP_RTL_ATTRS(__kmpc_distribute_for_static_loop_4, AlwaysInlineAttrs, AttributeSet(),
665                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), AttributeSet(),
666                           SExt, SExt, SExt, SExt))
667__OMP_RTL_ATTRS(__kmpc_distribute_for_static_loop_4u, AlwaysInlineAttrs, AttributeSet(),
668                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), AttributeSet(),
669                           ZExt, ZExt, ZExt, ZExt))
670__OMP_RTL_ATTRS(__kmpc_distribute_static_loop_4, AlwaysInlineAttrs, AttributeSet(),
671                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), AttributeSet(),
672                           SExt, SExt))
673__OMP_RTL_ATTRS(__kmpc_distribute_static_loop_4u, AlwaysInlineAttrs, AttributeSet(),
674                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), AttributeSet(),
675                           ZExt, ZExt))
676__OMP_RTL_ATTRS(__kmpc_for_static_loop_4, AlwaysInlineAttrs, AttributeSet(),
677                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), AttributeSet(),
678                           SExt, SExt, SExt))
679__OMP_RTL_ATTRS(__kmpc_for_static_loop_4u, AlwaysInlineAttrs, AttributeSet(),
680                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), AttributeSet(),
681                           ZExt, ZExt, ZExt))
682__OMP_RTL_ATTRS(__kmpc_error, AttributeSet(), AttributeSet(),
683                ParamAttrs(AttributeSet(), SExt))
684__OMP_RTL_ATTRS(__kmpc_flush, BarrierAttrs, AttributeSet(),
685                ParamAttrs(ReadOnlyPtrAttrs))
686__OMP_RTL_ATTRS(__kmpc_global_thread_num, GetterArgReadAttrs, SExt,
687                ParamAttrs(ReadOnlyPtrAttrs))
688__OMP_RTL_ATTRS(__kmpc_get_hardware_thread_id_in_block, GetterAttrs, ZExt,
689                ParamAttrs())
690__OMP_RTL_ATTRS(__kmpc_fork_call, ForkAttrs, AttributeSet(),
691                ParamAttrs(ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs))
692__OMP_RTL_ATTRS(__kmpc_fork_call_if, AttributeSet(), AttributeSet(),
693                ParamAttrs(ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs, SExt))
694__OMP_RTL_ATTRS(__kmpc_omp_taskwait, BarrierAttrs, SExt,
695                ParamAttrs(ReadOnlyPtrAttrs, SExt))
696__OMP_RTL_ATTRS(__kmpc_omp_taskyield, InaccessibleArgOnlyAttrs, SExt,
697                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
698__OMP_RTL_ATTRS(__kmpc_push_num_threads, InaccessibleArgOnlyAttrs,
699                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
700__OMP_RTL_ATTRS(__kmpc_push_proc_bind, InaccessibleArgOnlyAttrs, AttributeSet(),
701                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
702__OMP_RTL_ATTRS(__kmpc_omp_reg_task_with_affinity, DefaultAttrs, SExt,
703                ParamAttrs(ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs,
704                           SExt, ReadOnlyPtrAttrs))
705
706__OMP_RTL_ATTRS(__kmpc_get_hardware_num_blocks, GetterAttrs, ZExt, ParamAttrs())
707__OMP_RTL_ATTRS(__kmpc_get_hardware_num_threads_in_block, GetterAttrs, ZExt, ParamAttrs())
708__OMP_RTL_ATTRS(__kmpc_get_warp_size, GetterAttrs, ZExt, ParamAttrs())
709
710__OMP_RTL_ATTRS(omp_get_thread_num, GetterAttrs, SExt, ParamAttrs())
711__OMP_RTL_ATTRS(omp_get_num_threads, GetterAttrs, SExt, ParamAttrs())
712__OMP_RTL_ATTRS(omp_get_max_threads, GetterAttrs, SExt, ParamAttrs())
713__OMP_RTL_ATTRS(omp_in_parallel, GetterAttrs, SExt, ParamAttrs())
714__OMP_RTL_ATTRS(omp_get_dynamic, GetterAttrs, SExt, ParamAttrs())
715__OMP_RTL_ATTRS(omp_get_cancellation, GetterAttrs, SExt, ParamAttrs())
716__OMP_RTL_ATTRS(omp_get_nested, GetterAttrs, SExt, ParamAttrs())
717__OMP_RTL_ATTRS(
718    omp_get_schedule, GetterArgWriteAttrs, AttributeSet(),
719    ParamAttrs(AttributeSet(EnumAttr(NoCapture), EnumAttr(WriteOnly)),
720               AttributeSet(EnumAttr(NoCapture), EnumAttr(WriteOnly))))
721__OMP_RTL_ATTRS(omp_get_thread_limit, GetterAttrs, SExt, ParamAttrs())
722__OMP_RTL_ATTRS(omp_get_supported_active_levels, GetterAttrs, SExt, ParamAttrs())
723__OMP_RTL_ATTRS(omp_get_max_active_levels, GetterAttrs, SExt, ParamAttrs())
724__OMP_RTL_ATTRS(omp_get_level, GetterAttrs, SExt, ParamAttrs())
725__OMP_RTL_ATTRS(omp_get_ancestor_thread_num, GetterAttrs, SExt, ParamAttrs(SExt))
726__OMP_RTL_ATTRS(omp_get_team_size, GetterAttrs, SExt, ParamAttrs(SExt))
727__OMP_RTL_ATTRS(omp_get_active_level, GetterAttrs, SExt, ParamAttrs())
728__OMP_RTL_ATTRS(omp_in_final, GetterAttrs, SExt, ParamAttrs())
729__OMP_RTL_ATTRS(omp_get_proc_bind, GetterAttrs, SExt, ParamAttrs())
730__OMP_RTL_ATTRS(omp_get_num_places, GetterAttrs, SExt, ParamAttrs())
731__OMP_RTL_ATTRS(omp_get_num_procs, GetterAttrs, SExt, ParamAttrs())
732__OMP_RTL_ATTRS(omp_get_place_proc_ids, GetterArgWriteAttrs, AttributeSet(),
733                ParamAttrs(SExt, AttributeSet(EnumAttr(NoCapture),
734                                              EnumAttr(WriteOnly))))
735__OMP_RTL_ATTRS(omp_get_place_num, GetterAttrs, SExt, ParamAttrs())
736__OMP_RTL_ATTRS(omp_get_partition_num_places, GetterAttrs, SExt, ParamAttrs())
737__OMP_RTL_ATTRS(omp_get_partition_place_nums, GetterArgWriteAttrs, AttributeSet(),
738                ParamAttrs())
739__OMP_RTL_ATTRS(omp_get_wtime, GetterAttrs, AttributeSet(), ParamAttrs())
740
741__OMP_RTL_ATTRS(omp_set_num_threads, SetterAttrs, AttributeSet(),
742                ParamAttrs(SExt))
743__OMP_RTL_ATTRS(omp_set_dynamic, SetterAttrs, AttributeSet(), ParamAttrs(SExt))
744__OMP_RTL_ATTRS(omp_set_nested, SetterAttrs, AttributeSet(), ParamAttrs(SExt))
745__OMP_RTL_ATTRS(omp_set_schedule, SetterAttrs, AttributeSet(),
746                ParamAttrs(SExt, SExt))
747__OMP_RTL_ATTRS(omp_set_max_active_levels, SetterAttrs, AttributeSet(),
748                ParamAttrs(SExt))
749
750__OMP_RTL_ATTRS(__kmpc_master, InaccessibleArgOnlyAttrs, SExt,
751                ParamAttrs(ReadOnlyPtrAttrs, SExt))
752__OMP_RTL_ATTRS(__kmpc_end_master, InaccessibleArgOnlyAttrs, AttributeSet(),
753                ParamAttrs(ReadOnlyPtrAttrs, SExt))
754__OMP_RTL_ATTRS(__kmpc_masked, InaccessibleArgOnlyAttrs, SExt,
755                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
756__OMP_RTL_ATTRS(__kmpc_end_masked, InaccessibleArgOnlyAttrs, AttributeSet(),
757                ParamAttrs(ReadOnlyPtrAttrs, SExt))
758__OMP_RTL_ATTRS(__kmpc_critical, BarrierAttrs, AttributeSet(),
759                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet()))
760__OMP_RTL_ATTRS(__kmpc_critical_with_hint, BarrierAttrs, AttributeSet(),
761                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet(), ZExt))
762__OMP_RTL_ATTRS(__kmpc_end_critical, BarrierAttrs, AttributeSet(),
763                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet()))
764
765__OMP_RTL_ATTRS(__kmpc_begin, DefaultAttrs, AttributeSet(),
766                ParamAttrs(ReadOnlyPtrAttrs, SExt))
767__OMP_RTL_ATTRS(__kmpc_end, DefaultAttrs, AttributeSet(),
768                ParamAttrs(ReadOnlyPtrAttrs))
769
770__OMP_RTL_ATTRS(__kmpc_reduce, BarrierAttrs, SExt,
771                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SizeTyExt,
772                           ReadOnlyPtrAttrs, AttributeSet()))
773__OMP_RTL_ATTRS(__kmpc_reduce_nowait, BarrierAttrs, SExt,
774                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SizeTyExt,
775                           ReadOnlyPtrAttrs, AttributeSet()))
776__OMP_RTL_ATTRS(__kmpc_end_reduce, BarrierAttrs, AttributeSet(),
777                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet()))
778__OMP_RTL_ATTRS(__kmpc_end_reduce_nowait, BarrierAttrs, AttributeSet(),
779                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet()))
780
781__OMP_RTL_ATTRS(__kmpc_ordered, BarrierAttrs, AttributeSet(),
782                ParamAttrs(ReadOnlyPtrAttrs, SExt))
783__OMP_RTL_ATTRS(__kmpc_end_ordered, BarrierAttrs, AttributeSet(),
784                ParamAttrs(ReadOnlyPtrAttrs, SExt))
785
786__OMP_RTL_ATTRS(__kmpc_for_static_init_4, GetterArgWriteAttrs, AttributeSet(),
787                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
788                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs, SExt, SExt))
789__OMP_RTL_ATTRS(__kmpc_for_static_init_4u, GetterArgWriteAttrs, AttributeSet(),
790                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
791                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs, SExt, SExt))
792__OMP_RTL_ATTRS(__kmpc_for_static_init_8, GetterArgWriteAttrs, AttributeSet(),
793                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
794                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs,
795                           AttributeSet(), AttributeSet()))
796__OMP_RTL_ATTRS(__kmpc_for_static_init_8u, GetterArgWriteAttrs, AttributeSet(),
797                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
798                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs,
799                           AttributeSet(), AttributeSet()))
800__OMP_RTL_ATTRS(__kmpc_for_static_fini, InaccessibleArgOnlyAttrs,
801                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
802__OMP_RTL_ATTRS(__kmpc_distribute_static_init_4, GetterArgWriteAttrs,
803                AttributeSet(),
804                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
805                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs, SExt, SExt))
806__OMP_RTL_ATTRS(__kmpc_distribute_static_init_4u, GetterArgWriteAttrs,
807                AttributeSet(),
808                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
809                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs, SExt, SExt))
810__OMP_RTL_ATTRS(__kmpc_distribute_static_init_8, GetterArgWriteAttrs,
811                AttributeSet(),
812                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
813                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs,
814                           AttributeSet(), AttributeSet()))
815__OMP_RTL_ATTRS(__kmpc_distribute_static_init_8u, GetterArgWriteAttrs,
816                AttributeSet(),
817                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
818                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs,
819                           AttributeSet(), AttributeSet()))
820__OMP_RTL_ATTRS(__kmpc_distribute_static_fini, InaccessibleArgOnlyAttrs,
821                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
822__OMP_RTL_ATTRS(__kmpc_dist_dispatch_init_4, GetterArgWriteAttrs,
823                AttributeSet(),
824                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs, SExt,
825                           SExt, SExt, SExt))
826__OMP_RTL_ATTRS(__kmpc_dist_dispatch_init_4u, GetterArgWriteAttrs,
827                AttributeSet(),
828                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs, ZExt,
829                           ZExt, SExt, SExt))
830__OMP_RTL_ATTRS(__kmpc_dist_dispatch_init_8, GetterArgWriteAttrs,
831                AttributeSet(),
832                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs))
833__OMP_RTL_ATTRS(__kmpc_dist_dispatch_init_8u, GetterArgWriteAttrs,
834                AttributeSet(),
835                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs))
836__OMP_RTL_ATTRS(__kmpc_dispatch_init_4, GetterArgWriteAttrs, AttributeSet(),
837                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SExt, SExt, SExt, SExt))
838__OMP_RTL_ATTRS(__kmpc_dispatch_init_4u, GetterArgWriteAttrs, AttributeSet(),
839                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ZExt, ZExt, SExt, SExt))
840__OMP_RTL_ATTRS(__kmpc_dispatch_init_8, GetterArgWriteAttrs, AttributeSet(),
841                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
842__OMP_RTL_ATTRS(__kmpc_dispatch_init_8u, GetterArgWriteAttrs, AttributeSet(),
843                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
844__OMP_RTL_ATTRS(__kmpc_dispatch_next_4, GetterArgWriteAttrs, SExt,
845                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
846                           ArgPtrAttrs, ArgPtrAttrs))
847__OMP_RTL_ATTRS(__kmpc_dispatch_next_4u, GetterArgWriteAttrs, SExt,
848                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
849                           ArgPtrAttrs, ArgPtrAttrs))
850__OMP_RTL_ATTRS(__kmpc_dispatch_next_8, GetterArgWriteAttrs, SExt,
851                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
852                           ArgPtrAttrs, ArgPtrAttrs))
853__OMP_RTL_ATTRS(__kmpc_dispatch_next_8u, GetterArgWriteAttrs, SExt,
854                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
855                           ArgPtrAttrs, ArgPtrAttrs))
856__OMP_RTL_ATTRS(__kmpc_dispatch_fini_4, InaccessibleArgOnlyAttrs,
857                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
858__OMP_RTL_ATTRS(__kmpc_dispatch_fini_4u, InaccessibleArgOnlyAttrs,
859                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
860__OMP_RTL_ATTRS(__kmpc_dispatch_fini_8, InaccessibleArgOnlyAttrs,
861                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
862__OMP_RTL_ATTRS(__kmpc_dispatch_fini_8u, InaccessibleArgOnlyAttrs,
863                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
864__OMP_RTL_ATTRS(__kmpc_team_static_init_4, GetterArgWriteAttrs, AttributeSet(),
865                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
866                           ArgPtrAttrs, ArgPtrAttrs, SExt, SExt))
867__OMP_RTL_ATTRS(__kmpc_team_static_init_4u, GetterArgWriteAttrs, AttributeSet(),
868                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
869                           ArgPtrAttrs, ArgPtrAttrs, SExt, SExt))
870__OMP_RTL_ATTRS(__kmpc_team_static_init_8, GetterArgWriteAttrs, AttributeSet(),
871                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
872                           ArgPtrAttrs, ArgPtrAttrs))
873__OMP_RTL_ATTRS(__kmpc_team_static_init_8u, GetterArgWriteAttrs, AttributeSet(),
874                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
875                           ArgPtrAttrs, ArgPtrAttrs))
876__OMP_RTL_ATTRS(__kmpc_dist_for_static_init_4, GetterArgWriteAttrs,
877                AttributeSet(),
878                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
879                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs,
880                           ArgPtrAttrs, SExt, SExt))
881__OMP_RTL_ATTRS(__kmpc_dist_for_static_init_4u, GetterArgWriteAttrs,
882                AttributeSet(),
883                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
884                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs,
885                           ArgPtrAttrs, SExt, SExt))
886__OMP_RTL_ATTRS(__kmpc_dist_for_static_init_8, GetterArgWriteAttrs,
887                AttributeSet(),
888                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
889                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs))
890__OMP_RTL_ATTRS(__kmpc_dist_for_static_init_8u, GetterArgWriteAttrs,
891                AttributeSet(),
892                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
893                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs))
894
895__OMP_RTL_ATTRS(__kmpc_single, BarrierAttrs, SExt,
896                ParamAttrs(ReadOnlyPtrAttrs, SExt))
897__OMP_RTL_ATTRS(__kmpc_end_single, BarrierAttrs, AttributeSet(),
898                ParamAttrs(ReadOnlyPtrAttrs, SExt))
899
900__OMP_RTL_ATTRS(__kmpc_omp_task_alloc, DefaultAttrs, ReturnPtrAttrs,
901                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SizeTyExt, SizeTyExt,
902                           ReadOnlyPtrAttrs))
903__OMP_RTL_ATTRS(__kmpc_omp_task, DefaultAttrs, SExt,
904                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet()))
905__OMP_RTL_ATTRS(__kmpc_end_taskgroup, BarrierAttrs, AttributeSet(),
906                ParamAttrs(ReadOnlyPtrAttrs, SExt))
907__OMP_RTL_ATTRS(__kmpc_taskgroup, BarrierAttrs, AttributeSet(),
908                ParamAttrs(ReadOnlyPtrAttrs, SExt))
909__OMP_RTL_ATTRS(__kmpc_omp_task_begin_if0, DefaultAttrs, AttributeSet(),
910                ParamAttrs(ReadOnlyPtrAttrs, SExt))
911__OMP_RTL_ATTRS(__kmpc_omp_task_complete_if0, DefaultAttrs, AttributeSet(),
912                ParamAttrs(ReadOnlyPtrAttrs, SExt))
913__OMP_RTL_ATTRS(__kmpc_omp_task_with_deps, DefaultAttrs, SExt,
914                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet(), SExt,
915                           ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs))
916__OMP_RTL_ATTRS(__kmpc_taskloop, DefaultAttrs, AttributeSet(),
917                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet(), SExt,
918                           ArgPtrAttrs, ArgPtrAttrs, AttributeSet(), SExt, SExt))
919__OMP_RTL_ATTRS(__kmpc_omp_target_task_alloc, DefaultAttrs, ReturnPtrAttrs,
920                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SizeTyExt, SizeTyExt,
921                           ReadOnlyPtrAttrs, AttributeSet()))
922__OMP_RTL_ATTRS(__kmpc_taskred_modifier_init, DefaultAttrs, AttributeSet(),
923                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SExt))
924__OMP_RTL_ATTRS(__kmpc_taskred_init, DefaultAttrs, AttributeSet(),
925                ParamAttrs(SExt, SExt))
926__OMP_RTL_ATTRS(__kmpc_task_reduction_modifier_fini, BarrierAttrs,
927                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
928__OMP_RTL_ATTRS(__kmpc_task_reduction_get_th_data, DefaultAttrs, AttributeSet(),
929                ParamAttrs(SExt))
930__OMP_RTL_ATTRS(__kmpc_task_reduction_init, DefaultAttrs, AttributeSet(),
931                ParamAttrs(SExt, SExt))
932__OMP_RTL_ATTRS(__kmpc_task_reduction_modifier_init, DefaultAttrs,
933                AttributeSet(), ParamAttrs(AttributeSet(), SExt, SExt, SExt))
934__OMP_RTL_ATTRS(__kmpc_proxy_task_completed_ooo, DefaultAttrs, AttributeSet(),
935                ParamAttrs())
936
937__OMP_RTL_ATTRS(__kmpc_omp_wait_deps, BarrierAttrs, AttributeSet(),
938                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ReadOnlyPtrAttrs, SExt))
939__OMP_RTL_ATTRS(__kmpc_omp_taskwait_deps_51, BarrierAttrs, AttributeSet(),
940                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ReadOnlyPtrAttrs))
941__OMP_RTL_ATTRS(__kmpc_cancellationpoint, DefaultAttrs, SExt,
942                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
943
944__OMP_RTL_ATTRS(__kmpc_fork_teams, ForkAttrs, AttributeSet(),
945                ParamAttrs(ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs))
946__OMP_RTL_ATTRS(__kmpc_push_num_teams, InaccessibleArgOnlyAttrs, AttributeSet(),
947                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SExt))
948__OMP_RTL_ATTRS(__kmpc_set_thread_limit, InaccessibleArgOnlyAttrs, AttributeSet(),
949                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
950
951__OMP_RTL_ATTRS(__kmpc_copyprivate, DefaultAttrs, AttributeSet(),
952                ParamAttrs(ReadOnlyPtrAttrs, SExt, SizeTyExt,
953                           ReadOnlyPtrAttrs, AttributeSet(), SExt))
954__OMP_RTL_ATTRS(__kmpc_threadprivate_cached, DefaultAttrs, AttributeSet(),
955                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet(), SizeTyExt))
956__OMP_RTL_ATTRS(__kmpc_threadprivate_register, DefaultAttrs, AttributeSet(),
957                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), ReadOnlyPtrAttrs,
958                           ReadOnlyPtrAttrs, ReadOnlyPtrAttrs))
959
960__OMP_RTL_ATTRS(__kmpc_doacross_init, BarrierAttrs, AttributeSet(),
961                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
962__OMP_RTL_ATTRS(__kmpc_doacross_post, BarrierAttrs, AttributeSet(),
963                ParamAttrs(ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs))
964__OMP_RTL_ATTRS(__kmpc_doacross_wait, BarrierAttrs, AttributeSet(),
965                ParamAttrs(ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs))
966__OMP_RTL_ATTRS(__kmpc_doacross_fini, BarrierAttrs, AttributeSet(),
967                ParamAttrs(ReadOnlyPtrAttrs, SExt))
968
969__OMP_RTL_ATTRS(__kmpc_alloc_shared,
970                AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync),
971                             AllocSizeAttr(0, std::nullopt)),
972                ReturnPtrAttrs, ParamAttrs(SizeTyExt))
973__OMP_RTL_ATTRS(__kmpc_free_shared, DeviceAllocAttrs, AttributeSet(),
974                ParamAttrs(AttributeSet(EnumAttr(NoCapture),
975                                        EnumAttr(AllocatedPointer)),
976                           SizeTyExt))
977__OMP_RTL_ATTRS(__kmpc_begin_sharing_variables, AttributeSet(), AttributeSet(),
978                ParamAttrs(AttributeSet(), SizeTyExt))
979
980__OMP_RTL_ATTRS(__kmpc_alloc, DefaultAttrs, ReturnPtrAttrs,
981                ParamAttrs(SExt, SizeTyExt))
982__OMP_RTL_ATTRS(__kmpc_aligned_alloc, DefaultAttrs, ReturnPtrAttrs,
983                ParamAttrs(SExt, SizeTyExt, SizeTyExt))
984__OMP_RTL_ATTRS(__kmpc_free, AllocAttrs, AttributeSet(),
985                ParamAttrs(SExt))
986
987__OMP_RTL_ATTRS(__tgt_interop_init, AttributeSet(), AttributeSet(),
988                ParamAttrs(AttributeSet(), SExt, AttributeSet(), SExt,
989                           SExt, AttributeSet(), AttributeSet(), SExt))
990__OMP_RTL_ATTRS(__tgt_interop_destroy, AttributeSet(), AttributeSet(),
991                ParamAttrs(AttributeSet(), SExt, AttributeSet(), SExt, SExt,
992                           AttributeSet(), SExt))
993__OMP_RTL_ATTRS(__tgt_interop_use, AttributeSet(), AttributeSet(),
994                ParamAttrs(AttributeSet(), SExt, AttributeSet(), SExt, SExt,
995                           AttributeSet(), SExt))
996
997__OMP_RTL_ATTRS(__kmpc_init_allocator, DefaultAttrs, AttributeSet(),
998                ParamAttrs(SExt, AttributeSet(), SExt))
999__OMP_RTL_ATTRS(__kmpc_destroy_allocator, AllocAttrs, AttributeSet(),
1000                ParamAttrs(SExt))
1001
1002__OMP_RTL_ATTRS(__kmpc_push_target_tripcount_mapper, SetterAttrs,
1003                AttributeSet(), ParamAttrs())
1004__OMP_RTL_ATTRS(__tgt_target_mapper, ForkAttrs, SExt,
1005                ParamAttrs(AttributeSet(),AttributeSet(),AttributeSet(), SExt))
1006__OMP_RTL_ATTRS(__tgt_target_nowait_mapper, ForkAttrs, SExt,
1007                ParamAttrs(AttributeSet(), AttributeSet(), AttributeSet(), SExt,
1008                           AttributeSet(), AttributeSet(), AttributeSet(),
1009                           AttributeSet(), AttributeSet(), AttributeSet(),
1010                           SExt, AttributeSet(), SExt))
1011__OMP_RTL_ATTRS(__tgt_target_teams_mapper, ForkAttrs, SExt,
1012                ParamAttrs(AttributeSet(), AttributeSet(), AttributeSet(), SExt,
1013                           AttributeSet(), AttributeSet(), AttributeSet(),
1014                           AttributeSet(), AttributeSet(), AttributeSet(), SExt,
1015                           SExt))
1016__OMP_RTL_ATTRS(__tgt_target_teams_nowait_mapper, ForkAttrs, SExt,
1017                ParamAttrs(AttributeSet(), AttributeSet(), AttributeSet(), SExt,
1018                           AttributeSet(), AttributeSet(), AttributeSet(),
1019                           AttributeSet(), AttributeSet(), AttributeSet(),
1020                           SExt, SExt, SExt, AttributeSet(), SExt))
1021__OMP_RTL_ATTRS(__tgt_target_kernel, ForkAttrs, SExt,
1022                ParamAttrs(AttributeSet(), AttributeSet(), SExt, SExt))
1023__OMP_RTL_ATTRS(__tgt_target_kernel_nowait, ForkAttrs, SExt,
1024                ParamAttrs(AttributeSet(), AttributeSet(), SExt, SExt,
1025                           AttributeSet(), AttributeSet(), SExt, AttributeSet(),
1026                           SExt))
1027__OMP_RTL_ATTRS(__tgt_target_data_begin_mapper, ForkAttrs, AttributeSet(),
1028                ParamAttrs(AttributeSet(), AttributeSet(), SExt))
1029__OMP_RTL_ATTRS(__tgt_target_data_begin_nowait_mapper, ForkAttrs, AttributeSet(),
1030                ParamAttrs(AttributeSet(), AttributeSet(), SExt, AttributeSet(),
1031                           AttributeSet(), AttributeSet(), AttributeSet(),
1032                           AttributeSet(), AttributeSet()))
1033__OMP_RTL_ATTRS(__tgt_target_data_begin_mapper_issue, AttributeSet(),
1034                AttributeSet(),
1035                ParamAttrs(AttributeSet(), AttributeSet(), SExt))
1036__OMP_RTL_ATTRS(__tgt_target_data_end_mapper, ForkAttrs, AttributeSet(),
1037                ParamAttrs(AttributeSet(), AttributeSet(), SExt))
1038__OMP_RTL_ATTRS(__tgt_target_data_end_nowait_mapper, ForkAttrs, AttributeSet(),
1039                ParamAttrs(AttributeSet(), AttributeSet(), SExt, AttributeSet(),
1040                           AttributeSet(), AttributeSet(), AttributeSet(),
1041                           AttributeSet(), AttributeSet()))
1042__OMP_RTL_ATTRS(__tgt_target_data_update_mapper, ForkAttrs, AttributeSet(),
1043                ParamAttrs(AttributeSet(), AttributeSet(), SExt))
1044__OMP_RTL_ATTRS(__tgt_target_data_update_nowait_mapper, ForkAttrs, AttributeSet(),
1045                ParamAttrs(AttributeSet(), AttributeSet(), SExt, AttributeSet(),
1046                           AttributeSet(), AttributeSet(), AttributeSet(),
1047                           AttributeSet(), AttributeSet()))
1048__OMP_RTL_ATTRS(__tgt_mapper_num_components, ForkAttrs, AttributeSet(),
1049                ParamAttrs())
1050__OMP_RTL_ATTRS(__tgt_push_mapper_component, ForkAttrs, AttributeSet(),
1051                ParamAttrs())
1052__OMP_RTL_ATTRS(__kmpc_task_allow_completion_event, DefaultAttrs,
1053                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
1054
1055__OMP_RTL_ATTRS(__kmpc_target_init, AttributeSet(), SExt,
1056                ParamAttrs(AttributeSet()))
1057__OMP_RTL_ATTRS(__kmpc_target_deinit, AttributeSet(), AttributeSet(),
1058                ParamAttrs())
1059__OMP_RTL_ATTRS(__kmpc_parallel_51, AlwaysInlineAttrs, AttributeSet(),
1060                ParamAttrs(AttributeSet(), SExt, SExt, SExt, SExt,
1061                           AttributeSet(), AttributeSet(), AttributeSet(),
1062                           SizeTyExt))
1063__OMP_RTL_ATTRS(__kmpc_serialized_parallel, InaccessibleArgOnlyAttrs,
1064                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
1065__OMP_RTL_ATTRS(__kmpc_end_serialized_parallel, InaccessibleArgOnlyAttrs,
1066                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
1067__OMP_RTL_ATTRS(__kmpc_shuffle_int32, AttributeSet(), SExt,
1068                ParamAttrs(SExt, SExt, SExt))
1069__OMP_RTL_ATTRS(__kmpc_nvptx_parallel_reduce_nowait_v2, AttributeSet(), SExt,
1070                ParamAttrs())
1071__OMP_RTL_ATTRS(__kmpc_nvptx_teams_reduce_nowait_v2, AttributeSet(), SExt,
1072                ParamAttrs(AttributeSet(), AttributeSet(), ZExt))
1073__OMP_RTL_ATTRS(__kmpc_reduction_get_fixed_buffer, GetterAttrs, AttributeSet(), ParamAttrs())
1074
1075__OMP_RTL_ATTRS(__kmpc_shuffle_int64, AttributeSet(), AttributeSet(),
1076                ParamAttrs(AttributeSet(), SExt, SExt))
1077
1078__OMP_RTL_ATTRS(__kmpc_is_spmd_exec_mode, AttributeSet(), SExt, ParamAttrs())
1079
1080#undef __OMP_RTL_ATTRS
1081#undef OMP_RTL_ATTRS
1082#undef AttributeSet
1083#undef EnumAttr
1084#undef EnumAttrInt
1085#undef ParamAttrs
1086#undef AllocSizeAttr
1087
1088///}
1089
1090/// KMP ident_t bit flags
1091///
1092/// In accordance with the values in `openmp/runtime/src/kmp.h`.
1093///
1094///{
1095
1096#ifndef OMP_IDENT_FLAG
1097#define OMP_IDENT_FLAG(Enum, Str, Value)
1098#endif
1099
1100#define __OMP_IDENT_FLAG(Name, Value)                                          \
1101  OMP_IDENT_FLAG(OMP_IDENT_FLAG_##Name, #Name, Value)
1102
1103__OMP_IDENT_FLAG(KMPC, 0x02)
1104__OMP_IDENT_FLAG(ATOMIC_REDUCE, 0x10)
1105__OMP_IDENT_FLAG(BARRIER_EXPL, 0x20)
1106__OMP_IDENT_FLAG(BARRIER_IMPL, 0x0040)
1107__OMP_IDENT_FLAG(BARRIER_IMPL_MASK, 0x01C0)
1108__OMP_IDENT_FLAG(BARRIER_IMPL_FOR, 0x0040)
1109__OMP_IDENT_FLAG(BARRIER_IMPL_SECTIONS, 0x00C0)
1110__OMP_IDENT_FLAG(BARRIER_IMPL_SINGLE, 0x0140)
1111__OMP_IDENT_FLAG(BARRIER_IMPL_WORKSHARE, 0x01C0)
1112
1113#undef __OMP_IDENT_FLAG
1114#undef OMP_IDENT_FLAG
1115
1116///}
1117
1118/// KMP cancel kind
1119///
1120///{
1121
1122#ifndef OMP_CANCEL_KIND
1123#define OMP_CANCEL_KIND(Enum, Str, DirectiveEnum, Value)
1124#endif
1125
1126#define __OMP_CANCEL_KIND(Name, Value)                                         \
1127  OMP_CANCEL_KIND(OMP_CANCEL_KIND_##Name, #Name, OMPD_##Name, Value)
1128
1129__OMP_CANCEL_KIND(parallel, 1)
1130__OMP_CANCEL_KIND(for, 2)
1131__OMP_CANCEL_KIND(sections, 3)
1132__OMP_CANCEL_KIND(taskgroup, 4)
1133
1134#undef __OMP_CANCEL_KIND
1135#undef OMP_CANCEL_KIND
1136
1137///}
1138
1139/// Default kinds
1140///
1141///{
1142
1143#ifndef OMP_DEFAULT_KIND
1144#define OMP_DEFAULT_KIND(Enum, Str)
1145#endif
1146
1147#define __OMP_DEFAULT_KIND(Name) OMP_DEFAULT_KIND(OMP_DEFAULT_##Name, #Name)
1148
1149__OMP_DEFAULT_KIND(none)
1150__OMP_DEFAULT_KIND(shared)
1151__OMP_DEFAULT_KIND(private)
1152__OMP_DEFAULT_KIND(firstprivate)
1153__OMP_DEFAULT_KIND(unknown)
1154
1155#undef __OMP_DEFAULT_KIND
1156#undef OMP_DEFAULT_KIND
1157
1158///}
1159
1160/// Proc bind kinds
1161///
1162///{
1163
1164#ifndef OMP_PROC_BIND_KIND
1165#define OMP_PROC_BIND_KIND(Enum, Str, Value)
1166#endif
1167
1168#define __OMP_PROC_BIND_KIND(Name, Value)                                      \
1169  OMP_PROC_BIND_KIND(OMP_PROC_BIND_##Name, #Name, Value)
1170
1171__OMP_PROC_BIND_KIND(master, 2)
1172__OMP_PROC_BIND_KIND(close, 3)
1173__OMP_PROC_BIND_KIND(spread, 4)
1174__OMP_PROC_BIND_KIND(primary, 5)
1175__OMP_PROC_BIND_KIND(default, 6)
1176__OMP_PROC_BIND_KIND(unknown, 7)
1177
1178#undef __OMP_PROC_BIND_KIND
1179#undef OMP_PROC_BIND_KIND
1180
1181///}
1182
1183/// OpenMP context related definitions:
1184///  - trait set selector
1185///  - trait selector
1186///  - trait property
1187///
1188///{
1189
1190#ifndef OMP_TRAIT_SET
1191#define OMP_TRAIT_SET(Enum, Str)
1192#endif
1193#ifndef OMP_TRAIT_SELECTOR
1194#define OMP_TRAIT_SELECTOR(Enum, TraitSetEnum, Str, RequiresProperty)
1195#endif
1196#ifndef OMP_TRAIT_PROPERTY
1197#define OMP_TRAIT_PROPERTY(Enum, TraitSetEnum, TraitSelectorEnum, Str)
1198#endif
1199#ifndef OMP_LAST_TRAIT_PROPERTY
1200#define OMP_LAST_TRAIT_PROPERTY(Enum)
1201#endif
1202
1203#define __OMP_TRAIT_SET(Name) OMP_TRAIT_SET(Name, #Name)
1204#define __OMP_TRAIT_SELECTOR(TraitSet, Name, RequiresProperty)                 \
1205  OMP_TRAIT_SELECTOR(TraitSet##_##Name, TraitSet, #Name, RequiresProperty)
1206#define __OMP_TRAIT_SELECTOR_AND_PROPERTY(TraitSet, Name)                      \
1207  OMP_TRAIT_SELECTOR(TraitSet##_##Name, TraitSet, #Name, false)                \
1208  OMP_TRAIT_PROPERTY(TraitSet##_##Name##_##Name, TraitSet, TraitSet##_##Name,  \
1209                     #Name)
1210#define __OMP_TRAIT_PROPERTY(TraitSet, TraitSelector, Name)                    \
1211  OMP_TRAIT_PROPERTY(TraitSet##_##TraitSelector##_##Name, TraitSet,            \
1212                     TraitSet##_##TraitSelector, #Name)
1213
1214// "invalid" must go first.
1215OMP_TRAIT_SET(invalid, "invalid")
1216OMP_TRAIT_SELECTOR(invalid, invalid, "invalid", false)
1217OMP_TRAIT_PROPERTY(invalid, invalid, invalid, "invalid")
1218
1219__OMP_TRAIT_SET(construct)
1220__OMP_TRAIT_SELECTOR_AND_PROPERTY(construct, target)
1221__OMP_TRAIT_SELECTOR_AND_PROPERTY(construct, teams)
1222__OMP_TRAIT_SELECTOR_AND_PROPERTY(construct, parallel)
1223__OMP_TRAIT_SELECTOR_AND_PROPERTY(construct, for)
1224__OMP_TRAIT_SELECTOR_AND_PROPERTY(construct, simd)
1225
1226__OMP_TRAIT_SET(device)
1227
1228__OMP_TRAIT_SELECTOR(device, kind, true)
1229
1230__OMP_TRAIT_PROPERTY(device, kind, host)
1231__OMP_TRAIT_PROPERTY(device, kind, nohost)
1232__OMP_TRAIT_PROPERTY(device, kind, cpu)
1233__OMP_TRAIT_PROPERTY(device, kind, gpu)
1234__OMP_TRAIT_PROPERTY(device, kind, fpga)
1235__OMP_TRAIT_PROPERTY(device, kind, any)
1236
1237__OMP_TRAIT_SELECTOR(device, arch, true)
1238
1239__OMP_TRAIT_PROPERTY(device, arch, arm)
1240__OMP_TRAIT_PROPERTY(device, arch, armeb)
1241__OMP_TRAIT_PROPERTY(device, arch, aarch64)
1242__OMP_TRAIT_PROPERTY(device, arch, aarch64_be)
1243__OMP_TRAIT_PROPERTY(device, arch, aarch64_32)
1244__OMP_TRAIT_PROPERTY(device, arch, ppc)
1245__OMP_TRAIT_PROPERTY(device, arch, ppcle)
1246__OMP_TRAIT_PROPERTY(device, arch, ppc64)
1247__OMP_TRAIT_PROPERTY(device, arch, ppc64le)
1248__OMP_TRAIT_PROPERTY(device, arch, x86)
1249__OMP_TRAIT_PROPERTY(device, arch, x86_64)
1250__OMP_TRAIT_PROPERTY(device, arch, amdgcn)
1251__OMP_TRAIT_PROPERTY(device, arch, nvptx)
1252__OMP_TRAIT_PROPERTY(device, arch, nvptx64)
1253
1254__OMP_TRAIT_SET(implementation)
1255
1256__OMP_TRAIT_SELECTOR(implementation, vendor, true)
1257
1258__OMP_TRAIT_PROPERTY(implementation, vendor, amd)
1259__OMP_TRAIT_PROPERTY(implementation, vendor, arm)
1260__OMP_TRAIT_PROPERTY(implementation, vendor, bsc)
1261__OMP_TRAIT_PROPERTY(implementation, vendor, cray)
1262__OMP_TRAIT_PROPERTY(implementation, vendor, fujitsu)
1263__OMP_TRAIT_PROPERTY(implementation, vendor, gnu)
1264__OMP_TRAIT_PROPERTY(implementation, vendor, ibm)
1265__OMP_TRAIT_PROPERTY(implementation, vendor, intel)
1266__OMP_TRAIT_PROPERTY(implementation, vendor, llvm)
1267__OMP_TRAIT_PROPERTY(implementation, vendor, nec)
1268__OMP_TRAIT_PROPERTY(implementation, vendor, nvidia)
1269__OMP_TRAIT_PROPERTY(implementation, vendor, pgi)
1270__OMP_TRAIT_PROPERTY(implementation, vendor, ti)
1271__OMP_TRAIT_PROPERTY(implementation, vendor, unknown)
1272
1273__OMP_TRAIT_SELECTOR(implementation, extension, true)
1274__OMP_TRAIT_PROPERTY(implementation, extension, match_all)
1275__OMP_TRAIT_PROPERTY(implementation, extension, match_any)
1276__OMP_TRAIT_PROPERTY(implementation, extension, match_none)
1277__OMP_TRAIT_PROPERTY(implementation, extension, disable_implicit_base)
1278__OMP_TRAIT_PROPERTY(implementation, extension, allow_templates)
1279__OMP_TRAIT_PROPERTY(implementation, extension, bind_to_declaration)
1280
1281__OMP_TRAIT_SET(user)
1282
1283__OMP_TRAIT_SELECTOR(user, condition, true)
1284
1285__OMP_TRAIT_PROPERTY(user, condition, true)
1286__OMP_TRAIT_PROPERTY(user, condition, false)
1287__OMP_TRAIT_PROPERTY(user, condition, unknown)
1288
1289__OMP_TRAIT_SELECTOR_AND_PROPERTY(construct, dispatch)
1290
1291// Note that we put isa last so that the other conditions are checked first.
1292// This allows us to issue warnings wrt. isa only if we match otherwise.
1293__OMP_TRAIT_SELECTOR(device, isa, true)
1294
1295// We use "__ANY" as a placeholder in the isa property to denote the
1296// conceptual "any", not the literal `any` used in kind. The string we
1297// we use is not important except that it will show up in diagnostics.
1298OMP_TRAIT_PROPERTY(device_isa___ANY, device, device_isa,
1299                   "<any, entirely target dependent>")
1300
1301
1302#undef OMP_TRAIT_SET
1303#undef __OMP_TRAIT_SET
1304///}
1305
1306/// Traits for the requires directive
1307///
1308/// These will (potentially) become trait selectors for the OpenMP context if
1309/// the OMP_REQUIRES_TRAIT macro is not defined.
1310///
1311///{
1312
1313#ifdef OMP_REQUIRES_TRAIT
1314#define __OMP_REQUIRES_TRAIT(Name)                                             \
1315  OMP_REQUIRES_TRAIT(OMP_REQUIRES_TRAIT_##Name, #Name)
1316#else
1317#define __OMP_REQUIRES_TRAIT(Name)                                             \
1318  __OMP_TRAIT_SELECTOR_AND_PROPERTY(implementation, Name)
1319#endif
1320
1321__OMP_REQUIRES_TRAIT(unified_address)
1322__OMP_REQUIRES_TRAIT(unified_shared_memory)
1323__OMP_REQUIRES_TRAIT(reverse_offload)
1324__OMP_REQUIRES_TRAIT(dynamic_allocators)
1325__OMP_REQUIRES_TRAIT(atomic_default_mem_order)
1326
1327OMP_LAST_TRAIT_PROPERTY(
1328    implementation_atomic_default_mem_order_atomic_default_mem_order)
1329
1330#undef __OMP_TRAIT_SELECTOR_AND_PROPERTY
1331#undef OMP_TRAIT_SELECTOR
1332#undef __OMP_TRAIT_SELECTOR
1333#undef OMP_TRAIT_PROPERTY
1334#undef OMP_LAST_TRAIT_PROPERTY
1335#undef __OMP_TRAIT_PROPERTY
1336#undef __OMP_REQUIRES_TRAIT
1337#undef OMP_REQUIRES_TRAIT
1338///}
1339
1340
1341/// Assumption clauses
1342///
1343///{
1344
1345#ifdef OMP_ASSUME_CLAUSE
1346#define __OMP_ASSUME_CLAUSE(Identifier, StartsWith, HasDirectiveList, HasExpression) \
1347OMP_ASSUME_CLAUSE(Identifier, StartsWith, HasDirectiveList, HasExpression)
1348#else
1349#define __OMP_ASSUME_CLAUSE(...)
1350#endif
1351
1352__OMP_ASSUME_CLAUSE(llvm::StringLiteral("ext_"), true, false, false)
1353__OMP_ASSUME_CLAUSE(llvm::StringLiteral("absent"), false, true, false)
1354__OMP_ASSUME_CLAUSE(llvm::StringLiteral("contains"), false, true, false)
1355__OMP_ASSUME_CLAUSE(llvm::StringLiteral("holds"), false, false, true)
1356__OMP_ASSUME_CLAUSE(llvm::StringLiteral("no_openmp"), false, false, false)
1357__OMP_ASSUME_CLAUSE(llvm::StringLiteral("no_openmp_routines"), false, false, false)
1358__OMP_ASSUME_CLAUSE(llvm::StringLiteral("no_parallelism"), false, false, false)
1359
1360#undef __OMP_ASSUME_CLAUSE
1361#undef OMP_ASSUME_CLAUSE
1362///}
1363