mirror of
https://github.com/moonlight-stream/moonlight-common-c.git
synced 2025-08-18 01:15:46 +00:00
Track leaks of mutexes and events for debugging
This commit is contained in:
parent
71a69204e9
commit
c9745855fd
@ -14,7 +14,9 @@ struct thread_context {
|
||||
#endif
|
||||
};
|
||||
|
||||
static int running_threads = 0;
|
||||
static int activeThreads = 0;
|
||||
static int activeMutexes = 0;
|
||||
static int activeEvents = 0;
|
||||
|
||||
#if defined(LC_WINDOWS)
|
||||
DWORD WINAPI ThreadProc(LPVOID lpParameter) {
|
||||
@ -59,19 +61,23 @@ int PltCreateMutex(PLT_MUTEX* mutex) {
|
||||
if (!*mutex) {
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
#elif defined(__vita__)
|
||||
*mutex = sceKernelCreateMutex("", 0, 0, NULL);
|
||||
if (*mutex < 0) {
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
#else
|
||||
return pthread_mutex_init(mutex, NULL);
|
||||
int err = pthread_mutex_init(mutex, NULL);
|
||||
if (err != 0) {
|
||||
return err;
|
||||
}
|
||||
#endif
|
||||
activeMutexes++;
|
||||
return 0;
|
||||
}
|
||||
|
||||
void PltDeleteMutex(PLT_MUTEX* mutex) {
|
||||
activeMutexes--;
|
||||
#if defined(LC_WINDOWS)
|
||||
CloseHandle(*mutex);
|
||||
#elif defined(__vita__)
|
||||
@ -121,7 +127,7 @@ void PltJoinThread(PLT_THREAD* thread) {
|
||||
}
|
||||
|
||||
void PltCloseThread(PLT_THREAD* thread) {
|
||||
running_threads--;
|
||||
activeThreads--;
|
||||
#if defined(LC_WINDOWS)
|
||||
CloseHandle(thread->handle);
|
||||
#elif defined(__vita__)
|
||||
@ -180,7 +186,7 @@ int PltCreateThread(ThreadEntry entry, void* context, PLT_THREAD* thread) {
|
||||
}
|
||||
#endif
|
||||
|
||||
running_threads++;
|
||||
activeThreads++;
|
||||
|
||||
return 0;
|
||||
}
|
||||
@ -191,8 +197,6 @@ int PltCreateEvent(PLT_EVENT* event) {
|
||||
if (!*event) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
return 0;
|
||||
#elif defined(__vita__)
|
||||
event->mutex = sceKernelCreateMutex("", 0, 0, NULL);
|
||||
if (event->mutex < 0) {
|
||||
@ -204,16 +208,17 @@ int PltCreateEvent(PLT_EVENT* event) {
|
||||
return -1;
|
||||
}
|
||||
event->signalled = 0;
|
||||
return 0;
|
||||
#else
|
||||
pthread_mutex_init(&event->mutex, NULL);
|
||||
pthread_cond_init(&event->cond, NULL);
|
||||
event->signalled = 0;
|
||||
return 0;
|
||||
#endif
|
||||
activeEvents++;
|
||||
return 0;
|
||||
}
|
||||
|
||||
void PltCloseEvent(PLT_EVENT* event) {
|
||||
activeEvents--;
|
||||
#if defined(LC_WINDOWS)
|
||||
CloseHandle(*event);
|
||||
#elif defined(__vita__)
|
||||
@ -319,5 +324,7 @@ void cleanupPlatform(void) {
|
||||
|
||||
enet_deinitialize();
|
||||
|
||||
LC_ASSERT(running_threads == 0);
|
||||
LC_ASSERT(activeThreads == 0);
|
||||
LC_ASSERT(activeMutexes == 0);
|
||||
LC_ASSERT(activeEvents == 0);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user