mirror of
https://github.com/Lime3DS/Lime3DS.git
synced 2024-11-11 04:35:05 +01:00
Merge pull request #5062 from FearlessTobi/port-3173
Port yuzu-emu/yuzu#3173: "common: SPSCQueue: Notify after incrementing queue size."
This commit is contained in:
commit
b53b4bfb17
@ -46,8 +46,15 @@ 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;
|
||||||
++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();
|
cv.notify_one();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user