From e97a364d0754d7f7c61758c4dcd9dded7e7f9154 Mon Sep 17 00:00:00 2001 From: Simon Tatham Date: Thu, 26 Nov 2020 17:57:25 +0000 Subject: [PATCH] sclog: don't try to find libc functions outside libc. On AArch64, there are unexpectedly malloc and free functions in ld.so, so the module-load function finds them there, wraps them, and then misses the real versions in libc. --- test/sclog/sclog.c | 51 ++++++++++++++++++++++++---------------------- 1 file changed, 27 insertions(+), 24 deletions(-) diff --git a/test/sclog/sclog.c b/test/sclog/sclog.c index 96162fec..a964960a 100644 --- a/test/sclog/sclog.c +++ b/test/sclog/sclog.c @@ -546,6 +546,7 @@ static void try_wrap_fn(const module_data_t *module, const char *name, static void load_module( void *drcontext, const module_data_t *module, bool loaded) { + bool libc = !strncmp(dr_module_preferred_name(module), "libc", 4); #define TRY_WRAP(fn, pre, post) do \ { \ @@ -556,31 +557,33 @@ static void load_module( if (loaded) { TRY_WRAP("log_to_file_real", wrap_logsetfile, NULL); TRY_WRAP("dry_run_real", NULL, wrap_dryrun); - TRY_WRAP("malloc", wrap_malloc_pre, wrap_alloc_post); - TRY_WRAP("realloc", wrap_realloc_pre, wrap_alloc_post); - TRY_WRAP("free", wrap_free_pre, unpause_post); - TRY_WRAP("memset", wrap_memset_pre, unpause_post); + if (libc) { + TRY_WRAP("malloc", wrap_malloc_pre, wrap_alloc_post); + TRY_WRAP("realloc", wrap_realloc_pre, wrap_alloc_post); + TRY_WRAP("free", wrap_free_pre, unpause_post); + TRY_WRAP("memset", wrap_memset_pre, unpause_post); - /* - * More strangely named versions of standard C library - * functions, which I've observed in practice to be where the - * calls end up. I think these are probably selected by - * STT_IFUNC in libc.so, so that the normally named version of - * the function is never reached at all. - * - * This list is not expected to be complete. If you re-run - * this test on a different platform and find control flow - * diverging inside some libc function that looks as if it's - * another name for malloc or memset or whatever, then you may - * need to add more aliases here to stop the test failing. - */ - TRY_WRAP("__GI___libc_malloc", wrap_malloc_pre, wrap_alloc_post); - TRY_WRAP("__libc_malloc", wrap_malloc_pre, wrap_alloc_post); - TRY_WRAP("__GI___libc_realloc", wrap_realloc_pre, wrap_alloc_post); - TRY_WRAP("__GI___libc_free", wrap_free_pre, unpause_post); - TRY_WRAP("__memset_sse2_unaligned", wrap_memset_pre, unpause_post); - TRY_WRAP("__memset_sse2", wrap_memset_pre, unpause_post); - TRY_WRAP("cfree", wrap_free_pre, unpause_post); + /* + * More strangely named versions of standard C library + * functions, which I've observed in practice to be where the + * calls end up. I think these are probably selected by + * STT_IFUNC in libc.so, so that the normally named version of + * the function is never reached at all. + * + * This list is not expected to be complete. If you re-run + * this test on a different platform and find control flow + * diverging inside some libc function that looks as if it's + * another name for malloc or memset or whatever, then you may + * need to add more aliases here to stop the test failing. + */ + TRY_WRAP("__GI___libc_malloc", wrap_malloc_pre, wrap_alloc_post); + TRY_WRAP("__libc_malloc", wrap_malloc_pre, wrap_alloc_post); + TRY_WRAP("__GI___libc_realloc", wrap_realloc_pre, wrap_alloc_post); + TRY_WRAP("__GI___libc_free", wrap_free_pre, unpause_post); + TRY_WRAP("__memset_sse2_unaligned", wrap_memset_pre, unpause_post); + TRY_WRAP("__memset_sse2", wrap_memset_pre, unpause_post); + TRY_WRAP("cfree", wrap_free_pre, unpause_post); + } } }