[foreign-memaccess+abi] RFR: 8264386: LibraryLookup should be more friendly with implicit unloading
Maurizio Cimadamore
mcimadamore at openjdk.java.net
Mon Mar 29 15:41:56 UTC 2021
Quoting from the PR:
Dereferencing a segment from a LibraryLookup is possible, in the following form:
LibraryLookup libLookup = ...
MemorySegment segment = libLookup.lookup("foo").asSegmentRestricted(....)
The above code has a problem: there is no link between the produced segment and the original library lookup - meaning that, in principle, it's possible for the library to be unloaded when dereference occurs.
After having discussed many alternatives with Jorn, the best way to address this conundrum would be to add an overload of `LibraryLookup::lookup` which takes a lyout and returns a segment.
As part of this change I have also removed the LibraryLookup.Symbol API which seems unnecessary - now you can lookup an address or a segment. Of course, looking up a segment is creating a restricted segment (so it should be treated as unsafe).
I've added a test to make sure that the new API works as expected.
-------------
Commit messages:
- Initial push
Changes: https://git.openjdk.java.net/panama-foreign/pull/480/files
Webrev: https://webrevs.openjdk.java.net/?repo=panama-foreign&pr=480&range=00
Issue: https://bugs.openjdk.java.net/browse/JDK-8264386
Stats: 122 lines in 11 files changed: 44 ins; 30 del; 48 mod
Patch: https://git.openjdk.java.net/panama-foreign/pull/480.diff
Fetch: git fetch https://git.openjdk.java.net/panama-foreign pull/480/head:pull/480
PR: https://git.openjdk.java.net/panama-foreign/pull/480
More information about the panama-dev
mailing list