JEP 12: JVM version constraints

David Holmes david.holmes at oracle.com
Mon Mar 5 23:27:24 UTC 2018


Hi Dan,

On 6/03/2018 8:57 AM, Dan Smith wrote:
> JEP 12, in describing the treatment of "preview" class files, requires that:
> 
>> A JVM implementation for Java SE $N must not define a class file that depends on the preview VM features of another platform version
> 
> In other words, where SE 11 class files have major version 55, an SE 12 JVM must reject class files with version 55.65535.
> 
> This is a change in JVM behavior—currently the spec says:
> 
> "A Java Virtual Machine implementation can support a class file format of version v if and only if v lies in some contiguous range Mi.0 ≤ v ≤ Mj.m." (JVMS 4.1)
> 
> Note the word "contiguous".
> 
> Where is this change being tracked? Since it's not, itself, part of a preview feature, it could easily be overlooked.

AFAIK we are still in the process of determining exactly what JEP 12 
implies for the VM and JVMS. Initial work is being tracked by:

https://bugs.openjdk.java.net/browse/JDK-8198908

Not sure this is the right/best list to raise these issues though.

David

> My two cents: we can carve out a really narrow range of prohibited version numbers (55.65535, 56.65535, ...). But I'd rather make a breaking change: enumerate all the actually-used version numbers since 1.0 (something like 45.*, 46.0, 47.0, ..., 55.0), and reject the rest.
> 
> —Dan
> 


More information about the jdk-dev mailing list