From 0d8e7490d6e8a13a8f0977d9b7771803b9f64ea0 Mon Sep 17 00:00:00 2001 From: Dimitry Andric Date: Thu, 28 Dec 2017 23:58:28 +0000 Subject: Vendor import of compiler-rt trunk r321545: https://llvm.org/svn/llvm-project/compiler-rt/trunk@321545 --- test/msan/pthread_getname_np.cc | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 test/msan/pthread_getname_np.cc (limited to 'test') diff --git a/test/msan/pthread_getname_np.cc b/test/msan/pthread_getname_np.cc new file mode 100644 index 000000000000..ca27d8b6fd6c --- /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 +#include +#include +#include + +#include + +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; +} -- cgit v1.2.3