From 862f5a8458ddbee82426e53f7a6be3c0bd690860 Mon Sep 17 00:00:00 2001 From: Ivan Maidanski Date: Mon, 7 Aug 2017 11:37:30 +0300 Subject: [PATCH] Fix leak_test crash in print_callers if free() is redirected * dbg_mlc.c [REDIRECT_MALLOC && (GC_LINUX_THREADS || GC_SOLARIS_THREADS || MSWIN32 || NEED_CALLINFO && GC_HAVE_BUILTIN_BACKTRACE)] (GC_debug_free): If the object is not in the GC heap then just return (instead of ABORT). * malloc.c [REDIRECT_MALLOC && NEED_CALLINFO && GC_HAVE_BUILTIN_BACKTRACE] (GC_free): If hhdr is null (i.e. the object is not in the GC heap) then return without the object deallocation; add comment. * os_dep.c [NEED_CALLINFO && GC_HAVE_BUILTIN_BACKTRACE && !GC_BACKTRACE_SYMBOLS_BROKEN] (GC_print_callers): Adjust comment for free(). --- dbg_mlc.c | 8 ++++++++ malloc.c | 5 ++++- os_dep.c | 2 +- 3 files changed, 13 insertions(+), 2 deletions(-) diff --git a/dbg_mlc.c b/dbg_mlc.c index ea02bd51..29760c43 100644 --- a/dbg_mlc.c +++ b/dbg_mlc.c @@ -804,6 +804,14 @@ GC_API void GC_CALL GC_debug_free(void * p) base = GC_base(p); if (base == 0) { +# if defined(REDIRECT_MALLOC) \ + && ((defined(NEED_CALLINFO) && defined(GC_HAVE_BUILTIN_BACKTRACE)) \ + || defined(GC_LINUX_THREADS) || defined(GC_SOLARIS_THREADS) \ + || defined(MSWIN32)) + /* In some cases, we should ignore objects that do not belong */ + /* to the GC heap. See the comment in GC_free. */ + if (!GC_is_heap_ptr(p)) return; +# endif ABORT_ARG1("Invalid pointer passed to free()", ": %p", p); } if ((ptr_t)p - (ptr_t)base != sizeof(oh)) { diff --git a/malloc.c b/malloc.c index 5c378de3..3ba309fa 100644 --- a/malloc.c +++ b/malloc.c @@ -492,8 +492,11 @@ GC_API void GC_CALL GC_free(void * p) h = HBLKPTR(p); hhdr = HDR(h); # if defined(REDIRECT_MALLOC) && \ - (defined(GC_SOLARIS_THREADS) || defined(GC_LINUX_THREADS) \ + ((defined(NEED_CALLINFO) && defined(GC_HAVE_BUILTIN_BACKTRACE)) \ + || defined(GC_SOLARIS_THREADS) || defined(GC_LINUX_THREADS) \ || defined(MSWIN32)) + /* This might be called indirectly by GC_print_callers to free */ + /* the result of backtrace_symbols. */ /* For Solaris, we have to redirect malloc calls during */ /* initialization. For the others, this seems to happen */ /* implicitly. */ diff --git a/os_dep.c b/os_dep.c index 6f59efdb..4cc0e6ab 100644 --- a/os_dep.c +++ b/os_dep.c @@ -4762,7 +4762,7 @@ GC_INNER void GC_print_callers(struct callinfo info[NFRAMES]) GC_err_printf("\t\t%s\n", name); # if defined(GC_HAVE_BUILTIN_BACKTRACE) \ && !defined(GC_BACKTRACE_SYMBOLS_BROKEN) - free(sym_name); /* May call GC_free; that's OK */ + free(sym_name); /* May call GC_[debug_]free; that's OK */ # endif } } -- 2.40.0