Util: Add THREAD_EXIT macro

This commit is contained in:
Vicki Pfau 2023-05-09 22:21:55 -07:00
parent b205537558
commit ee2533831d
11 changed files with 11 additions and 4 deletions

View File

@ -12,6 +12,7 @@
#include <malloc.h> #include <malloc.h>
#define THREAD_ENTRY void #define THREAD_ENTRY void
#define THREAD_EXIT(RES) return
typedef ThreadFunc ThreadEntry; typedef ThreadFunc ThreadEntry;
typedef LightLock Mutex; typedef LightLock Mutex;

View File

@ -20,6 +20,7 @@ CXX_GUARD_START
#define THREAD_ENTRY void* #define THREAD_ENTRY void*
typedef THREAD_ENTRY (*ThreadEntry)(void*); typedef THREAD_ENTRY (*ThreadEntry)(void*);
#define THREAD_EXIT(RES) return RES
typedef pthread_t Thread; typedef pthread_t Thread;
typedef pthread_mutex_t Mutex; typedef pthread_mutex_t Mutex;

View File

@ -17,6 +17,7 @@ typedef struct {
} Condition; } Condition;
#define THREAD_ENTRY int #define THREAD_ENTRY int
typedef THREAD_ENTRY (*ThreadEntry)(void*); typedef THREAD_ENTRY (*ThreadEntry)(void*);
#define THREAD_EXIT(RES) return RES
static inline int MutexInit(Mutex* mutex) { static inline int MutexInit(Mutex* mutex) {
Mutex id = sceKernelCreateMutex("mutex", 0, 0, 0); Mutex id = sceKernelCreateMutex("mutex", 0, 0, 0);

View File

@ -11,6 +11,7 @@
#include <switch.h> #include <switch.h>
#define THREAD_ENTRY void #define THREAD_ENTRY void
#define THREAD_EXIT(RES) return
typedef ThreadFunc ThreadEntry; typedef ThreadFunc ThreadEntry;
typedef CondVar Condition; typedef CondVar Condition;

View File

@ -12,6 +12,7 @@
#include <windows.h> #include <windows.h>
#define THREAD_ENTRY DWORD WINAPI #define THREAD_ENTRY DWORD WINAPI
typedef THREAD_ENTRY ThreadEntry(LPVOID); typedef THREAD_ENTRY ThreadEntry(LPVOID);
#define THREAD_EXIT(RES) return RES
typedef HANDLE Thread; typedef HANDLE Thread;
typedef CRITICAL_SECTION Mutex; typedef CRITICAL_SECTION Mutex;

View File

@ -175,7 +175,7 @@ THREAD_ENTRY _rewindThread(void* context) {
rewindContext->ready = false; rewindContext->ready = false;
} }
MutexUnlock(&rewindContext->mutex); MutexUnlock(&rewindContext->mutex);
return 0; THREAD_EXIT(0);
} }
#endif #endif

View File

@ -450,7 +450,7 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) {
} }
logger->filter = NULL; logger->filter = NULL;
return 0; THREAD_EXIT(0);
} }
bool mCoreThreadStart(struct mCoreThread* threadContext) { bool mCoreThreadStart(struct mCoreThread* threadContext) {

View File

@ -794,5 +794,6 @@ THREAD_ENTRY mGUIAutosaveThread(void* context) {
} }
} }
MutexUnlock(&autosave->mutex); MutexUnlock(&autosave->mutex);
THREAD_EXIT(0);
} }
#endif #endif

View File

@ -207,7 +207,7 @@ static THREAD_ENTRY _proxyThread(void* logger) {
} }
} }
MutexUnlock(&proxyRenderer->mutex); MutexUnlock(&proxyRenderer->mutex);
return 0; THREAD_EXIT(0);
} }
#endif #endif

View File

@ -129,7 +129,7 @@ static THREAD_ENTRY _audioThread(void* context) {
sceAudioOutOutput(audioPort, buffer); sceAudioOutOutput(audioPort, buffer);
} }
sceAudioOutReleasePort(audioPort); sceAudioOutReleasePort(audioPort);
return 0; THREAD_EXIT(0);
} }
static void _sampleRotation(struct mRotationSource* source) { static void _sampleRotation(struct mRotationSource* source) {

View File

@ -1365,6 +1365,7 @@ static THREAD_ENTRY CInemaJob(void* context) {
CIflush(&stream.err, stderr); CIflush(&stream.err, stderr);
StringListDeinit(&stream.err.lines); StringListDeinit(&stream.err.lines);
StringListDeinit(&stream.err.partial); StringListDeinit(&stream.err.partial);
THREAD_EXIT(0);
} }
void _log(struct mLogger* log, int category, enum mLogLevel level, const char* format, va_list args) { void _log(struct mLogger* log, int category, enum mLogLevel level, const char* format, va_list args) {