Define a suppression for known leaks on pthread_exit call.
Summary: Refer to D32194 for the context. Reviewers: eugenis Subscribers: kubamracek, llvm-commits Differential Revision: https://reviews.llvm.org/D32303 llvm-svn: 300886
This commit is contained in:
parent
17f37ba3b9
commit
bdbb894a52
|
@ -22,13 +22,10 @@ extern "C" const char* __asan_default_options() {
|
||||||
// turn symbolization off to speed up testing, especially when not running
|
// turn symbolization off to speed up testing, especially when not running
|
||||||
// with llvm-symbolizer but with atos.
|
// with llvm-symbolizer but with atos.
|
||||||
return "symbolize=false:abort_on_error=0:log_to_syslog=0";
|
return "symbolize=false:abort_on_error=0:log_to_syslog=0";
|
||||||
#elif SANITIZER_PPC || defined(__thumb__)
|
#elif SANITIZER_SUPPRESS_LEAK_ON_PTHREAD_EXIT
|
||||||
// On PowerPC and ARM Thumb, a couple tests involving pthread_exit fail due to
|
// On PowerPC and ARM Thumb, a couple tests involving pthread_exit fail due to
|
||||||
// leaks detected by LSan. pthread_exit tries to perform unwinding that leads
|
// leaks detected by LSan. Symbolized leak report is required to apply a
|
||||||
// to dlopen'ing libgcc_s.so. dlopen mallocs "libgcc_s.so" string which
|
// suppression for this known problem.
|
||||||
// confuses LSan, it fails to realize that this allocation happens in dynamic
|
|
||||||
// linker and should be ignored. Symbolized leak report is required to define
|
|
||||||
// a suppression for this known problem.
|
|
||||||
return "";
|
return "";
|
||||||
#else
|
#else
|
||||||
// Let's turn symbolization off to speed up testing (more than 3 times speedup
|
// Let's turn symbolization off to speed up testing (more than 3 times speedup
|
||||||
|
|
|
@ -848,7 +848,13 @@ int __lsan_is_turned_off() {
|
||||||
|
|
||||||
SANITIZER_INTERFACE_ATTRIBUTE SANITIZER_WEAK_ATTRIBUTE
|
SANITIZER_INTERFACE_ATTRIBUTE SANITIZER_WEAK_ATTRIBUTE
|
||||||
const char *__lsan_default_suppressions() {
|
const char *__lsan_default_suppressions() {
|
||||||
|
#if SANITIZER_SUPPRESS_LEAK_ON_PTHREAD_EXIT
|
||||||
|
// The actual string allocation happens here (for more details refer to the
|
||||||
|
// SANITIZER_SUPPRESS_LEAK_ON_PTHREAD_EXIT definition).
|
||||||
|
return "leak:*_dl_map_object_deps*";
|
||||||
|
#else
|
||||||
return "";
|
return "";
|
||||||
|
#endif // SANITIZER_SUPPRESS_LEAK_ON_PTHREAD_EXIT
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
} // extern "C"
|
} // extern "C"
|
||||||
|
|
|
@ -259,4 +259,15 @@
|
||||||
# define SANITIZER_GO 0
|
# define SANITIZER_GO 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// On PowerPC and ARM Thumb, calling pthread_exit() causes LSan to detect leaks.
|
||||||
|
// pthread_exit() performs unwinding that leads to dlopen'ing libgcc_s.so.
|
||||||
|
// dlopen mallocs "libgcc_s.so" string which confuses LSan, it fails to realize
|
||||||
|
// that this allocation happens in dynamic linker and should be ignored.
|
||||||
|
#if SANITIZER_PPC || defined(__thumb__)
|
||||||
|
# define SANITIZER_SUPPRESS_LEAK_ON_PTHREAD_EXIT 1
|
||||||
|
#else
|
||||||
|
# define SANITIZER_SUPPRESS_LEAK_ON_PTHREAD_EXIT 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#endif // SANITIZER_PLATFORM_H
|
#endif // SANITIZER_PLATFORM_H
|
||||||
|
|
Loading…
Reference in New Issue