Updated SoV documents
Frederic Parain
frederic.parain at oracle.com
Fri Apr 3 17:12:18 UTC 2020
I haven’t mentioned bytecodes that are using CONSTANT_Class_info indirectly,
all the get/put and invoke bytecodes which are using CONSTANT_Class_info
through CONSTANT_Methodref_info and CONSTANT_Fieldref_info. Anyway, they
don’t need ReferenceType either.
Fred
> On Apr 3, 2020, at 13:08, Frederic Parain <frederic.parain at oracle.com> wrote:
>
> Hi,
>
> This is a good question.
>
> The ReferenceType descriptor was added to make the distinction between the two VM-level
> type sharing the same class name. The CONSTANT_Class_info is used by the following bytecodes:
> - ldc
> - new
> - defaultvalue
> - anewarray
> - multianewarray
> - checkcast
> - instanceof
>
> I’m not seeing any case now where a ReferenceType would be needed. All these bytecodes can
> work properly with the old fashioned CONSTANT_Class_info. For bytecodes like new, defaultvalue,
> anewarray, multianewarray, the class is loaded, so verifications are performed at runtime
> (for instance, new can throw an InstantiationError if the loaded type is an inline type),
> and layout information are available to allocate structures likes arrays.
>
> The Q-signature is used as a marker for inline types (null-free/immutable/identity-free),
> but also as a pre-loading and eager-loading signal. The places where it is used as such a
> signal are the descriptors in field_info and method_info, which point directly to an
> Utf8 entry.
>
> CONSTANT_Class_info is also used for the this_class and super_class fields at the classfile
> top-level structure. In both cases, there’s no need to have a ReferenceType: no distinction
> is needed, and these types are loaded anyway, so verification is performed on loaded types.
>
> Unless I’ve missed something, I would say that we are clear to return CONSTANT_Class_info
> to its pre-LW2 format, supporting only "binary class or interface name”.
>
> Fred
>
>
>> On Apr 2, 2020, at 12:26, Brian Goetz <brian.goetz at oracle.com> wrote:
>>
>> Hi Tobi;
>>
>> I don't have an answer for you offhand, but the current "eclair" model eliminates one of the reasons we needed the new syntax for C_Class -- that a class name could refer to two VM-level types. This is no longer the case; each VM type corresponds to exactly one classfile.
>>
>> The reason I can't give you an unqualified yes at this point is that I am not sure whether we still need to include a "Q" somewhere as a preload signal. When Q descriptors appear in certain places (e.g., field declarations), they generate load order constraints, and in other places, they generate nullity assumptions.
>>
>> I will leave it to Frederic to answer whether we have run out of reasons to need anything other than binary class names in C_Class structures. (It would be nice if we have!)
>>
>> On 4/1/2020 10:19 AM, Tobi Ajila wrote:
>>> Hi Brian
>>>
>>> Thanks for the updated SoV docs. In section 4, it mentions:
>>>
>>>> In most cases, such as field descriptors and method descriptors, uses of C.ref is translated as LC$ref;, uses of C.val is translated as QC$val;,
>>>
>>> In the LW2 spec the `name_index` in `CONSTANT_Class_info` structures could refer to "binary class or interface name" as well as "ReferenceType descriptors" which referenced UTF8s with 'Q' descriptors. In LW2 inline-types were both nullable and null-free so it was necessary to have ReferenceType descriptors in order make a distinction in CONSTANT_Class_info structures for things like allocating arrays. With the new model inline-types can only be null-free, so will the CONSTANT_Class_info structures be limited to binary class or interface names? or will ReferenceType descriptors be used for inline-types?
>>>
>>> --Tobi
>>>
>>> "valhalla-spec-experts" <valhalla-spec-experts-bounces at openjdk.java.net> wrote on 2020/03/27 03:59:38 PM:
>>>
>>>> From: Brian Goetz <brian.goetz at oracle.com>
>>>> To: valhalla-spec-experts <valhalla-spec-experts at openjdk.java.net>
>>>> Date: 2020/03/27 03:59 PM
>>>> Subject: [EXTERNAL] Updated SoV documents
>>>> Sent by: "valhalla-spec-experts" <valhalla-spec-experts-
>>>> bounces at openjdk.java.net>
>>>>
>>>> I've updated the SoV documents, including the new sections on VM
>>>> model and translation:
>>>>
>>>> http://cr.openjdk.java.net/~briangoetz/valhalla/sov/01-background.html
>>>>
>>>
>>>
>>
>
More information about the valhalla-spec-observers
mailing list