[foreign-memaccess+abi] Integrated: 8264386: LibraryLookup should be more friendly with implicit unloading
Ty Young
youngty1997 at gmail.com
Tue Mar 30 04:00:45 UTC 2021
Is the Addressable interface still necessary after removing Symbol? IIRC
it was added to get a MemoryAddress from Symbol, MemoryAddress,
MemorySegment, and MappedMemorySegment in a unified way, however with
Symbol gone you either have a MemoryAddress already or you can just call
MemorySegment.address(). The MemoryAddress.address() method was already
silly with Addressable as you could redundantly create new MemoryAddress
objects that represent the same thing, but now there doesn't seem to be
any justification for it that I can tell.
On 3/29/21 6:47 PM, Maurizio Cimadamore wrote:
> On Mon, 29 Mar 2021 15:36:13 GMT, Maurizio Cimadamore <mcimadamore at openjdk.org> wrote:
>
>> 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.
> This pull request has now been integrated.
>
> Changeset: d70c1e40
> Author: Maurizio Cimadamore <mcimadamore at openjdk.org>
> URL: https://git.openjdk.java.net/panama-foreign/commit/d70c1e40
> Stats: 126 lines in 11 files changed: 48 ins; 30 del; 48 mod
>
> 8264386: LibraryLookup should be more friendly with implicit unloading
>
> Reviewed-by: psandoz, jvernee
>
> -------------
>
> PR: https://git.openjdk.java.net/panama-foreign/pull/480
More information about the panama-dev
mailing list