From b972a62e80326f91db4a4e994ea01dae09cb3ecc Mon Sep 17 00:00:00 2001 From: Darius Maitia Date: Thu, 19 Dec 2024 10:29:49 -0300 Subject: [PATCH] Aarch64 windows support Adding support for AARCH64 architectures on windows --- .github/workflows/publish-jvm.yml | 56 ++++++++++--------- .../src/jvmMain/kotlin/io/zenoh/Target.kt | 4 +- .../src/jvmMain/kotlin/io/zenoh/Zenoh.kt | 33 +++++++---- 3 files changed, 57 insertions(+), 36 deletions(-) diff --git a/.github/workflows/publish-jvm.yml b/.github/workflows/publish-jvm.yml index 3f8d4d01..3fbb1cb9 100644 --- a/.github/workflows/publish-jvm.yml +++ b/.github/workflows/publish-jvm.yml @@ -29,35 +29,41 @@ jobs: job: # In order to load any added target at runtime, editing the Zenoh class under jvmMain is required. - { - target: x86_64-unknown-linux-gnu, - arch: amd64, - os: ubuntu-20.04, - build-cmd: "cargo", - } + target: x86_64-unknown-linux-gnu, + arch: amd64, + os: ubuntu-20.04, + build-cmd: "cargo", + } - { - target: aarch64-unknown-linux-gnu, - arch: arm64, - os: ubuntu-20.04, - build-cmd: "cross", - } + target: aarch64-unknown-linux-gnu, + arch: arm64, + os: ubuntu-20.04, + build-cmd: "cross", + } - { - target: x86_64-apple-darwin, - arch: darwin, - os: macos-latest, - build-cmd: "cargo", - } + target: x86_64-apple-darwin, + arch: darwin, + os: macos-latest, + build-cmd: "cargo", + } - { - target: aarch64-apple-darwin, - arch: darwin, - os: macos-latest, - build-cmd: "cargo", - } + target: aarch64-apple-darwin, + arch: darwin, + os: macos-latest, + build-cmd: "cargo", + } - { - target: x86_64-pc-windows-msvc, - arch: win64, - os: windows-2019, - build-cmd: "cargo", - } + target: x86_64-pc-windows-msvc, + arch: win64, + os: windows-2019, + build-cmd: "cargo", + } + - { + target: aarch64-pc-windows-msvc, + arch: arm64, + os: windows-2019, + build-cmd: "cargo", + } steps: - name: Checkout source code uses: actions/checkout@v4 diff --git a/zenoh-java/src/jvmMain/kotlin/io/zenoh/Target.kt b/zenoh-java/src/jvmMain/kotlin/io/zenoh/Target.kt index 4bb087ee..f3f28256 100644 --- a/zenoh-java/src/jvmMain/kotlin/io/zenoh/Target.kt +++ b/zenoh-java/src/jvmMain/kotlin/io/zenoh/Target.kt @@ -14,8 +14,9 @@ package io.zenoh -enum class Target { +internal enum class Target { WINDOWS_X86_64_MSVC, + WINDOWS_AARCH64_MSVC, LINUX_X86_64, LINUX_AARCH64, APPLE_AARCH64, @@ -24,6 +25,7 @@ enum class Target { override fun toString(): String { return when (this) { WINDOWS_X86_64_MSVC -> "x86_64-pc-windows-msvc" + WINDOWS_AARCH64_MSVC -> "aarch64-pc-windows-msvc" LINUX_X86_64 -> "x86_64-unknown-linux-gnu" LINUX_AARCH64 -> "aarch64-unknown-linux-gnu" APPLE_AARCH64 -> "aarch64-apple-darwin" diff --git a/zenoh-java/src/jvmMain/kotlin/io/zenoh/Zenoh.kt b/zenoh-java/src/jvmMain/kotlin/io/zenoh/Zenoh.kt index 11ae638c..95acbe4e 100644 --- a/zenoh-java/src/jvmMain/kotlin/io/zenoh/Zenoh.kt +++ b/zenoh-java/src/jvmMain/kotlin/io/zenoh/Zenoh.kt @@ -45,24 +45,37 @@ internal actual object ZenohLoad { */ private fun determineTarget(): Result = runCatching { val osName = System.getProperty("os.name").lowercase() - val osArch = System.getProperty("os.arch") + val osArch = System.getProperty("os.arch").lowercase() val target = when { osName.contains("win") -> when { - osArch.contains("x86_64") || osArch.contains("amd64") -> Target.WINDOWS_X86_64_MSVC - else -> throw UnsupportedOperationException("Unsupported architecture: $osArch") + osArch.contains("x86_64") || osArch.contains("amd64") || osArch.contains("x64") -> + Target.WINDOWS_X86_64_MSVC + + osArch.contains("aarch64") || osArch.contains("arm64") -> + Target.WINDOWS_AARCH64_MSVC + + else -> throw UnsupportedOperationException("Unsupported architecture on Windows: $osArch") } - osName.contains("mac") -> when { - osArch.contains("x86_64") || osArch.contains("amd64") -> Target.APPLE_X86_64 - osArch.contains("aarch64") -> Target.APPLE_AARCH64 - else -> throw UnsupportedOperationException("Unsupported architecture: $osArch") + osName.contains("mac") || osName.contains("darwin") || osName.contains("os x") -> when { + osArch.contains("x86_64") || osArch.contains("amd64") || osArch.contains("x64") -> + Target.APPLE_X86_64 + + osArch.contains("aarch64") || osArch.contains("arm64") -> + Target.APPLE_AARCH64 + + else -> throw UnsupportedOperationException("Unsupported architecture on macOS: $osArch") } osName.contains("nix") || osName.contains("nux") || osName.contains("aix") -> when { - osArch.contains("x86_64") || osArch.contains("amd64") -> Target.LINUX_X86_64 - osArch.contains("aarch64") -> Target.LINUX_AARCH64 - else -> throw UnsupportedOperationException("Unsupported architecture: $osArch") + osArch.contains("x86_64") || osArch.contains("amd64") || osArch.contains("x64") -> + Target.LINUX_X86_64 + + osArch.contains("aarch64") || osArch.contains("arm64") -> + Target.LINUX_AARCH64 + + else -> throw UnsupportedOperationException("Unsupported architecture on Linux/Unix: $osArch") } else -> throw UnsupportedOperationException("Unsupported platform: $osName")