Track leaks of mutexes and events for debugging

This commit is contained in:
Cameron Gutman 2019-03-17 02:23:32 -07:00
parent 71a69204e9
commit c9745855fd

View File

@ -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);
}