Bug in DescriptorParser when names contain digits

Maurizio Cimadamore maurizio.cimadamore at oracle.com
Thu Dec 5 11:22:02 UTC 2019


Hi Sebastian,
thanks for the great bug report - it is indeed an issue in the parser. 
I've filed this:

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

The problem seems to be related to a bogus call to scanner::lastNumber() 
instead of scanner::lastString() - which then causes "00" to be 
interpreted as just "0".

Maurizio

On 05/12/2019 10:21, Sebastian Stenzel wrote:
> Hi,
>
> This is my first post to the mailing list, I hope this is the correct place to ask whether this is a bug or not. I noticed that the annotation parsing might not work as intended when names contain zero-padded numbers:
>
> I have a .h file (from osxfuse) that defines a struct with the following function pointers:
> 	int (*reserved00)(void *, void *, void *, void *, void *, void *, void *, void *);
> 	int (*reserved01)(void *, void *, void *, void *, void *, void *, void *, void *);
> 	int (*reserved02)(void *, void *, void *, void *, void *, void *, void *, void *);
>
> jextract correctly creates annotations from this, e.g.:
> 	u64(reserved00):(u64:vu64:vu64:vu64:vu64:vu64:vu64:vu64:v)i32
>
> However, at runtime the name of the Descriptors are incorrectly parsed: reserved0, reserved1 and reserved2.
>
> It appears to me that this is caused by the special handling of numeric tokens in DescriptorParser.parseAnnotationValue(), which should not happen for the "name" annotation.
>
> At a later point in time it is then not possible to find those fields by name, because the generated Layout does not contain the requested field "reserved00" leading to an exception:
>
> Exception in thread "main" java.lang.IllegalStateException: java.lang.RuntimeException: Failed to generate implementation for class interface com.example.fuse.fuse_h$fuse_operations
> 	at java.base/java.foreign.memory.Pointer.lambda$get$3(Pointer.java:170)
> 	at java.base/java.security.AccessController.doPrivileged(AccessController.java:312)
> 	at java.base/java.foreign.memory.Pointer.get(Pointer.java:166)
> 	at java.base/jdk.internal.foreign.ScopeImpl.allocateStruct(ScopeImpl.java:160)
> 	at com.example.fusepanama.Main.main(Main.java:28)
> Caused by: java.lang.RuntimeException: Failed to generate implementation for class interface com.example.fuse.fuse_h$fuse_operations
> 	at java.base/jdk.internal.foreign.LibrariesHelper.generateImpl(LibrariesHelper.java:67)
> 	at java.base/jdk.internal.foreign.LibrariesHelper$1.computeValue(LibrariesHelper.java:76)
> 	at java.base/jdk.internal.foreign.LibrariesHelper$1.computeValue(LibrariesHelper.java:72)
> 	at java.base/java.lang.ClassValue.getFromHashMap(ClassValue.java:226)
> 	at java.base/java.lang.ClassValue.getFromBackup(ClassValue.java:208)
> 	at java.base/java.lang.ClassValue.get(ClassValue.java:114)
> 	at java.base/jdk.internal.foreign.LibrariesHelper.getStructImplClass(LibrariesHelper.java:92)
> 	at java.base/jdk.internal.foreign.memory.References$OfStruct.makeSpecializedGetter(References.java:542)
> 	at java.base/jdk.internal.foreign.memory.References$OfStruct.getter(References.java:527)
> 	at java.base/jdk.internal.foreign.memory.LayoutTypeImpl.getter(LayoutTypeImpl.java:87)
> 	at java.base/java.foreign.memory.Pointer.lambda$get$3(Pointer.java:168)
> 	... 4 more
> Caused by: java.lang.RuntimeException: Failed to generate method public abstract java.foreign.memory.Callback com.example.fuse.fuse_h$fuse_operations.reserved00$get()
> 	at java.base/jdk.internal.foreign.BinderClassGenerator.generateMembers(BinderClassGenerator.java:159)
> 	at java.base/jdk.internal.foreign.StructImplGenerator.generateMembers(StructImplGenerator.java:59)
> 	at java.base/jdk.internal.foreign.BinderClassGenerator.generate(BinderClassGenerator.java:110)
> 	at java.base/jdk.internal.foreign.LibrariesHelper.lambda$generateImpl$0(LibrariesHelper.java:64)
> 	at java.base/java.security.AccessController.doPrivileged(AccessController.java:312)
> 	at java.base/jdk.internal.foreign.LibrariesHelper.generateImpl(LibrariesHelper.java:63)
> 	... 14 more
> Caused by: java.lang.NullPointerException
> 	at java.base/jdk.internal.foreign.StructImplGenerator.generateFieldAccessor(StructImplGenerator.java:113)
> 	at java.base/jdk.internal.foreign.StructImplGenerator.generateMethodImplementation(StructImplGenerator.java:105)
> 	at java.base/jdk.internal.foreign.BinderClassGenerator.generateMembers(BinderClassGenerator.java:156)
> 	... 19 more
>
> Cheers!
> Sebastian


More information about the panama-dev mailing list