[libc-commits] [PATCH] D148293: [LIBC] Fix incorrect handling of `pthread_join(tid, nullptr)`
Noah Goldstein via Phabricator via libc-commits
libc-commits at lists.llvm.org
Thu Apr 20 12:49:35 PDT 2023
goldstein.w.n updated this revision to Diff 515441.
goldstein.w.n added a comment.
Use llvm style
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D148293/new/
https://reviews.llvm.org/D148293
Files:
libc/src/__support/threads/thread.h
libc/test/integration/src/pthread/CMakeLists.txt
libc/test/integration/src/pthread/pthread_join_test.cpp
Index: libc/test/integration/src/pthread/pthread_join_test.cpp
===================================================================
--- /dev/null
+++ libc/test/integration/src/pthread/pthread_join_test.cpp
@@ -0,0 +1,30 @@
+//===-- Tests for pthread_join-- ------------------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+#include "src/pthread/pthread_create.h"
+#include "src/pthread/pthread_join.h"
+
+#include "src/errno/libc_errno.h"
+
+#include "test/IntegrationTest/test.h"
+#include <pthread.h>
+
+static void *simpleFunc(void *) { return nullptr; }
+static void nullJoinTest() {
+ pthread_t Tid;
+ ASSERT_EQ(__llvm_libc::pthread_create(&Tid, nullptr, simpleFunc, nullptr), 0);
+ ASSERT_EQ(libc_errno, 0);
+ ASSERT_EQ(__llvm_libc::pthread_join(Tid, nullptr), 0);
+ ASSERT_EQ(libc_errno, 0);
+}
+
+TEST_MAIN() {
+ libc_errno = 0;
+ nullJoinTest();
+ return 0;
+}
Index: libc/test/integration/src/pthread/CMakeLists.txt
===================================================================
--- libc/test/integration/src/pthread/CMakeLists.txt
+++ libc/test/integration/src/pthread/CMakeLists.txt
@@ -116,3 +116,17 @@
libc.src.pthread.pthread_join
libc.src.__support.CPP.atomic
)
+
+add_integration_test(
+ pthread_join_test
+ SUITE
+ libc-pthread-integration-tests
+ SRCS
+ pthread_join_test.cpp
+ DEPENDS
+ libc.include.pthread
+ libc.include.errno
+ libc.include.stdio
+ libc.src.pthread.pthread_create
+ libc.src.pthread.pthread_join
+)
Index: libc/src/__support/threads/thread.h
===================================================================
--- libc/src/__support/threads/thread.h
+++ libc/src/__support/threads/thread.h
@@ -157,7 +157,8 @@
int status = join(retval);
if (status != 0)
return status;
- *val = retval.stdc_retval;
+ if (val != nullptr)
+ *val = retval.stdc_retval;
return 0;
}
@@ -166,7 +167,8 @@
int status = join(retval);
if (status != 0)
return status;
- *val = retval.posix_retval;
+ if (val != nullptr)
+ *val = retval.posix_retval;
return 0;
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D148293.515441.patch
Type: text/x-patch
Size: 2377 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/libc-commits/attachments/20230420/34e438f0/attachment-0001.bin>
More information about the libc-commits
mailing list