RFR: 8080538 hprof does not work well with multiple agents on non-Solaris platforms
Martin Buchholz
martinrb at google.com
Mon May 18 20:57:57 UTC 2015
Pushed to jdk9 dev.
On Mon, May 18, 2015 at 1:13 AM, Staffan Larsen <staffan.larsen at oracle.com>
wrote:
> This looks good, but given that hprof is going away [1] I’m not sure it’s
> worth the time to fix it. Anyway, I’m ok with the fix.
>
> Thanks,
> /Staffan
>
> [1] https://bugs.openjdk.java.net/browse/JDK-8046661
>
>
> On 16 maj 2015, at 01:12, Jeremy Manson <jeremymanson at google.com> wrote:
>
> Looking for a sponsor...
>
> The issue: hprof finds its location by looking for the first library
> containing an Agent_OnLoad symbol. This may not be libhprof.so. There is
> workaround logic for this on Solaris, but not on other platforms.
>
> Note the comment in
> src/jdk.hprof.agent/unix/native/libhprof/hprof_md.c:296:
>
> /* 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;
> }
>
> Instead of looking for Agent_OnLoad as a symbol, I suggest we just look
> for the symbol of the current method.
>
> Patch:
> http://cr.openjdk.java.net/~jmanson/8080538/webrev.00/
> Bug:
> https://bugs.openjdk.java.net/browse/JDK-8080538
>
> Jeremy
>
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.openjdk.java.net/pipermail/serviceability-dev/attachments/20150518/b096764e/attachment.html>
More information about the serviceability-dev
mailing list