Fix possible lost wakeups by acquring event mutex in signal path

This commit is contained in:
Cameron Gutman 2017-08-20 00:24:51 -07:00
parent e3dadc3c08
commit 454fdccffc

View File

@ -242,10 +242,14 @@ void PltSetEvent(PLT_EVENT* event) {
#if defined(LC_WINDOWS)
SetEvent(*event);
#elif defined(__vita__)
sceKernelLockMutex(event->mutex, 1, NULL);
event->signalled = 1;
sceKernelUnlockMutex(event->mutex, 1);
sceKernelSignalCondAll(event->cond);
#else
pthread_mutex_lock(&event->mutex);
event->signalled = 1;
pthread_mutex_unlock(&event->mutex);
pthread_cond_broadcast(&event->cond);
#endif
}