diff --git a/compiler-rt/lib/sanitizer_common/sanitizer_mac.cpp b/compiler-rt/lib/sanitizer_common/sanitizer_mac.cpp --- a/compiler-rt/lib/sanitizer_common/sanitizer_mac.cpp +++ b/compiler-rt/lib/sanitizer_common/sanitizer_mac.cpp @@ -1050,13 +1050,13 @@ RAW_CHECK("execv failed" && 0); } - // Verify that interceptors really work. We'll use dlsym to locate - // "pthread_create", if interceptors are working, it should really point to - // "wrap_pthread_create" within our own dylib. - Dl_info info_pthread_create; - void *dlopen_addr = dlsym(RTLD_DEFAULT, "pthread_create"); - RAW_CHECK(dladdr(dlopen_addr, &info_pthread_create)); - if (internal_strcmp(info.dli_fname, info_pthread_create.dli_fname) != 0) { + // Verify that interceptors really work. We'll use the real dlsym to locate + // itself. If interceptors are working, it should really point to + // "wrap_dlsym" within our own dylib. + Dl_info info_dlsym; + void *dlopen_addr = dlsym(RTLD_DEFAULT, "dlsym"); + RAW_CHECK(dladdr(dlopen_addr, &info_dlsym)); + if (internal_strcmp(info.dli_fname, info_dlsym.dli_fname) != 0) { Report( "ERROR: Interceptors are not working. This may be because %s is " "loaded too late (e.g. via dlopen). Please launch the executable "