RFR: 8256011: Shenandoah: Don't resurrect finalizably reachable objects [v9]
Roman Kennke
rkennke at openjdk.java.net
Wed Nov 11 18:13:07 UTC 2020
> In the weak-LRB we currently return referents when it is 'marked', that is when it's either reachable strongly or through a finalizable object. This means a finalizable object can be resurrected by Reference.get(), which is wrong. Only truly strongly reachable objects should be returned by Reference.get() during weak-reference-processing.
>
> I had to reconsider the way we call into runtime-LRBs from generated code for these reasons:
> - We need to distinguish phantom, weak and strong reference strength, and native vs in-heap access. Those are two orthogonal dimensions
> - We can have strong and phantom native referents, and strong and weak in-heap referents
> - Native referents are never compressed
>
> Note that this depends on PR#1140.
>
> Testing:
> - [x] hotspot_gc_shenandoah (x86_64, x64_32, aarch64)
> - [x] tier1 +UseShenandoahGC +ShenandoahVerify
> - [x] tier2 +UseShenandoahGC +ShenandoahVerify
Roman Kennke has updated the pull request with a new target base due to a merge or a rebase. The pull request now contains 20 commits:
- Move resurrection-barrier from JDK-8256020 into right place after merge
- Merge branch 'master' into JDK-8256011
- Fix/invert condition in CmpP optimization
- Fix after merge
- Merge branch 'master' into JDK-8256011
- Merge branch 'master' into JDK-8256011
- Don't make phantom-access narrow (mistake when doing 32bit parts
- Remove superfluous LP64 in aarch64 part
- Fixes/missing parts for x86_64
- Aarch64 parts
- ... and 10 more: https://git.openjdk.java.net/jdk/compare/96e02610...492cea4d
-------------
Changes: https://git.openjdk.java.net/jdk/pull/1109/files
Webrev: https://webrevs.openjdk.java.net/?repo=jdk&pr=1109&range=08
Stats: 337 lines in 16 files changed: 82 ins; 85 del; 170 mod
Patch: https://git.openjdk.java.net/jdk/pull/1109.diff
Fetch: git fetch https://git.openjdk.java.net/jdk pull/1109/head:pull/1109
PR: https://git.openjdk.java.net/jdk/pull/1109
More information about the shenandoah-dev
mailing list