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