-
Enhancement
-
Resolution: Unresolved
-
P4
-
21
Code root memregions are areas determined in the concurrent start pause that need to be scanned for references into the old gen before they can be evacuated (because evacuation might drop objects and references, evacuation may cause an incomplete snapshot).
Currently this set of memregions includes all areas that were allocated into during concurrent start, both survivor and old gen allocation regions; scanning these areas can block garbage collection (because they need to be scanned before evacuation as mentioned above).
However it is only absolutely necessary to scan regions that are about to be evacuated in the next gc - i.e. survivor regions. The old gen allocation regions root region scan may be deferred (as currently newly allocated old gen regions can not be evacuated, and due to G1 phasing, these regions can not have remembered sets for evacuation).
With the plan to try to evacuate evacuation failed (or in general, retained regions) as soon as possible, there may be many more old gen regions (with remembered sets) that may be evacuated and ought to be scanned before they can be evacuated.
This impacts pause times, so the idea here is to split the root (mem-)regions into two parts: one that still absolutely needs to be scanned (i.e. survivor regions), and one that may be deferred but does not block garbage collection.
(Obviously, not yet scanned regions may not be evacuated, but at this time there is no plan to do that anyway).
Currently this set of memregions includes all areas that were allocated into during concurrent start, both survivor and old gen allocation regions; scanning these areas can block garbage collection (because they need to be scanned before evacuation as mentioned above).
However it is only absolutely necessary to scan regions that are about to be evacuated in the next gc - i.e. survivor regions. The old gen allocation regions root region scan may be deferred (as currently newly allocated old gen regions can not be evacuated, and due to G1 phasing, these regions can not have remembered sets for evacuation).
With the plan to try to evacuate evacuation failed (or in general, retained regions) as soon as possible, there may be many more old gen regions (with remembered sets) that may be evacuated and ought to be scanned before they can be evacuated.
This impacts pause times, so the idea here is to split the root (mem-)regions into two parts: one that still absolutely needs to be scanned (i.e. survivor regions), and one that may be deferred but does not block garbage collection.
(Obviously, not yet scanned regions may not be evacuated, but at this time there is no plan to do that anyway).
- duplicates
-
JDK-8302881 Add method in G1RootProcessor that aborts and waits completion of root region scan
- Closed
- relates to
-
JDK-8140326 G1: Consider putting regions where evacuation failed into next collection set
- Resolved