RFR: 8271880: Tighten condition for excluding regions from collecting cards with cross-references [v11]
Stefan Johansson
sjohanss at openjdk.java.net
Mon Sep 20 12:33:56 UTC 2021
On Fri, 17 Sep 2021 14:16:00 GMT, Thomas Schatzl <tschatzl at openjdk.org> wrote:
>> Hi,
>>
>> can I have reviews for this change that by tightening the condition for excluding regions from collecting cards with cross-references allows us to avoid the rescanning of objects that failed evacuation in the fix up self-forwards phase after evacuation failure.
>>
>> I.e. during gc g1 never collects cards/references from the young gen (including eden) for later refinement - which means that we need to rescan all live objects remaining in eden regions for cross-references.
>>
>> The problem or the reason why we did that was that we did not want to add cards to refine from survivor regions (i.e. next gc's young gen) because we just don't need to as we always collect young gen, so references from there need not be recorded in the remembered sets (and actually, if we did, we errorneouosly marked cards in young gen which later card table verification will not like) - but we did not have that information on hand anywhere already quickly accessible.
>>
>> This change solves that problem by actually recording this information in the region attribute table as "NewSurvivor" type region. "NewSurvivor" because I did want to make explicit that these are the survivor regions from the *new* (next) young generation (i.e. just survivor) and not the survivor regions of the previous gc (that were turned eden at the start of this gc) but something like "NewYoung" or so would be fine with me as well (or certainly just "Survivor", but that might be confusing).
>>
>> Another interesting addition is probably the new assert in `G1ParThreadScanState::enqueue_card_if_tracked`
>>
>>
>> assert(!_g1h->heap_region_containing(o)->in_collection_set(), "Should not try to enqueue reference into collection set region");
>>
>> This, at this time, verifies the assumption that g1 is not trying to collect references *to* the collection set, i.e. other objects that failed evacuation - after all we later relabel their regions as old *without* a remembered set; we would do otherwise unnecessarily because the reason is that (currently) cset tracking for these regions is enabled (at least during gc - we only later relabel and drop the remembered sets).
>>
>> This might change later if we want to move evacuation failed regions into survivor (or keep their remembered sets for some reason), but for now we filter attempts to add cards in the dcqs for those this way.
>>
>> Testing: tier1-5, gc/g1 with `JAVA_OPTIONS_=-XX+G1EvacuationFailureALot -XX:+VerifyAfterGC`.
>>
>> Thanks,
>> Thomas
>
> Thomas Schatzl has updated the pull request with a new target base due to a merge or a rebase. The pull request now contains 14 commits:
>
> - Merge branch 'master' into pull/5037-tighten-condition
> - Merge branch 'master' into evac-failure-no-scan-during-remove-self-forwards
> - Fix compilation after merge
> - Merge branch 'master' into evac-failure-no-scan-during-remove-self-forwards
> - Add enqueue callback
> - Merge branch 'master' into evac-failure-no-scan-during-remove-self-forwards
> - ayang comments; note that the mentioned crash is still not fixed.
> - Merge master
> - Merge branch 'master' into evac-failure-no-scan-during-remove-self-forwards
> - More updates to comment
> - ... and 4 more: https://git.openjdk.java.net/jdk/compare/27d747ad...c708d5cb
Sorry for not getting to this one until now, but took a first quick look at this.
Apart from the small comment below, I think we might want to split this into two separate PRs. One to add the new reference processing abstraction with the general use and then do the specific G1 changes as another PR. What do you think about that?
src/hotspot/share/gc/g1/g1ParScanThreadState.inline.hpp line 116:
> 114: if (!dest_attr.is_in_cset()) {
> 115: enqueue_card_if_tracked(dest_attr, p, obj);
> 116: }
If I understand this correctly, the only time `dest_attr.is_in_cset() == true` is when `obj` is in a region that failed evacuation, right? To make this even more obvious could we add an else-statement with an assert that this is the case?
-------------
PR: https://git.openjdk.java.net/jdk/pull/5037
More information about the hotspot-gc-dev
mailing list