[foreign-memaccess+abi] RFR: 8291826: Rework MemoryLayout Sealed Hierarchy [v5]
Paul Sandoz
psandoz at openjdk.org
Fri Aug 19 17:24:06 UTC 2022
On Fri, 19 Aug 2022 12:12:19 GMT, Per Minborg <duke at openjdk.org> wrote:
>> This PR is a significant refactor of the `MemoryLayout` sealed hierarchy and whose purpose is described more in detail in https://bugs.openjdk.org/browse/JDK-8291826. In short, the main purpose is to allow pattern matching.
>>
>> The objective of the PR is to fix the issues described above while retaining as much API compatibility as possible with the pre-PR API. No changes were needed in any of the existing tests for example.
>>
>> The old sealed hierarchy prevented pattern matching with totality from being used and implied a number of other problems as illustrated in the picture below:
>>
>> data:image/s3,"s3://crabby-images/39647/39647db9e067d6bbf90ad073b576d70d3879ce4a" alt="graphviz (33)"
>>
>> Red nodes cannot be used in pattern matching. Light red nodes are implementations that are visible in the API. White nodes are interfaces.
>>
>> After this PR has been integrated, an improved sealed hierarchy will exist as depicted here:
>>
>> data:image/s3,"s3://crabby-images/d6b8c/d6b8cc3e1c1e07e761531b9acbaf25a455057798" alt="graphviz (34)"
>>
>> Gray "Impl" nodes are internal and not exported by the `java.base` module. White nodes are interfaces.
>>
>> Below, the "Principal Totalities" for the new API are outlined:
>>
>>
>> var v0 = switch (memoryLayout) {
>> case MemoryLayout ml -> 0;
>> };
>> var v1 = switch (memoryLayout) {
>> case GroupLayout gl -> 0;
>> case PaddingLayout pl -> 0; // leaf
>> case SequenceLayout sl -> 0; // leaf
>> case ValueLayout vl -> 0;
>> };
>> var v2 = switch (memoryLayout) {
>> case PaddingLayout pl -> 0; // leaf
>> case SequenceLayout sl -> 0; // leaf
>> case ValueLayout vl -> 0;
>> case StructLayout sl -> 0; // leaf
>> case UnionLayout ul -> 0; // leaf
>> };
>> var v3 = switch (memoryLayout) {
>> case PaddingLayout pl -> 0; // leaf
>> case SequenceLayout sl -> 0; // leaf
>> case StructLayout sl -> 0; // leaf
>> case UnionLayout ul -> 0; // leaf
>> case OfAddress oa -> 0; // leaf
>> case OfBoolean ob -> 0; // leaf
>> case OfByte ob -> 0; // leaf
>> case OfChar oc -> 0; // leaf
>> case OfDouble od -> 0; // leaf
>> case OfFloat of -> 0; // leaf
>> case OfInt oi -> 0; // leaf
>> case OfLong ol -> 0; // leaf
>> case OfShort os -> 0; // leaf
>> };
>> var v4 = switch (memoryLayout) {
>> case GroupLayout gl -> 0;
>> case PaddingLayout pl -> 0; // leaf
>> case SequenceLayout sl -> 0; // leaf
>> case OfAddress oa -> 0; // leaf
>> case OfBoolean ob -> 0; // leaf
>> case OfByte ob -> 0; // leaf
>> case OfChar oc -> 0; // leaf
>> case OfDouble od -> 0; // leaf
>> case OfFloat of -> 0; // leaf
>> case OfInt oi -> 0; // leaf
>> case OfLong ol -> 0; // leaf
>> case OfShort os -> 0; // leaf
>> };
>>
>>
>>
>> Additional improvements can be made later in a separate PR, including removing/improving some of the internal abstract classes.
>
> Per Minborg has updated the pull request incrementally with one additional commit since the last revision:
>
> Fix problems in static initializers
src/java.base/share/classes/java/lang/foreign/MemorySegment.java line 1159:
> 1157: @ForceInline
> 1158: default byte get(ValueLayout.OfByte layout, long offset) {
> 1159: return (byte) ((ValueLayouts.OfByteImpl) layout).accessHandle().get(this, offset);
That looks better. Let's measure using micros under test/micro/org/openjdk/bench/java/lang/foreign, search for a few that perform get/set via MemorySegment e.g. the LoopOver* benchmarks are a good candidate set.
-------------
PR: https://git.openjdk.org/panama-foreign/pull/710
More information about the panama-dev
mailing list