mirror of
https://github.com/skyline-emu/skyline.git
synced 2025-01-13 17:17:55 +03:00
Fix a race with multiple threads pushing data into circular queue
If the 'end' changes when waiting for data to be consumed our 'waitNext' would be invalid leading to a deadlock.
This commit is contained in:
parent
f55b135243
commit
6ea1483c9a
@ -96,12 +96,15 @@ namespace skyline {
|
||||
|
||||
void Push(const Type &item) {
|
||||
Type *waitNext{};
|
||||
Type *waitEnd{};
|
||||
|
||||
while (true) {
|
||||
if (waitNext) {
|
||||
std::unique_lock consumeLock{consumptionMutex};
|
||||
consumeCondition.wait(consumeLock, [=]() { return waitNext != start; });
|
||||
|
||||
consumeCondition.wait(consumeLock, [=]() { return waitNext != start || waitEnd != end; });
|
||||
waitNext = nullptr;
|
||||
waitEnd = nullptr;
|
||||
}
|
||||
|
||||
std::scoped_lock lock{productionMutex};
|
||||
@ -109,6 +112,7 @@ namespace skyline {
|
||||
next = (next == reinterpret_cast<Type *>(vector.end().base())) ? reinterpret_cast<Type *>(vector.begin().base()) : next;
|
||||
if (next == start) {
|
||||
waitNext = next;
|
||||
waitEnd = end;
|
||||
continue;
|
||||
}
|
||||
*next = item;
|
||||
|
Loading…
x
Reference in New Issue
Block a user