RFR[S] 8241158 SA TestHeapDumpForInvokeDynamic.java fails when CDS archive is relocated
Chris Plummer
chris.plummer at oracle.com
Tue Apr 14 22:34:45 UTC 2020
[Not a review]
Hi Ioi,
Your ProblemList.txt is out of date. All those Solaris entries for
8193639 are now gone.
thanks,
Chris
On 4/14/20 3:01 PM, Ioi Lam wrote:
> https://bugs.openjdk.java.net/browse/JDK-8241158
> http://cr.openjdk.java.net/~iklam/jdk15/8241158-sa-heap-dump-fails.v01/
>
> This is a bug in the CDS relocation code. When
> -XX:ArchiveRelocationMode=1 is
> specified, the CDS archive is mapped to an address picked by the OS
> (instead of the default address 0x800000000). As a result, we need to
> patch
> the native Klass* pointers inside java.lang.Class instances that are
> stored in the CDS archived heap region.
>
> Before this fix, the patching is done incrementally, when a class is
> resolved.
> However, when SA tries to do a heap dump, it may see a java.lang.Class
> instance
> that is not yet resolved, whose Klass* pointer has not been patched.
> Dereferencing the unpatched pointer causes SA to fail.
>
> (The failure happens on macos only, probably because the invalid
> dereference
> causes different exceptions on other platforms due to specific memory
> layout,
> and SA is able to handle such exceptions and limp on).
>
> The fix is to unconditionally patch all the Klass* pointers during VM
> initialization.
>
> We already patch a lot of stuff at start-up when the CDS archive is
> relocated,
> so doing a little patching more doesn't hurt.
>
> ----
>
> Passed mach5 tiers 1-4. Ran the failed test manually on macos and it
> passed.
>
> Thanks
> - Ioi
More information about the serviceability-dev
mailing list