mirror of
https://github.com/mutouyun/cpp-ipc.git
synced 2025-12-07 01:06:45 +08:00
adjust ipc::sleep
This commit is contained in:
parent
0dfbfd3fbf
commit
7813e20a5b
@ -134,7 +134,7 @@ struct prod_cons<relat::multi, relat::multi, trans::unicast>
|
|||||||
if (ct_.compare_exchange_weak(cur_ct, nxt_ct, std::memory_order_relaxed)) {
|
if (ct_.compare_exchange_weak(cur_ct, nxt_ct, std::memory_order_relaxed)) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
ipc::sleep<8192>(k);
|
ipc::sleep(k);
|
||||||
}
|
}
|
||||||
std::forward<F>(f)(elem_start + detail::index_of(cur_ct));
|
std::forward<F>(f)(elem_start + detail::index_of(cur_ct));
|
||||||
for (unsigned k = 0;;) {
|
for (unsigned k = 0;;) {
|
||||||
@ -142,7 +142,7 @@ struct prod_cons<relat::multi, relat::multi, trans::unicast>
|
|||||||
if (wt_.compare_exchange_weak(exp_wt, nxt_ct, std::memory_order_release)) {
|
if (wt_.compare_exchange_weak(exp_wt, nxt_ct, std::memory_order_release)) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
ipc::sleep<8192>(k);
|
ipc::sleep(k);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -177,7 +177,7 @@ struct prod_cons<relat::single, relat::multi, trans::broadcast> {
|
|||||||
expected, static_cast<rc_t>(conn_cnt), std::memory_order_relaxed)) {
|
expected, static_cast<rc_t>(conn_cnt), std::memory_order_relaxed)) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
ipc::sleep<8192>(k);
|
ipc::sleep(k);
|
||||||
conn_cnt = elems->conn_count(); // acquire
|
conn_cnt = elems->conn_count(); // acquire
|
||||||
if (conn_cnt == 0) return false;
|
if (conn_cnt == 0) return false;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -57,7 +57,7 @@
|
|||||||
|
|
||||||
namespace ipc {
|
namespace ipc {
|
||||||
|
|
||||||
template <std::size_t N = 4096, typename K>
|
template <std::size_t N = 8192, typename K>
|
||||||
inline void sleep(K& k) noexcept {
|
inline void sleep(K& k) noexcept {
|
||||||
if (k < static_cast<K>(N)) {
|
if (k < static_cast<K>(N)) {
|
||||||
std::this_thread::yield();
|
std::this_thread::yield();
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user