mirror of
https://github.com/moonlight-stream/moonlight-common-c.git
synced 2026-06-16 22:00:55 +00:00
Fix possible lost wakeups by acquring event mutex in signal path
This commit is contained in:
@@ -242,10 +242,14 @@ void PltSetEvent(PLT_EVENT* event) {
|
|||||||
#if defined(LC_WINDOWS)
|
#if defined(LC_WINDOWS)
|
||||||
SetEvent(*event);
|
SetEvent(*event);
|
||||||
#elif defined(__vita__)
|
#elif defined(__vita__)
|
||||||
|
sceKernelLockMutex(event->mutex, 1, NULL);
|
||||||
event->signalled = 1;
|
event->signalled = 1;
|
||||||
|
sceKernelUnlockMutex(event->mutex, 1);
|
||||||
sceKernelSignalCondAll(event->cond);
|
sceKernelSignalCondAll(event->cond);
|
||||||
#else
|
#else
|
||||||
|
pthread_mutex_lock(&event->mutex);
|
||||||
event->signalled = 1;
|
event->signalled = 1;
|
||||||
|
pthread_mutex_unlock(&event->mutex);
|
||||||
pthread_cond_broadcast(&event->cond);
|
pthread_cond_broadcast(&event->cond);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user