From 13c92b58f07aa89426aa2f9915f2e27bf28bcf0c Mon Sep 17 00:00:00 2001 From: Jeremy Manson Date: Mon, 18 May 2015 13:34:56 -0700 Subject: [PATCH] 8080538: hprof does not work well with multiple agents on non-Solaris platforms Never take the address of Agent_OnLoad. Reviewed-by: sla, martin --- .../unix/native/libhprof/hprof_md.c | 14 +------------- 1 file changed, 1 insertion(+), 13 deletions(-) diff --git a/jdk/src/jdk.hprof.agent/unix/native/libhprof/hprof_md.c b/jdk/src/jdk.hprof.agent/unix/native/libhprof/hprof_md.c index 78a4f606735..9b3063562d5 100644 --- a/jdk/src/jdk.hprof.agent/unix/native/libhprof/hprof_md.c +++ b/jdk/src/jdk.hprof.agent/unix/native/libhprof/hprof_md.c @@ -290,19 +290,7 @@ md_get_prelude_path(char *path, int path_len, char *filename) Dl_info dlinfo; libdir[0] = 0; -#if defined(LINUX) || defined(_ALLBSD_SOURCE) || defined(AIX) - addr = (void*)&Agent_OnLoad; -#else - /* Just using &Agent_OnLoad will get the first external symbol with - * this name in the first .so, which may not be libhprof.so. - * On Solaris we can actually ask for the address of our Agent_OnLoad. - */ - addr = dlsym(RTLD_SELF, "Agent_OnLoad"); - /* Just in case the above didn't work (missing linker patch?). */ - if ( addr == NULL ) { - addr = (void*)&Agent_OnLoad; - } -#endif + addr = (void*)&md_get_prelude_path; /* Use dladdr() to get the full path to libhprof.so, which we use to find * the prelude file.