|
|
@ -46,9 +46,16 @@ public:
|
|
|
|
ElementPtr* new_ptr = new ElementPtr();
|
|
|
|
ElementPtr* new_ptr = new ElementPtr();
|
|
|
|
write_ptr->next.store(new_ptr, std::memory_order_release);
|
|
|
|
write_ptr->next.store(new_ptr, std::memory_order_release);
|
|
|
|
write_ptr = new_ptr;
|
|
|
|
write_ptr = new_ptr;
|
|
|
|
cv.notify_one();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
++size;
|
|
|
|
const size_t previous_size{size++};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Acquire the mutex and then immediately release it as a fence.
|
|
|
|
|
|
|
|
// TODO(bunnei): This can be replaced with C++20 waitable atomics when properly supported.
|
|
|
|
|
|
|
|
// See discussion on https://github.com/yuzu-emu/yuzu/pull/3173 for details.
|
|
|
|
|
|
|
|
if (previous_size == 0) {
|
|
|
|
|
|
|
|
std::lock_guard lock{cv_mutex};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
cv.notify_one();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Pop() {
|
|
|
|
void Pop() {
|
|
|
|