#include "jemalloc/internal/jemalloc_preamble.h" #include "jemalloc/internal/jemalloc_internal_includes.h" static safety_check_abort_hook_t safety_check_abort; void safety_check_fail_sized_dealloc(bool current_dealloc, const void *ptr, size_t true_size, size_t input_size) { char *src = current_dealloc ? "the current pointer being freed" : "in thread cache, possibly from previous deallocations"; char *suggest_debug_build = config_debug ? "" : " --enable-debug or"; safety_check_fail( ": size mismatch detected (true size %zu " "vs input size %zu), likely caused by application sized " "deallocation bugs (source address: %p, %s). Suggest building with" "%s address sanitizer for debugging. Abort.\n", true_size, input_size, ptr, src, suggest_debug_build); } void safety_check_set_abort(safety_check_abort_hook_t abort_fn) { safety_check_abort = abort_fn; } /* * In addition to malloc_write, also embed hint msg in the abort function name * because there are cases only logging crash stack traces. */ static void safety_check_detected_heap_corruption___run_address_sanitizer_build_to_debug( const char *buf) { if (safety_check_abort == NULL) { malloc_write(buf); abort(); } else { safety_check_abort(buf); } } void safety_check_fail(const char *format, ...) { char buf[MALLOC_PRINTF_BUFSIZE]; va_list ap; va_start(ap, format); malloc_vsnprintf(buf, MALLOC_PRINTF_BUFSIZE, format, ap); va_end(ap); safety_check_detected_heap_corruption___run_address_sanitizer_build_to_debug( buf); }