RFR(S) 8245925 G1 allocates EDEN region after CDS has executed GC

Ioi Lam ioi.lam at oracle.com
Sat May 30 02:29:45 UTC 2020


https://bugs.openjdk.java.net/browse/JDK-8245925
http://cr.openjdk.java.net/~iklam/jdk15/8245925-g1-eden-after-cds-gc.v01/


Summary:

CDS supports archived heap objects only for G1. During -Xshare:dump,
CDS executes a full GC so that G1 will compact the heap regions, leaving
maximum contiguous free space at the top of the heap. Then, the archived
heap regions are allocated from the top of the heap.

Under some circumstances, java.lang.ref.Cleaners will execute
after the GC has completed. The cleaners may allocate or synchronized, which
will cause G1 to allocate an EDEN region at the top of the heap.

The fix is simple -- after CDS has entered a safepoint, if EDEN regions 
exist,
exit the safepoint, run GC, and try again. Eventually all the cleaners will
be executed and no more allocation can happen.

For safety, I limit the retry count to 30 (or about total 9 seconds).

Thanks
- Ioi


<https://bugs.openjdk.java.net/browse/JDK-8245925>



More information about the hotspot-gc-dev mailing list