summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorDimitry Andric <dim@FreeBSD.org>2017-12-28 23:58:28 +0000
committerDimitry Andric <dim@FreeBSD.org>2017-12-28 23:58:28 +0000
commit0d8e7490d6e8a13a8f0977d9b7771803b9f64ea0 (patch)
tree21b1390c80adf149dbf0a3cf182485942499dd65 /test
parentce2df4ef53e14dc3b8585123e49729f1cdf4c0af (diff)
Notes
Diffstat (limited to 'test')
-rw-r--r--test/msan/pthread_getname_np.cc34
1 files changed, 34 insertions, 0 deletions
diff --git a/test/msan/pthread_getname_np.cc b/test/msan/pthread_getname_np.cc
new file mode 100644
index 0000000000000..ca27d8b6fd6c0
--- /dev/null
+++ b/test/msan/pthread_getname_np.cc
@@ -0,0 +1,34 @@
+// RUN: %clangxx_msan -std=c++11 -O0 %s -o %t && %run %t
+// UNSUPPORTED: android, netbsd
+
+// Regression test for a deadlock in pthread_getattr_np
+
+#include <assert.h>
+#include <pthread.h>
+#include <string.h>
+#include <sanitizer/msan_interface.h>
+
+#include <stdio.h>
+
+void *ThreadFn(void *) {
+ return nullptr;
+}
+
+int main(void) {
+ pthread_t t;
+ int res = pthread_create(&t, 0, ThreadFn, 0);
+ assert(!res);
+
+ const char *kMyThreadName = "my-thread-name";
+ res = pthread_setname_np(t, kMyThreadName);
+ assert(!res);
+
+ char buf[100];
+ res = pthread_getname_np(t, buf, sizeof(buf));
+ assert(!res);
+ assert(strcmp(buf, kMyThreadName) == 0);
+
+ res = pthread_join(t, 0);
+ assert(!res);
+ return 0;
+}