Skip to content

Commit

Permalink
Issue #1072: add LSAN_DO_LEAK_CHECK macro to suppress _all_ shutdow…
Browse files Browse the repository at this point in the history
…n lsan leaks
  • Loading branch information
jiridanek committed Jan 5, 2024
1 parent 32286a2 commit a9bea85
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 0 deletions.
5 changes: 5 additions & 0 deletions src/dispatch.c
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@
#include "log_private.h"
#include "message_private.h"
#include "policy.h"
#include "qd_asan_interface.h"
#include "router_private.h"

#include "qpid/dispatch/alloc.h"
Expand Down Expand Up @@ -373,6 +374,10 @@ void qd_dispatch_free(qd_dispatch_t *qd)
{
if (!qd) return;

// Run a final lsan leakcheck right here (if lsan is enabled)
// only leaks (i.e. memory made unreachable) before this point will be reported by lsan
LSAN_DO_LEAK_CHECK();

/* Stop HTTP threads immediately */
qd_http_server_free(qd_server_http(qd->server));

Expand Down
24 changes: 24 additions & 0 deletions src/qd_asan_interface.h
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,8 @@ extern "C" {

void __asan_poison_memory_region(void const volatile *addr, size_t size);
void __asan_unpoison_memory_region(void const volatile *addr, size_t size);
void __lsan_do_leak_check(void);
int __lsan_do_recoverable_leak_check(void);

/// Marks a memory region as unaddressable.
///
Expand All @@ -73,6 +75,25 @@ void __asan_unpoison_memory_region(void const volatile *addr, size_t size);
/// \param size Size of memory region.
#define ASAN_UNPOISON_MEMORY_REGION(addr, size) __asan_unpoison_memory_region((addr), (size))

// Check for leaks now. This function behaves identically to the default
// end-of-process leak check. In particular, it will terminate the process if
// leaks are found and the exitcode runtime flag is non-zero.
// Subsequent calls to this function will have no effect and end-of-process
// leak check will not run. Effectively, end-of-process leak check is moved to
// the time of first invocation of this function.
// By calling this function early during process shutdown, you can instruct
// LSan to ignore shutdown-only leaks which happen later on.
#define LSAN_DO_LEAK_CHECK() __lsan_do_leak_check()

// Check for leaks now. Returns zero if no leaks have been found or if leak
// detection is disabled, non-zero otherwise.
// This function may be called repeatedly, e.g. to periodically check a
// long-running process. It prints a leak report if appropriate, but does not
// terminate the process. It does not affect the behavior of
// __lsan_do_leak_check() or the end-of-process leak check, and is not
// affected by them.
#define LSAN_DO_RECOVERABLE_LEAK_CHECK() __lsan_do_recoverable_leak_check()

#ifdef __cplusplus
} // extern "C"
#endif
Expand All @@ -84,6 +105,9 @@ void __asan_unpoison_memory_region(void const volatile *addr, size_t size);
#define ASAN_UNPOISON_MEMORY_REGION(addr, size) \
((void)(addr), (void)(size))

#define LSAN_DO_LEAK_CHECK() /**/
#define LSAN_DO_RECOVERABLE_LEAK_CHECK() 0

#endif // QD_HAS_ADDRESS_SANITIZER

// https://github.com/google/sanitizers/wiki/AddressSanitizer#turning-off-instrumentation
Expand Down

0 comments on commit a9bea85

Please sign in to comment.