From afdc4702385dfa66ba20b46b98d81bd224c2d84e Mon Sep 17 00:00:00 2001 From: Amlal El Mahrouss Date: Wed, 18 Mar 2026 13:11:57 +0100 Subject: [FEAT] PThread implementation improvements for v2. Signed-off-by: Amlal El Mahrouss --- src/libPThread/src/Thread.cpp | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) (limited to 'src/libPThread') diff --git a/src/libPThread/src/Thread.cpp b/src/libPThread/src/Thread.cpp index b70cf7d6..c1799d9c 100644 --- a/src/libPThread/src/Thread.cpp +++ b/src/libPThread/src/Thread.cpp @@ -23,8 +23,10 @@ PTHREAD_SAFE SInt32 pthread_exit(SInt32 retval) { PTHREAD_SAFE SInt32 pthread_join(ThreadRef thread, VoidPtr* retval) { SInt32* ret = (SInt32*) retval; - *ret = ThrJoinThread(thread); + if (!ret) return -1; + + *ret = ThrJoinThread(thread); return 0; } @@ -32,6 +34,8 @@ PTHREAD_SAFE SInt32 pthread_create(_Output ThreadRef* thread, VoidPtr at VoidPtr (*start_routine)(VoidPtr), VoidPtr arg) { LIBSYS_UNUSED(attr); + if (!attr || !thread || !arg || !start_routine) return -1; + /// @note passing zero means you'd have to read the argv until you hit a nullptr. ThreadRef thrd = ThrCreateThread("pthread_thread", (ThrProcKind) start_routine, 0, arg, 0); -- cgit v1.2.3