/* * kmp_wait_release.cpp -- Wait/Release implementation */ //===----------------------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #include "kmp_wait_release.h" void __kmp_wait_64(kmp_info_t *this_thr, kmp_flag_64<> *flag, int final_spin USE_ITT_BUILD_ARG(void *itt_sync_obj)) { if (final_spin) __kmp_wait_template, TRUE>( this_thr, flag USE_ITT_BUILD_ARG(itt_sync_obj)); else __kmp_wait_template, FALSE>( this_thr, flag USE_ITT_BUILD_ARG(itt_sync_obj)); } void __kmp_release_64(kmp_flag_64<> *flag) { __kmp_release_template(flag); } #if KMP_HAVE_MWAIT || KMP_HAVE_UMWAIT template void __kmp_mwait_32(int th_gtid, kmp_flag_32 *flag) { __kmp_mwait_template(th_gtid, flag); } template void __kmp_mwait_64(int th_gtid, kmp_flag_64 *flag) { __kmp_mwait_template(th_gtid, flag); } template void __kmp_atomic_mwait_64(int th_gtid, kmp_atomic_flag_64 *flag) { __kmp_mwait_template(th_gtid, flag); } void __kmp_mwait_oncore(int th_gtid, kmp_flag_oncore *flag) { __kmp_mwait_template(th_gtid, flag); } template void __kmp_mwait_32(int, kmp_flag_32 *); template void __kmp_mwait_64(int, kmp_flag_64 *); template void __kmp_mwait_64(int, kmp_flag_64 *); template void __kmp_atomic_mwait_64(int, kmp_atomic_flag_64 *); template void __kmp_atomic_mwait_64(int, kmp_atomic_flag_64 *); #endif