From c53669f664c22d45cdd0dcc375f1b18cf7379ad2 Mon Sep 17 00:00:00 2001 From: Jameson Nash Date: Thu, 2 Sep 2021 14:20:59 -0400 Subject: [PATCH] avoid loading duplicate libraries (#42058) We will not use the duplicate, so best to try to avoid loading it. --- cli/loader_lib.c | 17 ++++++++++++++++- src/jl_exported_funcs.inc | 1 + 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/cli/loader_lib.c b/cli/loader_lib.c index 94cec50ae7e6a..d921055f08221 100644 --- a/cli/loader_lib.c +++ b/cli/loader_lib.c @@ -31,12 +31,27 @@ void jl_loader_print_stderr3(const char * msg1, const char * msg2, const char * /* Wrapper around dlopen(), with extra relative pathing thrown in*/ static void * load_library(const char * rel_path, const char * src_dir) { + void * handle = NULL; + + // See if a handle is already open to the basename + const char *basename = rel_path + strlen(rel_path); + while (basename-- > rel_path) + if (*basename == PATHSEPSTRING[0] || *basename == '/') + break; + basename++; +#if defined(_OS_WINDOWS_) + if ((handle = GetModuleHandleW(basename))) + return handle; +#else + if ((handle = dlopen(basename, RTLD_NOLOAD | RTLD_NOW | RTLD_GLOBAL))) + return handle; +#endif + char path[2*PATH_MAX + 1] = {0}; strncat(path, src_dir, sizeof(path) - 1); strncat(path, PATHSEPSTRING, sizeof(path) - 1); strncat(path, rel_path, sizeof(path) - 1); - void * handle = NULL; #if defined(_OS_WINDOWS_) wchar_t wpath[2*PATH_MAX + 1] = {0}; if (!utf8_to_wchar(path, wpath, 2*PATH_MAX)) { diff --git a/src/jl_exported_funcs.inc b/src/jl_exported_funcs.inc index 99e7eb09aaa4c..877c603c7ac3e 100644 --- a/src/jl_exported_funcs.inc +++ b/src/jl_exported_funcs.inc @@ -551,3 +551,4 @@ XX(jl_vprintf) \ XX(jl_wakeup_thread) \ XX(jl_yield) \ +