[msan] Intercept pthread_getname_np.
llvm-svn: 321544
This commit is contained in:
parent
d4e71e9ec7
commit
39021fdd02
@ -4551,6 +4551,20 @@ INTERCEPTOR(int, pthread_setname_np, uptr thread, const char *name, void *arg) {
|
|||||||
#define INIT_PTHREAD_SETNAME_NP
|
#define INIT_PTHREAD_SETNAME_NP
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if SANITIZER_INTERCEPT_PTHREAD_GETNAME_NP
|
||||||
|
INTERCEPTOR(int, pthread_getname_np, uptr thread, char *name, SIZE_T len) {
|
||||||
|
void *ctx;
|
||||||
|
COMMON_INTERCEPTOR_ENTER(ctx, pthread_getname_np, thread, name, len);
|
||||||
|
int res = REAL(pthread_getname_np)(thread, name, len);
|
||||||
|
if (!res)
|
||||||
|
COMMON_INTERCEPTOR_WRITE_RANGE(ctx, name, internal_strnlen(name, len) + 1);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
#define INIT_PTHREAD_GETNAME_NP COMMON_INTERCEPT_FUNCTION(pthread_getname_np);
|
||||||
|
#else
|
||||||
|
#define INIT_PTHREAD_GETNAME_NP
|
||||||
|
#endif
|
||||||
|
|
||||||
#if SANITIZER_INTERCEPT_SINCOS
|
#if SANITIZER_INTERCEPT_SINCOS
|
||||||
INTERCEPTOR(void, sincos, double x, double *sin, double *cos) {
|
INTERCEPTOR(void, sincos, double x, double *sin, double *cos) {
|
||||||
void *ctx;
|
void *ctx;
|
||||||
@ -6541,6 +6555,7 @@ static void InitializeCommonInterceptors() {
|
|||||||
INIT_TTYNAME_R;
|
INIT_TTYNAME_R;
|
||||||
INIT_TEMPNAM;
|
INIT_TEMPNAM;
|
||||||
INIT_PTHREAD_SETNAME_NP;
|
INIT_PTHREAD_SETNAME_NP;
|
||||||
|
INIT_PTHREAD_GETNAME_NP;
|
||||||
INIT_SINCOS;
|
INIT_SINCOS;
|
||||||
INIT_REMQUO;
|
INIT_REMQUO;
|
||||||
INIT_LGAMMA;
|
INIT_LGAMMA;
|
||||||
|
@ -343,6 +343,8 @@
|
|||||||
#define SANITIZER_INTERCEPT_PHTREAD_MUTEX SI_POSIX
|
#define SANITIZER_INTERCEPT_PHTREAD_MUTEX SI_POSIX
|
||||||
#define SANITIZER_INTERCEPT_PTHREAD_SETNAME_NP \
|
#define SANITIZER_INTERCEPT_PTHREAD_SETNAME_NP \
|
||||||
(SI_FREEBSD || SI_NETBSD || SI_LINUX_NOT_ANDROID || SI_SOLARIS)
|
(SI_FREEBSD || SI_NETBSD || SI_LINUX_NOT_ANDROID || SI_SOLARIS)
|
||||||
|
#define SANITIZER_INTERCEPT_PTHREAD_GETNAME_NP \
|
||||||
|
(SI_FREEBSD || SI_LINUX_NOT_ANDROID || SI_SOLARIS)
|
||||||
|
|
||||||
#define SANITIZER_INTERCEPT_TLS_GET_ADDR \
|
#define SANITIZER_INTERCEPT_TLS_GET_ADDR \
|
||||||
(SI_FREEBSD || SI_NETBSD || SI_LINUX_NOT_ANDROID || SI_SOLARIS)
|
(SI_FREEBSD || SI_NETBSD || SI_LINUX_NOT_ANDROID || SI_SOLARIS)
|
||||||
|
34
compiler-rt/test/msan/pthread_getname_np.cc
Normal file
34
compiler-rt/test/msan/pthread_getname_np.cc
Normal file
@ -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;
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user