1*0b57cec5SDimitry Andric /*
2*0b57cec5SDimitry Andric * kmp_wait_release.cpp -- Wait/Release implementation
3*0b57cec5SDimitry Andric */
4*0b57cec5SDimitry Andric
5*0b57cec5SDimitry Andric //===----------------------------------------------------------------------===//
6*0b57cec5SDimitry Andric //
7*0b57cec5SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
8*0b57cec5SDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
9*0b57cec5SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
10*0b57cec5SDimitry Andric //
11*0b57cec5SDimitry Andric //===----------------------------------------------------------------------===//
12*0b57cec5SDimitry Andric
13*0b57cec5SDimitry Andric #include "kmp_wait_release.h"
14*0b57cec5SDimitry Andric
__kmp_wait_64(kmp_info_t * this_thr,kmp_flag_64<> * flag,int final_spin USE_ITT_BUILD_ARG (void * itt_sync_obj))15*0b57cec5SDimitry Andric void __kmp_wait_64(kmp_info_t *this_thr, kmp_flag_64<> *flag,
16*0b57cec5SDimitry Andric int final_spin USE_ITT_BUILD_ARG(void *itt_sync_obj)) {
17*0b57cec5SDimitry Andric if (final_spin)
18*0b57cec5SDimitry Andric __kmp_wait_template<kmp_flag_64<>, TRUE>(
19*0b57cec5SDimitry Andric this_thr, flag USE_ITT_BUILD_ARG(itt_sync_obj));
20*0b57cec5SDimitry Andric else
21*0b57cec5SDimitry Andric __kmp_wait_template<kmp_flag_64<>, FALSE>(
22*0b57cec5SDimitry Andric this_thr, flag USE_ITT_BUILD_ARG(itt_sync_obj));
23*0b57cec5SDimitry Andric }
24*0b57cec5SDimitry Andric
__kmp_release_64(kmp_flag_64<> * flag)25*0b57cec5SDimitry Andric void __kmp_release_64(kmp_flag_64<> *flag) { __kmp_release_template(flag); }
26
27 #if KMP_HAVE_MWAIT || KMP_HAVE_UMWAIT
28 template <bool C, bool S>
__kmp_mwait_32(int th_gtid,kmp_flag_32<C,S> * flag)29 void __kmp_mwait_32(int th_gtid, kmp_flag_32<C, S> *flag) {
30 __kmp_mwait_template(th_gtid, flag);
31 }
32 template <bool C, bool S>
__kmp_mwait_64(int th_gtid,kmp_flag_64<C,S> * flag)33 void __kmp_mwait_64(int th_gtid, kmp_flag_64<C, S> *flag) {
34 __kmp_mwait_template(th_gtid, flag);
35 }
36 template <bool C, bool S>
__kmp_atomic_mwait_64(int th_gtid,kmp_atomic_flag_64<C,S> * flag)37 void __kmp_atomic_mwait_64(int th_gtid, kmp_atomic_flag_64<C, S> *flag) {
38 __kmp_mwait_template(th_gtid, flag);
39 }
__kmp_mwait_oncore(int th_gtid,kmp_flag_oncore * flag)40 void __kmp_mwait_oncore(int th_gtid, kmp_flag_oncore *flag) {
41 __kmp_mwait_template(th_gtid, flag);
42 }
43
44 template void __kmp_mwait_32<false, false>(int, kmp_flag_32<false, false> *);
45 template void __kmp_mwait_64<false, true>(int, kmp_flag_64<false, true> *);
46 template void __kmp_mwait_64<true, false>(int, kmp_flag_64<true, false> *);
47 template void
48 __kmp_atomic_mwait_64<false, true>(int, kmp_atomic_flag_64<false, true> *);
49 template void
50 __kmp_atomic_mwait_64<true, false>(int, kmp_atomic_flag_64<true, false> *);
51 #endif
52