forked from ShuriZma/suyu
Merge pull request #9966 from bunnei/bounded-polyfill
common: bounded_threadsafe_queue: Use polyfill_thread.
This commit is contained in:
commit
0e7e98e24e
|
@ -9,10 +9,11 @@
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <mutex>
|
#include <mutex>
|
||||||
#include <new>
|
#include <new>
|
||||||
#include <stop_token>
|
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
|
#include "common/polyfill_thread.h"
|
||||||
|
|
||||||
namespace Common {
|
namespace Common {
|
||||||
|
|
||||||
#if defined(__cpp_lib_hardware_interference_size)
|
#if defined(__cpp_lib_hardware_interference_size)
|
||||||
|
@ -78,7 +79,7 @@ public:
|
||||||
auto& slot = slots[idx(tail)];
|
auto& slot = slots[idx(tail)];
|
||||||
if (!slot.turn.test()) {
|
if (!slot.turn.test()) {
|
||||||
std::unique_lock lock{cv_mutex};
|
std::unique_lock lock{cv_mutex};
|
||||||
cv.wait(lock, stop, [&slot] { return slot.turn.test(); });
|
Common::CondvarWait(cv, lock, stop, [&slot] { return slot.turn.test(); });
|
||||||
}
|
}
|
||||||
v = slot.move();
|
v = slot.move();
|
||||||
slot.destroy();
|
slot.destroy();
|
||||||
|
|
Loading…
Reference in New Issue