RFR: 8299089: Instrument global jni handles with tag to make them distinguishable
Axel Boldt-Christmas
aboldtch at openjdk.org
Tue Dec 20 11:53:27 UTC 2022
Weak global jni handles are tagged so the GC can distinguish them when resolving the object. Today there is no cheap way of distinguishing global jni handles from local jni handles. For generational ZGC the OopStorage handles and the thread local handles semantical difference requires the handles to be distinguishable.
This enhancements instruments the jni handles with a global tag similarly to the jweak tag.
Note:
* the s390 implementation has minimal changes and requires improvement.
* There is room for enchantment here to create the same abstraction that ppc uses for all platforms, i.e. move the resolve_jobject from the MacroAssembler to the BarrierSetAssembler which allows for more optimised code for GCs that can treat local and global handles the same.
Testing: GHA. Oracle supported platforms tier1-3. Will run higher tiers. Has also been tested on the generational branch of ZGC for over three months. Requires testing on non Oracle platforms.
-------------
Commit messages:
- UPSTREAM: JNI Global Handle Non Oracle Platforms
- UPSTREAM: JNI Global Handle Change
Changes: https://git.openjdk.org/jdk/pull/11740/files
Webrev: https://webrevs.openjdk.org/?repo=jdk&pr=11740&range=00
Issue: https://bugs.openjdk.org/browse/JDK-8299089
Stats: 453 lines in 35 files changed: 300 ins; 57 del; 96 mod
Patch: https://git.openjdk.org/jdk/pull/11740.diff
Fetch: git fetch https://git.openjdk.org/jdk pull/11740/head:pull/11740
PR: https://git.openjdk.org/jdk/pull/11740
More information about the hotspot-dev
mailing list