From 7d00a24f3de779225c763dc55e9dca4d686fe5e5 Mon Sep 17 00:00:00 2001 From: Sam Gammon Date: Thu, 13 Jun 2024 00:38:50 -0700 Subject: [PATCH] feat: jna over static jni - chore: switch to jna snapshot - chore: add new jna graalvm artifact - chore: opt-in to static jna feature - chore: cleanup superfluous configs Adopts java-native-access/jna#1608 Signed-off-by: Sam Gammon --- gradle/elide.versions.toml | 3 +- .../META-INF/native-image/jni-config.json | 60 +------ .../META-INF/native-image/proxy-config.json | 17 +- .../META-INF/native-image/reflect-config.json | 54 +----- .../dev.elide/graalvm/proxy-config.json | 4 +- packages/runtime/build.gradle.kts | 5 + .../META-INF/native-image/jni-config.json | 156 ------------------ .../META-INF/native-image/proxy-config.json | 33 +--- .../META-INF/native-image/reflect-config.json | 71 -------- settings.gradle.kts | 1 + 10 files changed, 13 insertions(+), 391 deletions(-) diff --git a/gradle/elide.versions.toml b/gradle/elide.versions.toml index f3ce770b0c..cf81f0b03d 100644 --- a/gradle/elide.versions.toml +++ b/gradle/elide.versions.toml @@ -110,7 +110,7 @@ jimfs = "1.3.0" jline = "3.26.1" jmh-lib = "1.37" jmh-plugin = "0.7.2" -jna = "5.14.0" +jna = "5.15.0-SNAPSHOT" jprofiler = "14.0.1" json = "20240303" jsoup = "1.17.2" @@ -557,6 +557,7 @@ jline-terminal-jna = { module = "org.jline:jline-terminal-jna", version.ref = "j jline-terminal-jni = { module = "org.jline:jline-terminal-jni", version.ref = "jline" } jna = { group = "net.java.dev.jna", name = "jna", version.ref = "jna" } jna-jpms = { group = "net.java.dev.jna", name = "jna-jpms", version.ref = "jna" } +jna-graalvm = { group = "net.java.dev.jna", name = "jna-graalvm", version.ref = "jna" } json = { group = "org.json", name = "json", version.ref = "json" } jsoup = { group = "org.jsoup", name = "jsoup", version.ref = "jsoup" } junit = "junit:junit:4.13.2" diff --git a/packages/cli/src/main/resources/META-INF/native-image/jni-config.json b/packages/cli/src/main/resources/META-INF/native-image/jni-config.json index 22e50673b6..adf802c3fe 100644 --- a/packages/cli/src/main/resources/META-INF/native-image/jni-config.json +++ b/packages/cli/src/main/resources/META-INF/native-image/jni-config.json @@ -19,64 +19,6 @@ "name":"com.apple.eawt._AppMenuBarHandler", "methods":[{"name":"initMenuStates","parameterTypes":["boolean","boolean","boolean","boolean"] }] }, -{ - "name":"com.sun.jna.Callback" -}, -{ - "name":"com.sun.jna.CallbackReference", - "methods":[{"name":"getCallback","parameterTypes":["java.lang.Class","com.sun.jna.Pointer","boolean"] }, {"name":"getFunctionPointer","parameterTypes":["com.sun.jna.Callback","boolean"] }, {"name":"getNativeString","parameterTypes":["java.lang.Object","boolean"] }, {"name":"initializeThread","parameterTypes":["com.sun.jna.Callback","com.sun.jna.CallbackReference$AttachOptions"] }] -}, -{ - "name":"com.sun.jna.CallbackReference$AttachOptions" -}, -{ - "name":"com.sun.jna.FromNativeConverter", - "methods":[{"name":"nativeType","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.IntegerType", - "fields":[{"name":"value"}] -}, -{ - "name":"com.sun.jna.JNIEnv" -}, -{ - "name":"com.sun.jna.Native", - "methods":[{"name":"dispose","parameterTypes":[] }, {"name":"fromNative","parameterTypes":["com.sun.jna.FromNativeConverter","java.lang.Object","java.lang.reflect.Method"] }, {"name":"fromNative","parameterTypes":["java.lang.Class","java.lang.Object"] }, {"name":"fromNative","parameterTypes":["java.lang.reflect.Method","java.lang.Object"] }, {"name":"nativeType","parameterTypes":["java.lang.Class"] }, {"name":"toNative","parameterTypes":["com.sun.jna.ToNativeConverter","java.lang.Object"] }] -}, -{ - "name":"com.sun.jna.Native$ffi_callback", - "methods":[{"name":"invoke","parameterTypes":["long","long","long"] }] -}, -{ - "name":"com.sun.jna.NativeMapped", - "methods":[{"name":"toNative","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.Pointer", - "fields":[{"name":"peer"}], - "methods":[{"name":"","parameterTypes":["long"] }] -}, -{ - "name":"com.sun.jna.PointerType", - "fields":[{"name":"pointer"}] -}, -{ - "name":"com.sun.jna.Structure", - "fields":[{"name":"memory"}, {"name":"typeInfo"}], - "methods":[{"name":"autoRead","parameterTypes":[] }, {"name":"autoWrite","parameterTypes":[] }, {"name":"getTypeInfo","parameterTypes":[] }, {"name":"newInstance","parameterTypes":["java.lang.Class","long"] }] -}, -{ - "name":"com.sun.jna.Structure$ByValue" -}, -{ - "name":"com.sun.jna.Structure$FFIType$FFITypes", - "fields":[{"name":"ffi_type_double"}, {"name":"ffi_type_float"}, {"name":"ffi_type_longdouble"}, {"name":"ffi_type_pointer"}, {"name":"ffi_type_sint16"}, {"name":"ffi_type_sint32"}, {"name":"ffi_type_sint64"}, {"name":"ffi_type_sint8"}, {"name":"ffi_type_uint16"}, {"name":"ffi_type_uint32"}, {"name":"ffi_type_uint64"}, {"name":"ffi_type_uint8"}, {"name":"ffi_type_void"}] -}, -{ - "name":"com.sun.jna.WString", - "methods":[{"name":"","parameterTypes":["java.lang.String"] }] -}, { "name":"com.sun.management.internal.DiagnosticCommandArgumentInfo", "methods":[{"name":"","parameterTypes":["java.lang.String","java.lang.String","java.lang.String","java.lang.String","boolean","boolean","boolean","int"] }] @@ -503,4 +445,4 @@ "name":"sun.nio.ch.FileChannelImpl", "fields":[{"name":"fd"}] } -] \ No newline at end of file +] diff --git a/packages/cli/src/main/resources/META-INF/native-image/proxy-config.json b/packages/cli/src/main/resources/META-INF/native-image/proxy-config.json index adbc0ab536..11059ba532 100644 --- a/packages/cli/src/main/resources/META-INF/native-image/proxy-config.json +++ b/packages/cli/src/main/resources/META-INF/native-image/proxy-config.json @@ -1,20 +1,5 @@ [ - { - "interfaces":["com.github.ajalt.mordant.internal.jna.MacosLibC"] - }, - { - "interfaces":["com.sun.jna.platform.mac.CoreFoundation"] - }, - { - "interfaces":["com.sun.jna.platform.mac.IOKit"] - }, - { - "interfaces":["com.sun.jna.platform.mac.SystemB"] - }, { "interfaces":["kotlin.jvm.functions.Function2"] - }, - { - "interfaces":["oshi.jna.platform.mac.SystemB"] } -] \ No newline at end of file +] diff --git a/packages/cli/src/main/resources/META-INF/native-image/reflect-config.json b/packages/cli/src/main/resources/META-INF/native-image/reflect-config.json index 3e56e734b7..3858d4af64 100644 --- a/packages/cli/src/main/resources/META-INF/native-image/reflect-config.json +++ b/packages/cli/src/main/resources/META-INF/native-image/reflect-config.json @@ -345,58 +345,6 @@ "name":"com.sun.crypto.provider.TlsPrfGenerator$V12", "methods":[{"name":"","parameterTypes":[] }] }, -{ - "name":"com.sun.jna.CallbackProxy", - "methods":[{"name":"callback","parameterTypes":["java.lang.Object[]"] }] -}, -{ - "name":"com.sun.jna.platform.mac.CoreFoundation$CFAllocatorRef", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.platform.mac.CoreFoundation$CFDataRef", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.platform.mac.CoreFoundation$CFIndex", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.platform.mac.CoreFoundation$CFMutableDictionaryRef", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.platform.mac.CoreFoundation$CFStringRef", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.platform.mac.CoreFoundation$CFTypeID", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.platform.mac.CoreFoundation$CFTypeRef", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.platform.mac.IOKit$IOIterator", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.platform.mac.IOKit$IORegistryEntry", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.platform.unix.LibCAPI$size_t", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.ptr.IntByReference", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.ptr.PointerByReference", - "methods":[{"name":"","parameterTypes":[] }] -}, { "name":"com.sun.management.GarbageCollectorMXBean", "queryAllPublicMethods":true @@ -10937,4 +10885,4 @@ "name":"sun.security.x509.SubjectKeyIdentifierExtension", "methods":[{"name":"","parameterTypes":["java.lang.Boolean","java.lang.Object"] }] } -] \ No newline at end of file +] diff --git a/packages/graalvm/src/main/resources/META-INF/native-image/dev.elide/graalvm/proxy-config.json b/packages/graalvm/src/main/resources/META-INF/native-image/dev.elide/graalvm/proxy-config.json index 1610ea14b3..fe51488c70 100644 --- a/packages/graalvm/src/main/resources/META-INF/native-image/dev.elide/graalvm/proxy-config.json +++ b/packages/graalvm/src/main/resources/META-INF/native-image/dev.elide/graalvm/proxy-config.json @@ -1,3 +1 @@ -[ - -] \ No newline at end of file +[] diff --git a/packages/runtime/build.gradle.kts b/packages/runtime/build.gradle.kts index 1bdb6caa0f..5c0b4c7f05 100644 --- a/packages/runtime/build.gradle.kts +++ b/packages/runtime/build.gradle.kts @@ -111,6 +111,7 @@ val enablePgoSampling = false val enablePgoInstrumentation = false val enablePgoReport = true val enableJna = true +val enableJnaStatic = true val enableSbom = oracleGvm val enableSbomStrict = false val glibcTarget = "glibc" @@ -411,6 +412,9 @@ dependencies { jvmOnly(libs.jna.jpms) } else { implementation(libs.jna.jpms) + if (enableJnaStatic) { + implementation(libs.jna.graalvm) + } } // Tests @@ -580,6 +584,7 @@ val deprecatedNativeArgs = listOf( ) val enabledFeatures = listOfNotNull( + "com.sun.jna.SubstrateStaticJNA", "elide.tool.feature.ToolingUmbrellaFeature", onlyIf(enableSqlite, "elide.runtime.feature.engine.NativeSQLiteFeature"), ) diff --git a/packages/runtime/src/main/resources/META-INF/native-image/jni-config.json b/packages/runtime/src/main/resources/META-INF/native-image/jni-config.json index 4a32e9262d..ea291e0c54 100644 --- a/packages/runtime/src/main/resources/META-INF/native-image/jni-config.json +++ b/packages/runtime/src/main/resources/META-INF/native-image/jni-config.json @@ -20,162 +20,6 @@ { "name":"[[J" }, -{ - "name":"com.sun.jna.Callback", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, -{ - "name":"com.sun.jna.CallbackReference", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true, - "methods":[{"name":"getCallback","parameterTypes":["java.lang.Class","com.sun.jna.Pointer","boolean"] }, {"name":"getFunctionPointer","parameterTypes":["com.sun.jna.Callback","boolean"] }, {"name":"getNativeString","parameterTypes":["java.lang.Object","boolean"] }, {"name":"initializeThread","parameterTypes":["com.sun.jna.Callback","com.sun.jna.CallbackReference$AttachOptions"] }] -}, -{ - "name":"com.sun.jna.CallbackReference$AttachOptions", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, -{ - "name":"com.sun.jna.FromNativeConverter", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true, - "methods":[{"name":"nativeType","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.IntegerType", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true, - "fields":[{"name":"value", "allowWrite":true}] -}, -{ - "name":"com.sun.jna.JNIEnv", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, -{ - "name":"com.sun.jna.Native", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true, - "methods":[ - {"name":"dispose","parameterTypes":[] }, - {"name":"fromNative","parameterTypes":["com.sun.jna.FromNativeConverter","java.lang.Object","java.lang.reflect.Method"] }, - {"name":"fromNative","parameterTypes":["java.lang.Class","java.lang.Object"] }, - {"name":"fromNative","parameterTypes":["java.lang.reflect.Method","java.lang.Object"] }, - {"name":"nativeType","parameterTypes":["java.lang.Class"] }, - {"name":"toNative","parameterTypes":["com.sun.jna.ToNativeConverter","java.lang.Object"]}, - {"name":"open","parameterTypes":["java.lang.String","java.lang.Integer"]}, - {"name":"close","parameterTypes":["java.lang.Long"]}, - {"name":"findSymbol","parameterTypes":["java.lang.Long","java.lang.String"]} - ] -}, -{ - "name":"com.sun.jna.Native$ffi_callback", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true, - "methods":[{"name":"invoke","parameterTypes":["long","long","long"] }] -}, -{ - "name":"com.sun.jna.NativeLong", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, -{ - "name":"com.sun.jna.NativeMapped", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true, - "methods":[{"name":"toNative","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.Pointer", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true, - "fields":[{"name":"peer", "allowWrite":true}], - "methods":[{"name":"","parameterTypes":["long"] }] -}, -{ - "name":"com.sun.jna.PointerType", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true, - "fields":[{"name":"pointer", "allowWrite":true}] -}, -{ - "name":"com.sun.jna.Structure", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true, - "fields":[{"name":"memory", "allowWrite":true}, {"name":"typeInfo", "allowWrite":true}], - "methods":[{"name":"autoRead","parameterTypes":[] }, {"name":"autoWrite","parameterTypes":[] }, {"name":"getTypeInfo","parameterTypes":[] }, {"name":"getTypeInfo","parameterTypes":["java.lang.Object"] }, {"name":"newInstance","parameterTypes":["java.lang.Class"] }, {"name":"newInstance","parameterTypes":["java.lang.Class","long"] }, {"name":"newInstance","parameterTypes":["java.lang.Class","com.sun.jna.Pointer"] }] -}, -{ - "name":"com.sun.jna.Structure$ByValue", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, -{ - "name":"com.sun.jna.Structure$FFIType", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, -{ - "name":"com.sun.jna.Structure$FFIType$FFITypes", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true, - "fields":[{"name":"ffi_type_double", "allowWrite":true}, {"name":"ffi_type_float", "allowWrite":true}, {"name":"ffi_type_longdouble", "allowWrite":true}, {"name":"ffi_type_pointer", "allowWrite":true}, {"name":"ffi_type_sint16", "allowWrite":true}, {"name":"ffi_type_sint32", "allowWrite":true}, {"name":"ffi_type_sint64", "allowWrite":true}, {"name":"ffi_type_sint8", "allowWrite":true}, {"name":"ffi_type_uint16", "allowWrite":true}, {"name":"ffi_type_uint32", "allowWrite":true}, {"name":"ffi_type_uint64", "allowWrite":true}, {"name":"ffi_type_uint8", "allowWrite":true}, {"name":"ffi_type_void", "allowWrite":true}] -}, -{ - "name":"com.sun.jna.WString", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true, - "methods":[{"name":"","parameterTypes":["java.lang.String"] }] -}, -{ - "name":"com.sun.jna.ptr.PointerByReference", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, -{ - "name":"com.sun.jna.platform.mac.CoreFoundation$CFStringRef", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, { "name":"com.sun.management.internal.DiagnosticCommandArgumentInfo", "methods":[{"name":"","parameterTypes":["java.lang.String","java.lang.String","java.lang.String","java.lang.String","boolean","boolean","boolean","int"] }] diff --git a/packages/runtime/src/main/resources/META-INF/native-image/proxy-config.json b/packages/runtime/src/main/resources/META-INF/native-image/proxy-config.json index 1eb28a0e2e..fe51488c70 100644 --- a/packages/runtime/src/main/resources/META-INF/native-image/proxy-config.json +++ b/packages/runtime/src/main/resources/META-INF/native-image/proxy-config.json @@ -1,32 +1 @@ -[ - { - "interfaces":["com.github.ajalt.mordant.internal.jna.MacosLibC"] - }, - { - "interfaces":["com.github.ajalt.mordant.internal.jna.PosixLibC"] - }, - { - "interfaces":["com.sun.jna.Callback"] - }, - { - "interfaces":["com.sun.jna.Library"] - }, - { - "interfaces":["com.sun.jna.platform.linux.Udev"] - }, - { - "interfaces":["oshi.jna.platform.linux.LinuxLibc"] - }, - { - "interfaces":["com.sun.jna.platform.mac.SystemB"] - }, - { - "interfaces":["oshi.jna.platform.mac.SystemB"] - }, - { - "interfaces":["com.sun.jna.platform.mac.IOKit"] - }, - { - "interfaces":["com.sun.jna.platform.mac.CoreFoundation"] - } -] +[] diff --git a/packages/runtime/src/main/resources/META-INF/native-image/reflect-config.json b/packages/runtime/src/main/resources/META-INF/native-image/reflect-config.json index e3ac3d02ec..9c724c9bf5 100644 --- a/packages/runtime/src/main/resources/META-INF/native-image/reflect-config.json +++ b/packages/runtime/src/main/resources/META-INF/native-image/reflect-config.json @@ -169,77 +169,6 @@ "name":"com.sun.crypto.provider.TlsMasterSecretGenerator", "methods":[{"name":"","parameterTypes":[] }] }, -{ - "name":"com.sun.jna.CallbackProxy", - "methods":[{"name":"callback","parameterTypes":["java.lang.Object[]"] }] -}, -{ - "name":"com.sun.jna.CallbackReference", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, -{ - "name":"com.sun.jna.Klass", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, -{ - "name":"com.sun.jna.Native", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, -{ - "name":"com.sun.jna.NativeLong", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, -{ - "name":"com.sun.jna.Structure", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true, - "fields":[{"name":"memory", "allowWrite":true}, {"name":"typeInfo"}], - "methods":[{"name":"newInstance","parameterTypes":["java.lang.Class"] }, {"name":"newInstance","parameterTypes":["java.lang.Class","long"] }, {"name":"newInstance","parameterTypes":["java.lang.Class","com.sun.jna.Pointer"] }] -}, -{ - "name":"com.sun.jna.platform.linux.Udev$UdevContext", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.platform.linux.Udev$UdevDevice", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.platform.linux.Udev$UdevEnumerate", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.platform.linux.Udev$UdevListEntry", - "methods":[{"name":"","parameterTypes":[] }] -}, -{ - "name":"com.sun.jna.ptr.IntByReference", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, -{ - "name":"com.sun.jna.ptr.PointerByReference", - "allDeclaredMethods":true, - "allPublicMethods":true, - "allDeclaredConstructors":true, - "allPublicConstructors":true -}, { "name":"com.sun.management.GarbageCollectorMXBean", "queryAllPublicMethods":true diff --git a/settings.gradle.kts b/settings.gradle.kts index 86be705291..8ffc71c344 100644 --- a/settings.gradle.kts +++ b/settings.gradle.kts @@ -96,6 +96,7 @@ dependencyResolutionManagement { content { includeGroup("dev.elide") includeGroup("org.capnproto") + includeGroup("net.java.dev.jna") includeGroup("org.jetbrains.reflekt") includeGroup("com.google.devtools.ksp") includeGroupAndSubgroups("org.graalvm")