RFR: 8256516: Simplify clearing References

Per Liden pliden at openjdk.java.net
Wed Nov 18 18:03:04 UTC 2020


On Wed, 18 Nov 2020 10:10:33 GMT, Aleksey Shipilev <shade at openjdk.org> wrote:

>> Please review this simplification of jlr.Reference clearing by VM code.
>> 
>> The function java_lang_ref_Reference::set_referent_raw was being used to
>> clear the referent of Reference objects, and only for that purpose.  This
>> change replaces that function with java_lang_ref_Reference::clear_referent,
>> which is much more obvious in intent.  That change is then percolated up
>> through callers in the obvious way.
>> 
>> Testing:
>> mach5 tier1
>
> src/hotspot/share/gc/shenandoah/shenandoahReferenceProcessor.cpp line 319:
> 
>> 317:   } else {
>> 318:     // Clear referent
>> 319:     reference_clear_referent(reference);
> 
> Now I am looking at this code and wonder if we could just inline `reference_clear_referent` and `reference_set_next` both in Shenandoah and ZGC code. Probably something for a followup.

I'd prefer to keep the `reference_*` helper functions as is in ZGC.

-------------

PR: https://git.openjdk.java.net/jdk/pull/1286


More information about the hotspot-dev mailing list