• 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_register_requires, false, Void, Int64)
440__OMP_RTL(__tgt_target_data_begin_mapper, false, Void, IdentPtr, Int64, Int32, VoidPtrPtr,
441          VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr)
442__OMP_RTL(__tgt_target_data_begin_nowait_mapper, false, Void, IdentPtr, Int64, Int32,
443          VoidPtrPtr, VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr)
444__OMP_RTL(__tgt_target_data_begin_mapper_issue, false, Void, IdentPtr, Int64, Int32,
445          VoidPtrPtr, VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr, AsyncInfoPtr)
446__OMP_RTL(__tgt_target_data_begin_mapper_wait, false, Void, Int64, AsyncInfoPtr)
447__OMP_RTL(__tgt_target_data_end_mapper, false, Void, IdentPtr, Int64, Int32, VoidPtrPtr,
448          VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr)
449__OMP_RTL(__tgt_target_data_end_nowait_mapper, false, Void, IdentPtr, Int64, Int32,
450          VoidPtrPtr, VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr)
451__OMP_RTL(__tgt_target_data_update_mapper, false, Void, IdentPtr, Int64, Int32,
452          VoidPtrPtr, VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr)
453__OMP_RTL(__tgt_target_data_update_nowait_mapper, false, Void, IdentPtr, Int64, Int32,
454          VoidPtrPtr, VoidPtrPtr, Int64Ptr, Int64Ptr, VoidPtrPtr, VoidPtrPtr)
455__OMP_RTL(__tgt_mapper_num_components, false, Int64, VoidPtr)
456__OMP_RTL(__tgt_push_mapper_component, false, Void, VoidPtr, VoidPtr, VoidPtr,
457          Int64, Int64, VoidPtr)
458__OMP_RTL(__kmpc_task_allow_completion_event, false, VoidPtr, IdentPtr,
459          /* Int */ Int32, /* kmp_task_t */ VoidPtr)
460
461/// OpenMP Device runtime functions
462__OMP_RTL(__kmpc_target_init, false, Int32, KernelEnvironmentPtr, KernelLaunchEnvironmentPtr)
463__OMP_RTL(__kmpc_target_deinit, false, Void,)
464__OMP_RTL(__kmpc_kernel_prepare_parallel, false, Void, VoidPtr)
465__OMP_RTL(__kmpc_parallel_51, false, Void, IdentPtr, Int32, Int32, Int32, Int32,
466          VoidPtr, VoidPtr, VoidPtrPtr, SizeTy)
467__OMP_RTL(__kmpc_for_static_loop_4, false, Void, IdentPtr, VoidPtr, VoidPtr, Int32, Int32, Int32)
468__OMP_RTL(__kmpc_for_static_loop_4u, false, Void, IdentPtr, VoidPtr, VoidPtr, Int32, Int32, Int32)
469__OMP_RTL(__kmpc_for_static_loop_8, false, Void, IdentPtr, VoidPtr, VoidPtr, Int64, Int64, Int64)
470__OMP_RTL(__kmpc_for_static_loop_8u, false, Void, IdentPtr, VoidPtr, VoidPtr, Int64, Int64, Int64)
471__OMP_RTL(__kmpc_distribute_static_loop_4, false, Void, IdentPtr, VoidPtr, VoidPtr, Int32, Int32)
472__OMP_RTL(__kmpc_distribute_static_loop_4u, false, Void, IdentPtr, VoidPtr, VoidPtr, Int32, Int32)
473__OMP_RTL(__kmpc_distribute_static_loop_8, false, Void, IdentPtr, VoidPtr, VoidPtr, Int64, Int64)
474__OMP_RTL(__kmpc_distribute_static_loop_8u, false, Void, IdentPtr, VoidPtr, VoidPtr, Int64, Int64)
475__OMP_RTL(__kmpc_distribute_for_static_loop_4, false, Void, IdentPtr, VoidPtr, VoidPtr, Int32, Int32, Int32, Int32)
476__OMP_RTL(__kmpc_distribute_for_static_loop_4u, false, Void, IdentPtr, VoidPtr, VoidPtr, Int32, Int32, Int32, Int32)
477__OMP_RTL(__kmpc_distribute_for_static_loop_8, false, Void, IdentPtr, VoidPtr, VoidPtr, Int64, Int64, Int64, Int64)
478__OMP_RTL(__kmpc_distribute_for_static_loop_8u, false, Void, IdentPtr, VoidPtr, VoidPtr, Int64, Int64, Int64, Int64)
479__OMP_RTL(__kmpc_kernel_parallel, false, Int1, VoidPtrPtr)
480__OMP_RTL(__kmpc_kernel_end_parallel, false, Void, )
481__OMP_RTL(__kmpc_serialized_parallel, false, Void, IdentPtr, Int32)
482__OMP_RTL(__kmpc_end_serialized_parallel, false, Void, IdentPtr, Int32)
483__OMP_RTL(__kmpc_shuffle_int32, false, Int32, Int32, Int16, Int16)
484__OMP_RTL(__kmpc_nvptx_parallel_reduce_nowait_v2, false, Int32, IdentPtr,
485	  Int64, VoidPtr, ShuffleReducePtr, InterWarpCopyPtr)
486__OMP_RTL(__kmpc_nvptx_teams_reduce_nowait_v2, false, Int32, IdentPtr,
487          VoidPtr, Int32, Int64, VoidPtr, ShuffleReducePtr, InterWarpCopyPtr,
488          GlobalListPtr, GlobalListPtr, GlobalListPtr, GlobalListPtr)
489__OMP_RTL(__kmpc_reduction_get_fixed_buffer, false, VoidPtr, )
490
491__OMP_RTL(__kmpc_shuffle_int64, false, Int64, Int64, Int16, Int16)
492
493__OMP_RTL(__kmpc_alloc_shared, false, VoidPtr, SizeTy)
494__OMP_RTL(__kmpc_free_shared, false, Void, VoidPtr, SizeTy)
495__OMP_RTL(__kmpc_begin_sharing_variables, false, Void, VoidPtrPtrPtr, SizeTy)
496__OMP_RTL(__kmpc_end_sharing_variables, false, Void, )
497__OMP_RTL(__kmpc_get_shared_variables, false, Void, VoidPtrPtrPtr)
498__OMP_RTL(__kmpc_parallel_level, false, Int16, IdentPtr, Int32)
499__OMP_RTL(__kmpc_is_spmd_exec_mode, false, Int8, )
500__OMP_RTL(__kmpc_barrier_simple_spmd, false, Void, IdentPtr, Int32)
501__OMP_RTL(__kmpc_barrier_simple_generic, false, Void, IdentPtr, Int32)
502
503__OMP_RTL(__kmpc_warp_active_thread_mask, false, Int64,)
504__OMP_RTL(__kmpc_syncwarp, false, Void, Int64)
505
506__OMP_RTL(__last, false, Void, )
507
508#undef __OMP_RTL
509#undef OMP_RTL
510
511#define ParamAttrs(...) ArrayRef<AttributeSet>({__VA_ARGS__})
512#define EnumAttr(Kind) Attribute::get(Ctx, Attribute::AttrKind::Kind)
513#define EnumAttrInt(Kind, N) Attribute::get(Ctx, Attribute::AttrKind::Kind, N)
514#define AllocSizeAttr(N, M) Attribute::getWithAllocSizeArgs(Ctx, N, M)
515#define MemoryAttr(ME) Attribute::getWithMemoryEffects(Ctx, ME)
516#define AttributeSet(...)                                                      \
517  AttributeSet::get(Ctx, ArrayRef<Attribute>({__VA_ARGS__}))
518
519#ifndef OMP_ATTRS_SET
520#define OMP_ATTRS_SET(VarName, AttrSet)
521#endif
522
523#define __OMP_ATTRS_SET(VarName, AttrSet) OMP_ATTRS_SET(VarName, AttrSet)
524
525__OMP_ATTRS_SET(
526    GetterAttrs,
527    OptimisticAttributes
528        ? AttributeSet(
529              EnumAttr(NoUnwind), EnumAttr(NoSync), EnumAttr(NoFree),
530              EnumAttr(WillReturn),
531              MemoryAttr(MemoryEffects::inaccessibleMemOnly(ModRefInfo::Ref)))
532        : AttributeSet(EnumAttr(NoUnwind)))
533__OMP_ATTRS_SET(
534    GetterArgReadAttrs,
535    OptimisticAttributes
536        ? AttributeSet(
537              EnumAttr(NoUnwind), EnumAttr(NoSync), EnumAttr(NoFree),
538              EnumAttr(WillReturn),
539              MemoryAttr(MemoryEffects::inaccessibleOrArgMemOnly(ModRefInfo::Ref)))
540        : AttributeSet(EnumAttr(NoUnwind)))
541__OMP_ATTRS_SET(
542    GetterArgWriteAttrs,
543    OptimisticAttributes
544        ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync), EnumAttr(NoFree),
545                       EnumAttr(WillReturn),
546                       MemoryAttr(MemoryEffects::argMemOnly() | MemoryEffects::inaccessibleMemOnly(ModRefInfo::Ref)))
547        : AttributeSet(EnumAttr(NoUnwind)))
548__OMP_ATTRS_SET(
549  SetterAttrs,
550  OptimisticAttributes
551      ? AttributeSet(
552            EnumAttr(NoUnwind), EnumAttr(NoSync), EnumAttr(NoFree),
553            EnumAttr(WillReturn),
554            MemoryAttr(MemoryEffects::inaccessibleMemOnly(ModRefInfo::Mod)))
555      : AttributeSet(EnumAttr(NoUnwind)))
556
557__OMP_ATTRS_SET(DefaultAttrs,
558                OptimisticAttributes
559                    ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync),
560                                   EnumAttr(WillReturn), EnumAttr(NoFree))
561                    : AttributeSet(EnumAttr(NoUnwind)))
562
563__OMP_ATTRS_SET(BarrierAttrs,
564                OptimisticAttributes
565                    ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(Convergent))
566                    : AttributeSet(EnumAttr(NoUnwind), EnumAttr(Convergent)))
567
568__OMP_ATTRS_SET(
569    InaccessibleArgOnlyAttrs,
570    OptimisticAttributes
571         ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync), EnumAttr(NoFree),
572                        EnumAttr(WillReturn),
573                        MemoryAttr(MemoryEffects::inaccessibleOrArgMemOnly()))
574         : AttributeSet(EnumAttr(NoUnwind)))
575
576__OMP_ATTRS_SET(AlwaysInlineAttrs,
577                OptimisticAttributes
578                    ? AttributeSet(EnumAttr(AlwaysInline))
579                    : AttributeSet(EnumAttr(AlwaysInline)))
580
581#if 0
582__OMP_ATTRS_SET(
583    InaccessibleOnlyAttrs,
584    OptimisticAttributes
585        ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync), EnumAttr(NoFree),
586                       EnumAttr(WillReturn),
587                       MemoryAttr(MemoryEffects::inaccessibleMemOnly()))
588        : AttributeSet(EnumAttr(NoUnwind)))
589#endif
590
591__OMP_ATTRS_SET(AllocAttrs,
592                OptimisticAttributes
593                    ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync),
594                                   EnumAttr(WillReturn))
595                    : AttributeSet(EnumAttr(NoUnwind)))
596
597__OMP_ATTRS_SET(ForkAttrs, OptimisticAttributes
598                               ? AttributeSet(EnumAttr(NoUnwind))
599                               : AttributeSet(EnumAttr(NoUnwind)))
600
601__OMP_ATTRS_SET(ReadOnlyPtrAttrs,
602                OptimisticAttributes
603                    ? AttributeSet(EnumAttr(ReadOnly), EnumAttr(NoFree),
604                                   EnumAttr(NoCapture))
605                    : AttributeSet())
606
607__OMP_ATTRS_SET(DeviceAllocAttrs,
608                OptimisticAttributes
609                    ? AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync))
610                    : AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync)))
611
612#if 0
613__OMP_ATTRS_SET(WriteOnlyPtrAttrs,
614                OptimisticAttributes
615                    ? AttributeSet(EnumAttr(WriteOnly), EnumAttr(NoFree),
616                                   EnumAttr(NoCapture))
617                    : AttributeSet())
618#endif
619
620__OMP_ATTRS_SET(ArgPtrAttrs,
621                OptimisticAttributes
622                    ? AttributeSet(EnumAttr(NoCapture), EnumAttr(NoFree))
623                    : AttributeSet())
624
625__OMP_ATTRS_SET(ReturnPtrAttrs, AttributeSet(EnumAttr(NoAlias)))
626
627__OMP_ATTRS_SET(ZExt, AttributeSet(EnumAttr(ZExt)))
628__OMP_ATTRS_SET(SExt, AttributeSet(EnumAttr(SExt)))
629__OMP_ATTRS_SET(SizeTyExt,
630                M.getDataLayout().getIntPtrType(Ctx)->getBitWidth() < 64
631                    ? AttributeSet(EnumAttr(ZExt))
632                    : AttributeSet())
633
634#if 0
635__OMP_ATTRS_SET(ReturnAlignedPtrAttrs,
636                OptimisticAttributes
637                    ? AttributeSet(EnumAttr(NoAlias), EnumAttrInt(Alignment, 8),
638                                   EnumAttrInt(DereferenceableOrNull, 8))
639                    : AttributeSet())
640#endif
641
642#undef __OMP_ATTRS_SET
643#undef OMP_ATTRS_SET
644
645#ifndef OMP_RTL_ATTRS
646#define OMP_RTL_ATTRS(Enum, FnAttrSet, RetAttrSet, ArgAttrSets)
647#endif
648
649#define __OMP_RTL_ATTRS(Name, FnAttrSet, RetAttrSet, ArgAttrSets)              \
650  OMP_RTL_ATTRS(OMPRTL_##Name, FnAttrSet, RetAttrSet, ArgAttrSets)
651
652__OMP_RTL_ATTRS(__kmpc_barrier, BarrierAttrs, AttributeSet(),
653                ParamAttrs(ReadOnlyPtrAttrs, SExt))
654__OMP_RTL_ATTRS(__kmpc_barrier_simple_spmd, BarrierAttrs, AttributeSet(),
655                ParamAttrs(ReadOnlyPtrAttrs, SExt))
656__OMP_RTL_ATTRS(__kmpc_barrier_simple_generic, BarrierAttrs, AttributeSet(),
657                ParamAttrs(ReadOnlyPtrAttrs, SExt))
658__OMP_RTL_ATTRS(__kmpc_warp_active_thread_mask, BarrierAttrs, AttributeSet(),
659                ParamAttrs())
660__OMP_RTL_ATTRS(__kmpc_syncwarp, BarrierAttrs, AttributeSet(), ParamAttrs())
661__OMP_RTL_ATTRS(__kmpc_cancel, InaccessibleArgOnlyAttrs, SExt,
662                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
663__OMP_RTL_ATTRS(__kmpc_cancel_barrier, BarrierAttrs, SExt,
664                ParamAttrs(ReadOnlyPtrAttrs, SExt))
665__OMP_RTL_ATTRS(__kmpc_distribute_for_static_loop_4, AlwaysInlineAttrs, AttributeSet(),
666                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), AttributeSet(),
667                           SExt, SExt, SExt, SExt))
668__OMP_RTL_ATTRS(__kmpc_distribute_for_static_loop_4u, AlwaysInlineAttrs, AttributeSet(),
669                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), AttributeSet(),
670                           ZExt, ZExt, ZExt, ZExt))
671__OMP_RTL_ATTRS(__kmpc_distribute_static_loop_4, AlwaysInlineAttrs, AttributeSet(),
672                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), AttributeSet(),
673                           SExt, SExt))
674__OMP_RTL_ATTRS(__kmpc_distribute_static_loop_4u, AlwaysInlineAttrs, AttributeSet(),
675                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), AttributeSet(),
676                           ZExt, ZExt))
677__OMP_RTL_ATTRS(__kmpc_for_static_loop_4, AlwaysInlineAttrs, AttributeSet(),
678                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), AttributeSet(),
679                           SExt, SExt, SExt))
680__OMP_RTL_ATTRS(__kmpc_for_static_loop_4u, AlwaysInlineAttrs, AttributeSet(),
681                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), AttributeSet(),
682                           ZExt, ZExt, ZExt))
683__OMP_RTL_ATTRS(__kmpc_error, AttributeSet(), AttributeSet(),
684                ParamAttrs(AttributeSet(), SExt))
685__OMP_RTL_ATTRS(__kmpc_flush, BarrierAttrs, AttributeSet(),
686                ParamAttrs(ReadOnlyPtrAttrs))
687__OMP_RTL_ATTRS(__kmpc_global_thread_num, GetterArgReadAttrs, SExt,
688                ParamAttrs(ReadOnlyPtrAttrs))
689__OMP_RTL_ATTRS(__kmpc_get_hardware_thread_id_in_block, GetterAttrs, ZExt,
690                ParamAttrs())
691__OMP_RTL_ATTRS(__kmpc_fork_call, ForkAttrs, AttributeSet(),
692                ParamAttrs(ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs))
693__OMP_RTL_ATTRS(__kmpc_fork_call_if, AttributeSet(), AttributeSet(),
694                ParamAttrs(ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs, SExt))
695__OMP_RTL_ATTRS(__kmpc_omp_taskwait, BarrierAttrs, SExt,
696                ParamAttrs(ReadOnlyPtrAttrs, SExt))
697__OMP_RTL_ATTRS(__kmpc_omp_taskyield, InaccessibleArgOnlyAttrs, SExt,
698                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
699__OMP_RTL_ATTRS(__kmpc_push_num_threads, InaccessibleArgOnlyAttrs,
700                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
701__OMP_RTL_ATTRS(__kmpc_push_proc_bind, InaccessibleArgOnlyAttrs, AttributeSet(),
702                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
703__OMP_RTL_ATTRS(__kmpc_omp_reg_task_with_affinity, DefaultAttrs, SExt,
704                ParamAttrs(ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs,
705                           SExt, ReadOnlyPtrAttrs))
706
707__OMP_RTL_ATTRS(__kmpc_get_hardware_num_blocks, GetterAttrs, ZExt, ParamAttrs())
708__OMP_RTL_ATTRS(__kmpc_get_hardware_num_threads_in_block, GetterAttrs, ZExt, ParamAttrs())
709__OMP_RTL_ATTRS(__kmpc_get_warp_size, GetterAttrs, ZExt, ParamAttrs())
710
711__OMP_RTL_ATTRS(omp_get_thread_num, GetterAttrs, SExt, ParamAttrs())
712__OMP_RTL_ATTRS(omp_get_num_threads, GetterAttrs, SExt, ParamAttrs())
713__OMP_RTL_ATTRS(omp_get_max_threads, GetterAttrs, SExt, ParamAttrs())
714__OMP_RTL_ATTRS(omp_in_parallel, GetterAttrs, SExt, ParamAttrs())
715__OMP_RTL_ATTRS(omp_get_dynamic, GetterAttrs, SExt, ParamAttrs())
716__OMP_RTL_ATTRS(omp_get_cancellation, GetterAttrs, SExt, ParamAttrs())
717__OMP_RTL_ATTRS(omp_get_nested, GetterAttrs, SExt, ParamAttrs())
718__OMP_RTL_ATTRS(
719    omp_get_schedule, GetterArgWriteAttrs, AttributeSet(),
720    ParamAttrs(AttributeSet(EnumAttr(NoCapture), EnumAttr(WriteOnly)),
721               AttributeSet(EnumAttr(NoCapture), EnumAttr(WriteOnly))))
722__OMP_RTL_ATTRS(omp_get_thread_limit, GetterAttrs, SExt, ParamAttrs())
723__OMP_RTL_ATTRS(omp_get_supported_active_levels, GetterAttrs, SExt, ParamAttrs())
724__OMP_RTL_ATTRS(omp_get_max_active_levels, GetterAttrs, SExt, ParamAttrs())
725__OMP_RTL_ATTRS(omp_get_level, GetterAttrs, SExt, ParamAttrs())
726__OMP_RTL_ATTRS(omp_get_ancestor_thread_num, GetterAttrs, SExt, ParamAttrs(SExt))
727__OMP_RTL_ATTRS(omp_get_team_size, GetterAttrs, SExt, ParamAttrs(SExt))
728__OMP_RTL_ATTRS(omp_get_active_level, GetterAttrs, SExt, ParamAttrs())
729__OMP_RTL_ATTRS(omp_in_final, GetterAttrs, SExt, ParamAttrs())
730__OMP_RTL_ATTRS(omp_get_proc_bind, GetterAttrs, SExt, ParamAttrs())
731__OMP_RTL_ATTRS(omp_get_num_places, GetterAttrs, SExt, ParamAttrs())
732__OMP_RTL_ATTRS(omp_get_num_procs, GetterAttrs, SExt, ParamAttrs())
733__OMP_RTL_ATTRS(omp_get_place_proc_ids, GetterArgWriteAttrs, AttributeSet(),
734                ParamAttrs(SExt, AttributeSet(EnumAttr(NoCapture),
735                                              EnumAttr(WriteOnly))))
736__OMP_RTL_ATTRS(omp_get_place_num, GetterAttrs, SExt, ParamAttrs())
737__OMP_RTL_ATTRS(omp_get_partition_num_places, GetterAttrs, SExt, ParamAttrs())
738__OMP_RTL_ATTRS(omp_get_partition_place_nums, GetterArgWriteAttrs, AttributeSet(),
739                ParamAttrs())
740__OMP_RTL_ATTRS(omp_get_wtime, GetterAttrs, AttributeSet(), ParamAttrs())
741
742__OMP_RTL_ATTRS(omp_set_num_threads, SetterAttrs, AttributeSet(),
743                ParamAttrs(SExt))
744__OMP_RTL_ATTRS(omp_set_dynamic, SetterAttrs, AttributeSet(), ParamAttrs(SExt))
745__OMP_RTL_ATTRS(omp_set_nested, SetterAttrs, AttributeSet(), ParamAttrs(SExt))
746__OMP_RTL_ATTRS(omp_set_schedule, SetterAttrs, AttributeSet(),
747                ParamAttrs(SExt, SExt))
748__OMP_RTL_ATTRS(omp_set_max_active_levels, SetterAttrs, AttributeSet(),
749                ParamAttrs(SExt))
750
751__OMP_RTL_ATTRS(__kmpc_master, InaccessibleArgOnlyAttrs, SExt,
752                ParamAttrs(ReadOnlyPtrAttrs, SExt))
753__OMP_RTL_ATTRS(__kmpc_end_master, InaccessibleArgOnlyAttrs, AttributeSet(),
754                ParamAttrs(ReadOnlyPtrAttrs, SExt))
755__OMP_RTL_ATTRS(__kmpc_masked, InaccessibleArgOnlyAttrs, SExt,
756                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
757__OMP_RTL_ATTRS(__kmpc_end_masked, InaccessibleArgOnlyAttrs, AttributeSet(),
758                ParamAttrs(ReadOnlyPtrAttrs, SExt))
759__OMP_RTL_ATTRS(__kmpc_critical, BarrierAttrs, AttributeSet(),
760                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet()))
761__OMP_RTL_ATTRS(__kmpc_critical_with_hint, BarrierAttrs, AttributeSet(),
762                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet(), ZExt))
763__OMP_RTL_ATTRS(__kmpc_end_critical, BarrierAttrs, AttributeSet(),
764                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet()))
765
766__OMP_RTL_ATTRS(__kmpc_begin, DefaultAttrs, AttributeSet(),
767                ParamAttrs(ReadOnlyPtrAttrs, SExt))
768__OMP_RTL_ATTRS(__kmpc_end, DefaultAttrs, AttributeSet(),
769                ParamAttrs(ReadOnlyPtrAttrs))
770
771__OMP_RTL_ATTRS(__kmpc_reduce, BarrierAttrs, SExt,
772                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SizeTyExt,
773                           ReadOnlyPtrAttrs, AttributeSet()))
774__OMP_RTL_ATTRS(__kmpc_reduce_nowait, BarrierAttrs, SExt,
775                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SizeTyExt,
776                           ReadOnlyPtrAttrs, AttributeSet()))
777__OMP_RTL_ATTRS(__kmpc_end_reduce, BarrierAttrs, AttributeSet(),
778                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet()))
779__OMP_RTL_ATTRS(__kmpc_end_reduce_nowait, BarrierAttrs, AttributeSet(),
780                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet()))
781
782__OMP_RTL_ATTRS(__kmpc_ordered, BarrierAttrs, AttributeSet(),
783                ParamAttrs(ReadOnlyPtrAttrs, SExt))
784__OMP_RTL_ATTRS(__kmpc_end_ordered, BarrierAttrs, AttributeSet(),
785                ParamAttrs(ReadOnlyPtrAttrs, SExt))
786
787__OMP_RTL_ATTRS(__kmpc_for_static_init_4, GetterArgWriteAttrs, AttributeSet(),
788                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
789                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs, SExt, SExt))
790__OMP_RTL_ATTRS(__kmpc_for_static_init_4u, GetterArgWriteAttrs, AttributeSet(),
791                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
792                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs, SExt, SExt))
793__OMP_RTL_ATTRS(__kmpc_for_static_init_8, GetterArgWriteAttrs, AttributeSet(),
794                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
795                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs,
796                           AttributeSet(), AttributeSet()))
797__OMP_RTL_ATTRS(__kmpc_for_static_init_8u, GetterArgWriteAttrs, AttributeSet(),
798                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
799                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs,
800                           AttributeSet(), AttributeSet()))
801__OMP_RTL_ATTRS(__kmpc_for_static_fini, InaccessibleArgOnlyAttrs,
802                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
803__OMP_RTL_ATTRS(__kmpc_distribute_static_init_4, GetterArgWriteAttrs,
804                AttributeSet(),
805                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
806                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs, SExt, SExt))
807__OMP_RTL_ATTRS(__kmpc_distribute_static_init_4u, GetterArgWriteAttrs,
808                AttributeSet(),
809                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
810                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs, SExt, SExt))
811__OMP_RTL_ATTRS(__kmpc_distribute_static_init_8, GetterArgWriteAttrs,
812                AttributeSet(),
813                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
814                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs,
815                           AttributeSet(), AttributeSet()))
816__OMP_RTL_ATTRS(__kmpc_distribute_static_init_8u, GetterArgWriteAttrs,
817                AttributeSet(),
818                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
819                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs,
820                           AttributeSet(), AttributeSet()))
821__OMP_RTL_ATTRS(__kmpc_distribute_static_fini, InaccessibleArgOnlyAttrs,
822                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
823__OMP_RTL_ATTRS(__kmpc_dist_dispatch_init_4, GetterArgWriteAttrs,
824                AttributeSet(),
825                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs, SExt,
826                           SExt, SExt, SExt))
827__OMP_RTL_ATTRS(__kmpc_dist_dispatch_init_4u, GetterArgWriteAttrs,
828                AttributeSet(),
829                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs, ZExt,
830                           ZExt, SExt, SExt))
831__OMP_RTL_ATTRS(__kmpc_dist_dispatch_init_8, GetterArgWriteAttrs,
832                AttributeSet(),
833                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs))
834__OMP_RTL_ATTRS(__kmpc_dist_dispatch_init_8u, GetterArgWriteAttrs,
835                AttributeSet(),
836                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs))
837__OMP_RTL_ATTRS(__kmpc_dispatch_init_4, GetterArgWriteAttrs, AttributeSet(),
838                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SExt, SExt, SExt, SExt))
839__OMP_RTL_ATTRS(__kmpc_dispatch_init_4u, GetterArgWriteAttrs, AttributeSet(),
840                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ZExt, ZExt, SExt, SExt))
841__OMP_RTL_ATTRS(__kmpc_dispatch_init_8, GetterArgWriteAttrs, AttributeSet(),
842                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
843__OMP_RTL_ATTRS(__kmpc_dispatch_init_8u, GetterArgWriteAttrs, AttributeSet(),
844                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
845__OMP_RTL_ATTRS(__kmpc_dispatch_next_4, GetterArgWriteAttrs, SExt,
846                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
847                           ArgPtrAttrs, ArgPtrAttrs))
848__OMP_RTL_ATTRS(__kmpc_dispatch_next_4u, GetterArgWriteAttrs, SExt,
849                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
850                           ArgPtrAttrs, ArgPtrAttrs))
851__OMP_RTL_ATTRS(__kmpc_dispatch_next_8, GetterArgWriteAttrs, SExt,
852                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
853                           ArgPtrAttrs, ArgPtrAttrs))
854__OMP_RTL_ATTRS(__kmpc_dispatch_next_8u, GetterArgWriteAttrs, SExt,
855                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
856                           ArgPtrAttrs, ArgPtrAttrs))
857__OMP_RTL_ATTRS(__kmpc_dispatch_fini_4, InaccessibleArgOnlyAttrs,
858                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
859__OMP_RTL_ATTRS(__kmpc_dispatch_fini_4u, InaccessibleArgOnlyAttrs,
860                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
861__OMP_RTL_ATTRS(__kmpc_dispatch_fini_8, InaccessibleArgOnlyAttrs,
862                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
863__OMP_RTL_ATTRS(__kmpc_dispatch_fini_8u, InaccessibleArgOnlyAttrs,
864                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
865__OMP_RTL_ATTRS(__kmpc_team_static_init_4, GetterArgWriteAttrs, AttributeSet(),
866                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
867                           ArgPtrAttrs, ArgPtrAttrs, SExt, SExt))
868__OMP_RTL_ATTRS(__kmpc_team_static_init_4u, GetterArgWriteAttrs, AttributeSet(),
869                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
870                           ArgPtrAttrs, ArgPtrAttrs, SExt, SExt))
871__OMP_RTL_ATTRS(__kmpc_team_static_init_8, GetterArgWriteAttrs, AttributeSet(),
872                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
873                           ArgPtrAttrs, ArgPtrAttrs))
874__OMP_RTL_ATTRS(__kmpc_team_static_init_8u, GetterArgWriteAttrs, AttributeSet(),
875                ParamAttrs(ReadOnlyPtrAttrs, SExt, ArgPtrAttrs, ArgPtrAttrs,
876                           ArgPtrAttrs, ArgPtrAttrs))
877__OMP_RTL_ATTRS(__kmpc_dist_for_static_init_4, GetterArgWriteAttrs,
878                AttributeSet(),
879                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
880                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs,
881                           ArgPtrAttrs, SExt, SExt))
882__OMP_RTL_ATTRS(__kmpc_dist_for_static_init_4u, GetterArgWriteAttrs,
883                AttributeSet(),
884                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
885                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs,
886                           ArgPtrAttrs, SExt, SExt))
887__OMP_RTL_ATTRS(__kmpc_dist_for_static_init_8, GetterArgWriteAttrs,
888                AttributeSet(),
889                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
890                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs))
891__OMP_RTL_ATTRS(__kmpc_dist_for_static_init_8u, GetterArgWriteAttrs,
892                AttributeSet(),
893                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ArgPtrAttrs,
894                           ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs, ArgPtrAttrs))
895
896__OMP_RTL_ATTRS(__kmpc_single, BarrierAttrs, SExt,
897                ParamAttrs(ReadOnlyPtrAttrs, SExt))
898__OMP_RTL_ATTRS(__kmpc_end_single, BarrierAttrs, AttributeSet(),
899                ParamAttrs(ReadOnlyPtrAttrs, SExt))
900
901__OMP_RTL_ATTRS(__kmpc_omp_task_alloc, DefaultAttrs, ReturnPtrAttrs,
902                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SizeTyExt, SizeTyExt,
903                           ReadOnlyPtrAttrs))
904__OMP_RTL_ATTRS(__kmpc_omp_task, DefaultAttrs, SExt,
905                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet()))
906__OMP_RTL_ATTRS(__kmpc_end_taskgroup, BarrierAttrs, AttributeSet(),
907                ParamAttrs(ReadOnlyPtrAttrs, SExt))
908__OMP_RTL_ATTRS(__kmpc_taskgroup, BarrierAttrs, AttributeSet(),
909                ParamAttrs(ReadOnlyPtrAttrs, SExt))
910__OMP_RTL_ATTRS(__kmpc_omp_task_begin_if0, DefaultAttrs, AttributeSet(),
911                ParamAttrs(ReadOnlyPtrAttrs, SExt))
912__OMP_RTL_ATTRS(__kmpc_omp_task_complete_if0, DefaultAttrs, AttributeSet(),
913                ParamAttrs(ReadOnlyPtrAttrs, SExt))
914__OMP_RTL_ATTRS(__kmpc_omp_task_with_deps, DefaultAttrs, SExt,
915                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet(), SExt,
916                           ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs))
917__OMP_RTL_ATTRS(__kmpc_taskloop, DefaultAttrs, AttributeSet(),
918                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet(), SExt,
919                           ArgPtrAttrs, ArgPtrAttrs, AttributeSet(), SExt, SExt))
920__OMP_RTL_ATTRS(__kmpc_omp_target_task_alloc, DefaultAttrs, ReturnPtrAttrs,
921                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SizeTyExt, SizeTyExt,
922                           ReadOnlyPtrAttrs, AttributeSet()))
923__OMP_RTL_ATTRS(__kmpc_taskred_modifier_init, DefaultAttrs, AttributeSet(),
924                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SExt))
925__OMP_RTL_ATTRS(__kmpc_taskred_init, DefaultAttrs, AttributeSet(),
926                ParamAttrs(SExt, SExt))
927__OMP_RTL_ATTRS(__kmpc_task_reduction_modifier_fini, BarrierAttrs,
928                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
929__OMP_RTL_ATTRS(__kmpc_task_reduction_get_th_data, DefaultAttrs, AttributeSet(),
930                ParamAttrs(SExt))
931__OMP_RTL_ATTRS(__kmpc_task_reduction_init, DefaultAttrs, AttributeSet(),
932                ParamAttrs(SExt, SExt))
933__OMP_RTL_ATTRS(__kmpc_task_reduction_modifier_init, DefaultAttrs,
934                AttributeSet(), ParamAttrs(AttributeSet(), SExt, SExt, SExt))
935__OMP_RTL_ATTRS(__kmpc_proxy_task_completed_ooo, DefaultAttrs, AttributeSet(),
936                ParamAttrs())
937
938__OMP_RTL_ATTRS(__kmpc_omp_wait_deps, BarrierAttrs, AttributeSet(),
939                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ReadOnlyPtrAttrs, SExt))
940__OMP_RTL_ATTRS(__kmpc_omp_taskwait_deps_51, BarrierAttrs, AttributeSet(),
941                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, ReadOnlyPtrAttrs))
942__OMP_RTL_ATTRS(__kmpc_cancellationpoint, DefaultAttrs, SExt,
943                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
944
945__OMP_RTL_ATTRS(__kmpc_fork_teams, ForkAttrs, AttributeSet(),
946                ParamAttrs(ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs))
947__OMP_RTL_ATTRS(__kmpc_push_num_teams, InaccessibleArgOnlyAttrs, AttributeSet(),
948                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt, SExt))
949__OMP_RTL_ATTRS(__kmpc_set_thread_limit, InaccessibleArgOnlyAttrs, AttributeSet(),
950                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
951
952__OMP_RTL_ATTRS(__kmpc_copyprivate, DefaultAttrs, AttributeSet(),
953                ParamAttrs(ReadOnlyPtrAttrs, SExt, SizeTyExt,
954                           ReadOnlyPtrAttrs, AttributeSet(), SExt))
955__OMP_RTL_ATTRS(__kmpc_threadprivate_cached, DefaultAttrs, AttributeSet(),
956                ParamAttrs(ReadOnlyPtrAttrs, SExt, AttributeSet(), SizeTyExt))
957__OMP_RTL_ATTRS(__kmpc_threadprivate_register, DefaultAttrs, AttributeSet(),
958                ParamAttrs(ReadOnlyPtrAttrs, AttributeSet(), ReadOnlyPtrAttrs,
959                           ReadOnlyPtrAttrs, ReadOnlyPtrAttrs))
960
961__OMP_RTL_ATTRS(__kmpc_doacross_init, BarrierAttrs, AttributeSet(),
962                ParamAttrs(ReadOnlyPtrAttrs, SExt, SExt))
963__OMP_RTL_ATTRS(__kmpc_doacross_post, BarrierAttrs, AttributeSet(),
964                ParamAttrs(ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs))
965__OMP_RTL_ATTRS(__kmpc_doacross_wait, BarrierAttrs, AttributeSet(),
966                ParamAttrs(ReadOnlyPtrAttrs, SExt, ReadOnlyPtrAttrs))
967__OMP_RTL_ATTRS(__kmpc_doacross_fini, BarrierAttrs, AttributeSet(),
968                ParamAttrs(ReadOnlyPtrAttrs, SExt))
969
970__OMP_RTL_ATTRS(__kmpc_alloc_shared,
971                AttributeSet(EnumAttr(NoUnwind), EnumAttr(NoSync),
972                             AllocSizeAttr(0, std::nullopt)),
973                ReturnPtrAttrs, ParamAttrs(SizeTyExt))
974__OMP_RTL_ATTRS(__kmpc_free_shared, DeviceAllocAttrs, AttributeSet(),
975                ParamAttrs(AttributeSet(EnumAttr(NoCapture),
976                                        EnumAttr(AllocatedPointer)),
977                           SizeTyExt))
978__OMP_RTL_ATTRS(__kmpc_begin_sharing_variables, AttributeSet(), AttributeSet(),
979                ParamAttrs(AttributeSet(), SizeTyExt))
980
981__OMP_RTL_ATTRS(__kmpc_alloc, DefaultAttrs, ReturnPtrAttrs,
982                ParamAttrs(SExt, SizeTyExt))
983__OMP_RTL_ATTRS(__kmpc_aligned_alloc, DefaultAttrs, ReturnPtrAttrs,
984                ParamAttrs(SExt, SizeTyExt, SizeTyExt))
985__OMP_RTL_ATTRS(__kmpc_free, AllocAttrs, AttributeSet(),
986                ParamAttrs(SExt))
987
988__OMP_RTL_ATTRS(__tgt_interop_init, AttributeSet(), AttributeSet(),
989                ParamAttrs(AttributeSet(), SExt, AttributeSet(), SExt,
990                           SExt, AttributeSet(), AttributeSet(), SExt))
991__OMP_RTL_ATTRS(__tgt_interop_destroy, AttributeSet(), AttributeSet(),
992                ParamAttrs(AttributeSet(), SExt, AttributeSet(), SExt, SExt,
993                           AttributeSet(), SExt))
994__OMP_RTL_ATTRS(__tgt_interop_use, AttributeSet(), AttributeSet(),
995                ParamAttrs(AttributeSet(), SExt, AttributeSet(), SExt, SExt,
996                           AttributeSet(), SExt))
997
998__OMP_RTL_ATTRS(__kmpc_init_allocator, DefaultAttrs, AttributeSet(),
999                ParamAttrs(SExt, AttributeSet(), SExt))
1000__OMP_RTL_ATTRS(__kmpc_destroy_allocator, AllocAttrs, AttributeSet(),
1001                ParamAttrs(SExt))
1002
1003__OMP_RTL_ATTRS(__kmpc_push_target_tripcount_mapper, SetterAttrs,
1004                AttributeSet(), ParamAttrs())
1005__OMP_RTL_ATTRS(__tgt_target_mapper, ForkAttrs, SExt,
1006                ParamAttrs(AttributeSet(),AttributeSet(),AttributeSet(), SExt))
1007__OMP_RTL_ATTRS(__tgt_target_nowait_mapper, ForkAttrs, SExt,
1008                ParamAttrs(AttributeSet(), AttributeSet(), AttributeSet(), SExt,
1009                           AttributeSet(), AttributeSet(), AttributeSet(),
1010                           AttributeSet(), AttributeSet(), AttributeSet(),
1011                           SExt, AttributeSet(), SExt))
1012__OMP_RTL_ATTRS(__tgt_target_teams_mapper, ForkAttrs, SExt,
1013                ParamAttrs(AttributeSet(), AttributeSet(), AttributeSet(), SExt,
1014                           AttributeSet(), AttributeSet(), AttributeSet(),
1015                           AttributeSet(), AttributeSet(), AttributeSet(), SExt,
1016                           SExt))
1017__OMP_RTL_ATTRS(__tgt_target_teams_nowait_mapper, ForkAttrs, SExt,
1018                ParamAttrs(AttributeSet(), AttributeSet(), AttributeSet(), SExt,
1019                           AttributeSet(), AttributeSet(), AttributeSet(),
1020                           AttributeSet(), AttributeSet(), AttributeSet(),
1021                           SExt, SExt, SExt, AttributeSet(), SExt))
1022__OMP_RTL_ATTRS(__tgt_target_kernel, ForkAttrs, SExt,
1023                ParamAttrs(AttributeSet(), AttributeSet(), SExt, SExt))
1024__OMP_RTL_ATTRS(__tgt_target_kernel_nowait, ForkAttrs, SExt,
1025                ParamAttrs(AttributeSet(), AttributeSet(), SExt, SExt,
1026                           AttributeSet(), AttributeSet(), SExt, AttributeSet(),
1027                           SExt))
1028__OMP_RTL_ATTRS(__tgt_register_requires, ForkAttrs, AttributeSet(),
1029                ParamAttrs())
1030__OMP_RTL_ATTRS(__tgt_target_data_begin_mapper, ForkAttrs, AttributeSet(),
1031                ParamAttrs(AttributeSet(), AttributeSet(), SExt))
1032__OMP_RTL_ATTRS(__tgt_target_data_begin_nowait_mapper, ForkAttrs, AttributeSet(),
1033                ParamAttrs(AttributeSet(), AttributeSet(), SExt, AttributeSet(),
1034                           AttributeSet(), AttributeSet(), AttributeSet(),
1035                           AttributeSet(), AttributeSet()))
1036__OMP_RTL_ATTRS(__tgt_target_data_begin_mapper_issue, AttributeSet(),
1037                AttributeSet(),
1038                ParamAttrs(AttributeSet(), AttributeSet(), SExt))
1039__OMP_RTL_ATTRS(__tgt_target_data_end_mapper, ForkAttrs, AttributeSet(),
1040                ParamAttrs(AttributeSet(), AttributeSet(), SExt))
1041__OMP_RTL_ATTRS(__tgt_target_data_end_nowait_mapper, ForkAttrs, AttributeSet(),
1042                ParamAttrs(AttributeSet(), AttributeSet(), SExt, AttributeSet(),
1043                           AttributeSet(), AttributeSet(), AttributeSet(),
1044                           AttributeSet(), AttributeSet()))
1045__OMP_RTL_ATTRS(__tgt_target_data_update_mapper, ForkAttrs, AttributeSet(),
1046                ParamAttrs(AttributeSet(), AttributeSet(), SExt))
1047__OMP_RTL_ATTRS(__tgt_target_data_update_nowait_mapper, ForkAttrs, AttributeSet(),
1048                ParamAttrs(AttributeSet(), AttributeSet(), SExt, AttributeSet(),
1049                           AttributeSet(), AttributeSet(), AttributeSet(),
1050                           AttributeSet(), AttributeSet()))
1051__OMP_RTL_ATTRS(__tgt_mapper_num_components, ForkAttrs, AttributeSet(),
1052                ParamAttrs())
1053__OMP_RTL_ATTRS(__tgt_push_mapper_component, ForkAttrs, AttributeSet(),
1054                ParamAttrs())
1055__OMP_RTL_ATTRS(__kmpc_task_allow_completion_event, DefaultAttrs,
1056                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
1057
1058__OMP_RTL_ATTRS(__kmpc_target_init, AttributeSet(), SExt,
1059                ParamAttrs(AttributeSet()))
1060__OMP_RTL_ATTRS(__kmpc_target_deinit, AttributeSet(), AttributeSet(),
1061                ParamAttrs())
1062__OMP_RTL_ATTRS(__kmpc_parallel_51, AlwaysInlineAttrs, AttributeSet(),
1063                ParamAttrs(AttributeSet(), SExt, SExt, SExt, SExt,
1064                           AttributeSet(), AttributeSet(), AttributeSet(),
1065                           SizeTyExt))
1066__OMP_RTL_ATTRS(__kmpc_serialized_parallel, InaccessibleArgOnlyAttrs,
1067                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
1068__OMP_RTL_ATTRS(__kmpc_end_serialized_parallel, InaccessibleArgOnlyAttrs,
1069                AttributeSet(), ParamAttrs(ReadOnlyPtrAttrs, SExt))
1070__OMP_RTL_ATTRS(__kmpc_shuffle_int32, AttributeSet(), SExt,
1071                ParamAttrs(SExt, SExt, SExt))
1072__OMP_RTL_ATTRS(__kmpc_nvptx_parallel_reduce_nowait_v2, AttributeSet(), SExt,
1073                ParamAttrs())
1074__OMP_RTL_ATTRS(__kmpc_nvptx_teams_reduce_nowait_v2, AttributeSet(), SExt,
1075                ParamAttrs(AttributeSet(), AttributeSet(), ZExt))
1076__OMP_RTL_ATTRS(__kmpc_reduction_get_fixed_buffer, GetterAttrs, AttributeSet(), ParamAttrs())
1077
1078__OMP_RTL_ATTRS(__kmpc_shuffle_int64, AttributeSet(), AttributeSet(),
1079                ParamAttrs(AttributeSet(), SExt, SExt))
1080
1081__OMP_RTL_ATTRS(__kmpc_is_spmd_exec_mode, AttributeSet(), SExt, ParamAttrs())
1082
1083#undef __OMP_RTL_ATTRS
1084#undef OMP_RTL_ATTRS
1085#undef AttributeSet
1086#undef EnumAttr
1087#undef EnumAttrInt
1088#undef ParamAttrs
1089#undef AllocSizeAttr
1090
1091///}
1092
1093/// KMP ident_t bit flags
1094///
1095/// In accordance with the values in `openmp/runtime/src/kmp.h`.
1096///
1097///{
1098
1099#ifndef OMP_IDENT_FLAG
1100#define OMP_IDENT_FLAG(Enum, Str, Value)
1101#endif
1102
1103#define __OMP_IDENT_FLAG(Name, Value)                                          \
1104  OMP_IDENT_FLAG(OMP_IDENT_FLAG_##Name, #Name, Value)
1105
1106__OMP_IDENT_FLAG(KMPC, 0x02)
1107__OMP_IDENT_FLAG(ATOMIC_REDUCE, 0x10)
1108__OMP_IDENT_FLAG(BARRIER_EXPL, 0x20)
1109__OMP_IDENT_FLAG(BARRIER_IMPL, 0x0040)
1110__OMP_IDENT_FLAG(BARRIER_IMPL_MASK, 0x01C0)
1111__OMP_IDENT_FLAG(BARRIER_IMPL_FOR, 0x0040)
1112__OMP_IDENT_FLAG(BARRIER_IMPL_SECTIONS, 0x00C0)
1113__OMP_IDENT_FLAG(BARRIER_IMPL_SINGLE, 0x0140)
1114__OMP_IDENT_FLAG(BARRIER_IMPL_WORKSHARE, 0x01C0)
1115
1116#undef __OMP_IDENT_FLAG
1117#undef OMP_IDENT_FLAG
1118
1119///}
1120
1121/// KMP cancel kind
1122///
1123///{
1124
1125#ifndef OMP_CANCEL_KIND
1126#define OMP_CANCEL_KIND(Enum, Str, DirectiveEnum, Value)
1127#endif
1128
1129#define __OMP_CANCEL_KIND(Name, Value)                                         \
1130  OMP_CANCEL_KIND(OMP_CANCEL_KIND_##Name, #Name, OMPD_##Name, Value)
1131
1132__OMP_CANCEL_KIND(parallel, 1)
1133__OMP_CANCEL_KIND(for, 2)
1134__OMP_CANCEL_KIND(sections, 3)
1135__OMP_CANCEL_KIND(taskgroup, 4)
1136
1137#undef __OMP_CANCEL_KIND
1138#undef OMP_CANCEL_KIND
1139
1140///}
1141
1142/// Default kinds
1143///
1144///{
1145
1146#ifndef OMP_DEFAULT_KIND
1147#define OMP_DEFAULT_KIND(Enum, Str)
1148#endif
1149
1150#define __OMP_DEFAULT_KIND(Name) OMP_DEFAULT_KIND(OMP_DEFAULT_##Name, #Name)
1151
1152__OMP_DEFAULT_KIND(none)
1153__OMP_DEFAULT_KIND(shared)
1154__OMP_DEFAULT_KIND(private)
1155__OMP_DEFAULT_KIND(firstprivate)
1156__OMP_DEFAULT_KIND(unknown)
1157
1158#undef __OMP_DEFAULT_KIND
1159#undef OMP_DEFAULT_KIND
1160
1161///}
1162
1163/// Proc bind kinds
1164///
1165///{
1166
1167#ifndef OMP_PROC_BIND_KIND
1168#define OMP_PROC_BIND_KIND(Enum, Str, Value)
1169#endif
1170
1171#define __OMP_PROC_BIND_KIND(Name, Value)                                      \
1172  OMP_PROC_BIND_KIND(OMP_PROC_BIND_##Name, #Name, Value)
1173
1174__OMP_PROC_BIND_KIND(master, 2)
1175__OMP_PROC_BIND_KIND(close, 3)
1176__OMP_PROC_BIND_KIND(spread, 4)
1177__OMP_PROC_BIND_KIND(primary, 5)
1178__OMP_PROC_BIND_KIND(default, 6)
1179__OMP_PROC_BIND_KIND(unknown, 7)
1180
1181#undef __OMP_PROC_BIND_KIND
1182#undef OMP_PROC_BIND_KIND
1183
1184///}
1185
1186/// OpenMP context related definitions:
1187///  - trait set selector
1188///  - trait selector
1189///  - trait property
1190///
1191///{
1192
1193#ifndef OMP_TRAIT_SET
1194#define OMP_TRAIT_SET(Enum, Str)
1195#endif
1196#ifndef OMP_TRAIT_SELECTOR
1197#define OMP_TRAIT_SELECTOR(Enum, TraitSetEnum, Str, RequiresProperty)
1198#endif
1199#ifndef OMP_TRAIT_PROPERTY
1200#define OMP_TRAIT_PROPERTY(Enum, TraitSetEnum, TraitSelectorEnum, Str)
1201#endif
1202#ifndef OMP_LAST_TRAIT_PROPERTY
1203#define OMP_LAST_TRAIT_PROPERTY(Enum)
1204#endif
1205
1206#define __OMP_TRAIT_SET(Name) OMP_TRAIT_SET(Name, #Name)
1207#define __OMP_TRAIT_SELECTOR(TraitSet, Name, RequiresProperty)                 \
1208  OMP_TRAIT_SELECTOR(TraitSet##_##Name, TraitSet, #Name, RequiresProperty)
1209#define __OMP_TRAIT_SELECTOR_AND_PROPERTY(TraitSet, Name)                      \
1210  OMP_TRAIT_SELECTOR(TraitSet##_##Name, TraitSet, #Name, false)                \
1211  OMP_TRAIT_PROPERTY(TraitSet##_##Name##_##Name, TraitSet, TraitSet##_##Name,  \
1212                     #Name)
1213#define __OMP_TRAIT_PROPERTY(TraitSet, TraitSelector, Name)                    \
1214  OMP_TRAIT_PROPERTY(TraitSet##_##TraitSelector##_##Name, TraitSet,            \
1215                     TraitSet##_##TraitSelector, #Name)
1216
1217// "invalid" must go first.
1218OMP_TRAIT_SET(invalid, "invalid")
1219OMP_TRAIT_SELECTOR(invalid, invalid, "invalid", false)
1220OMP_TRAIT_PROPERTY(invalid, invalid, invalid, "invalid")
1221
1222__OMP_TRAIT_SET(construct)
1223__OMP_TRAIT_SELECTOR_AND_PROPERTY(construct, target)
1224__OMP_TRAIT_SELECTOR_AND_PROPERTY(construct, teams)
1225__OMP_TRAIT_SELECTOR_AND_PROPERTY(construct, parallel)
1226__OMP_TRAIT_SELECTOR_AND_PROPERTY(construct, for)
1227__OMP_TRAIT_SELECTOR_AND_PROPERTY(construct, simd)
1228
1229__OMP_TRAIT_SET(device)
1230
1231__OMP_TRAIT_SELECTOR(device, kind, true)
1232
1233__OMP_TRAIT_PROPERTY(device, kind, host)
1234__OMP_TRAIT_PROPERTY(device, kind, nohost)
1235__OMP_TRAIT_PROPERTY(device, kind, cpu)
1236__OMP_TRAIT_PROPERTY(device, kind, gpu)
1237__OMP_TRAIT_PROPERTY(device, kind, fpga)
1238__OMP_TRAIT_PROPERTY(device, kind, any)
1239
1240__OMP_TRAIT_SELECTOR(device, arch, true)
1241
1242__OMP_TRAIT_PROPERTY(device, arch, arm)
1243__OMP_TRAIT_PROPERTY(device, arch, armeb)
1244__OMP_TRAIT_PROPERTY(device, arch, aarch64)
1245__OMP_TRAIT_PROPERTY(device, arch, aarch64_be)
1246__OMP_TRAIT_PROPERTY(device, arch, aarch64_32)
1247__OMP_TRAIT_PROPERTY(device, arch, ppc)
1248__OMP_TRAIT_PROPERTY(device, arch, ppcle)
1249__OMP_TRAIT_PROPERTY(device, arch, ppc64)
1250__OMP_TRAIT_PROPERTY(device, arch, ppc64le)
1251__OMP_TRAIT_PROPERTY(device, arch, x86)
1252__OMP_TRAIT_PROPERTY(device, arch, x86_64)
1253__OMP_TRAIT_PROPERTY(device, arch, amdgcn)
1254__OMP_TRAIT_PROPERTY(device, arch, nvptx)
1255__OMP_TRAIT_PROPERTY(device, arch, nvptx64)
1256
1257__OMP_TRAIT_SET(implementation)
1258
1259__OMP_TRAIT_SELECTOR(implementation, vendor, true)
1260
1261__OMP_TRAIT_PROPERTY(implementation, vendor, amd)
1262__OMP_TRAIT_PROPERTY(implementation, vendor, arm)
1263__OMP_TRAIT_PROPERTY(implementation, vendor, bsc)
1264__OMP_TRAIT_PROPERTY(implementation, vendor, cray)
1265__OMP_TRAIT_PROPERTY(implementation, vendor, fujitsu)
1266__OMP_TRAIT_PROPERTY(implementation, vendor, gnu)
1267__OMP_TRAIT_PROPERTY(implementation, vendor, ibm)
1268__OMP_TRAIT_PROPERTY(implementation, vendor, intel)
1269__OMP_TRAIT_PROPERTY(implementation, vendor, llvm)
1270__OMP_TRAIT_PROPERTY(implementation, vendor, nec)
1271__OMP_TRAIT_PROPERTY(implementation, vendor, nvidia)
1272__OMP_TRAIT_PROPERTY(implementation, vendor, pgi)
1273__OMP_TRAIT_PROPERTY(implementation, vendor, ti)
1274__OMP_TRAIT_PROPERTY(implementation, vendor, unknown)
1275
1276__OMP_TRAIT_SELECTOR(implementation, extension, true)
1277__OMP_TRAIT_PROPERTY(implementation, extension, match_all)
1278__OMP_TRAIT_PROPERTY(implementation, extension, match_any)
1279__OMP_TRAIT_PROPERTY(implementation, extension, match_none)
1280__OMP_TRAIT_PROPERTY(implementation, extension, disable_implicit_base)
1281__OMP_TRAIT_PROPERTY(implementation, extension, allow_templates)
1282__OMP_TRAIT_PROPERTY(implementation, extension, bind_to_declaration)
1283
1284__OMP_TRAIT_SET(user)
1285
1286__OMP_TRAIT_SELECTOR(user, condition, true)
1287
1288__OMP_TRAIT_PROPERTY(user, condition, true)
1289__OMP_TRAIT_PROPERTY(user, condition, false)
1290__OMP_TRAIT_PROPERTY(user, condition, unknown)
1291
1292__OMP_TRAIT_SELECTOR_AND_PROPERTY(construct, dispatch)
1293
1294// Note that we put isa last so that the other conditions are checked first.
1295// This allows us to issue warnings wrt. isa only if we match otherwise.
1296__OMP_TRAIT_SELECTOR(device, isa, true)
1297
1298// We use "__ANY" as a placeholder in the isa property to denote the
1299// conceptual "any", not the literal `any` used in kind. The string we
1300// we use is not important except that it will show up in diagnostics.
1301OMP_TRAIT_PROPERTY(device_isa___ANY, device, device_isa,
1302                   "<any, entirely target dependent>")
1303
1304
1305#undef OMP_TRAIT_SET
1306#undef __OMP_TRAIT_SET
1307///}
1308
1309/// Traits for the requires directive
1310///
1311/// These will (potentially) become trait selectors for the OpenMP context if
1312/// the OMP_REQUIRES_TRAIT macro is not defined.
1313///
1314///{
1315
1316#ifdef OMP_REQUIRES_TRAIT
1317#define __OMP_REQUIRES_TRAIT(Name)                                             \
1318  OMP_REQUIRES_TRAIT(OMP_REQUIRES_TRAIT_##Name, #Name)
1319#else
1320#define __OMP_REQUIRES_TRAIT(Name)                                             \
1321  __OMP_TRAIT_SELECTOR_AND_PROPERTY(implementation, Name)
1322#endif
1323
1324__OMP_REQUIRES_TRAIT(unified_address)
1325__OMP_REQUIRES_TRAIT(unified_shared_memory)
1326__OMP_REQUIRES_TRAIT(reverse_offload)
1327__OMP_REQUIRES_TRAIT(dynamic_allocators)
1328__OMP_REQUIRES_TRAIT(atomic_default_mem_order)
1329
1330OMP_LAST_TRAIT_PROPERTY(
1331    implementation_atomic_default_mem_order_atomic_default_mem_order)
1332
1333#undef __OMP_TRAIT_SELECTOR_AND_PROPERTY
1334#undef OMP_TRAIT_SELECTOR
1335#undef __OMP_TRAIT_SELECTOR
1336#undef OMP_TRAIT_PROPERTY
1337#undef OMP_LAST_TRAIT_PROPERTY
1338#undef __OMP_TRAIT_PROPERTY
1339#undef __OMP_REQUIRES_TRAIT
1340#undef OMP_REQUIRES_TRAIT
1341///}
1342
1343
1344/// Assumption clauses
1345///
1346///{
1347
1348#ifdef OMP_ASSUME_CLAUSE
1349#define __OMP_ASSUME_CLAUSE(Identifier, StartsWith, HasDirectiveList, HasExpression) \
1350OMP_ASSUME_CLAUSE(Identifier, StartsWith, HasDirectiveList, HasExpression)
1351#else
1352#define __OMP_ASSUME_CLAUSE(...)
1353#endif
1354
1355__OMP_ASSUME_CLAUSE(llvm::StringLiteral("ext_"), true, false, false)
1356__OMP_ASSUME_CLAUSE(llvm::StringLiteral("absent"), false, true, false)
1357__OMP_ASSUME_CLAUSE(llvm::StringLiteral("contains"), false, true, false)
1358__OMP_ASSUME_CLAUSE(llvm::StringLiteral("holds"), false, false, true)
1359__OMP_ASSUME_CLAUSE(llvm::StringLiteral("no_openmp"), false, false, false)
1360__OMP_ASSUME_CLAUSE(llvm::StringLiteral("no_openmp_routines"), false, false, false)
1361__OMP_ASSUME_CLAUSE(llvm::StringLiteral("no_parallelism"), false, false, false)
1362
1363#undef __OMP_ASSUME_CLAUSE
1364#undef OMP_ASSUME_CLAUSE
1365///}
1366