diff options
author | Martin Willi <martin@strongswan.org> | 2007-06-08 07:21:03 +0000 |
---|---|---|
committer | Martin Willi <martin@strongswan.org> | 2007-06-08 07:21:03 +0000 |
commit | 9cc7a29786c048acfdb7c13103847d064b1867e8 (patch) | |
tree | a06fe3c0810168b16f372a8080d1469f1b0eea64 /src | |
parent | b9659a50dca0184d6d4d40a4039d9fde0bf0b137 (diff) | |
download | strongswan-9cc7a29786c048acfdb7c13103847d064b1867e8.tar.bz2 strongswan-9cc7a29786c048acfdb7c13103847d064b1867e8.tar.xz |
disabling leak detective at runtime by setting LEAK_DETECTIVE_DISABLE env var
Diffstat (limited to 'src')
-rw-r--r-- | src/libstrongswan/utils/leak_detective.c | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/src/libstrongswan/utils/leak_detective.c b/src/libstrongswan/utils/leak_detective.c index b8a023270..a28ebba51 100644 --- a/src/libstrongswan/utils/leak_detective.c +++ b/src/libstrongswan/utils/leak_detective.c @@ -410,7 +410,10 @@ void *realloc_hook(void *old, size_t bytes, const void *caller) */ void __attribute__ ((constructor)) leak_detective_init() { - install_hooks(); + if (getenv("LEAK_DETECTIVE_DISABLE") == NULL) + { + install_hooks(); + } } /** @@ -418,8 +421,11 @@ void __attribute__ ((constructor)) leak_detective_init() */ void __attribute__ ((destructor)) leak_detective_cleanup() { - uninstall_hooks(); - report_leaks(); + if (getenv("LEAK_DETECTIVE_DISABLE") == NULL) + { + uninstall_hooks(); + report_leaks(); + } } /** @@ -431,6 +437,11 @@ void leak_detective_status(FILE *stream) size_t bytes = 0; memory_header_t *hdr = &first_header; + if (getenv("LEAK_DETECTIVE_DISABLE")) + { + return; + } + pthread_mutex_lock(&mutex); while ((hdr = hdr->next)) { |