From f61f03fae3189b618d18f8a4082570e4930842eb Mon Sep 17 00:00:00 2001 From: Ashcon Partovi Date: Sun, 24 Nov 2024 23:07:08 -0800 Subject: [PATCH] cmake: Fix cross-compiling zig on alpine (#15400) Co-authored-by: Electroid --- .buildkite/ci.mjs | 12 +++++++----- cmake/Globals.cmake | 10 ---------- cmake/Options.cmake | 10 ++++++++++ cmake/targets/BuildBun.cmake | 2 +- cmake/tools/SetupLLVM.cmake | 2 +- cmake/tools/SetupWebKit.cmake | 2 +- 6 files changed, 20 insertions(+), 18 deletions(-) diff --git a/.buildkite/ci.mjs b/.buildkite/ci.mjs index e38f544e6726fb..733e95d843c5f8 100755 --- a/.buildkite/ci.mjs +++ b/.buildkite/ci.mjs @@ -307,14 +307,16 @@ function getPipeline(options) { const getZigAgent = platform => { const { arch } = platform; const instanceType = arch === "aarch64" ? "c8g.large" : "c7i.large"; - const zigPlatform = { + return { + robobun: true, + robobun2: true, os: "linux", arch, - abi: "musl", - distro: "alpine", - release: "3.20" + distro: "debian", + release: "11", + "image-name": `linux-${arch}-debian-11-v5`, // v5 is not on main yet + "instance-type": instanceType, }; - return getEmphemeralAgent("v2", zigPlatform, instanceType); // TODO: Temporarily disable due to configuration // return { // queue: "build-zig", diff --git a/cmake/Globals.cmake b/cmake/Globals.cmake index 106e1285ea586d..3066bb2033dc67 100644 --- a/cmake/Globals.cmake +++ b/cmake/Globals.cmake @@ -136,16 +136,6 @@ else() set(WARNING WARNING) endif() -if(LINUX) - if(EXISTS "/etc/alpine-release") - set(DEFAULT_ABI "musl") - else() - set(DEFAULT_ABI "gnu") - endif() - - optionx(ABI "musl|gnu" "The ABI to use (e.g. musl, gnu)" DEFAULT ${DEFAULT_ABI}) -endif() - # TODO: This causes flaky zig builds in CI, so temporarily disable it. # if(CI) # set(DEFAULT_VENDOR_PATH ${CACHE_PATH}/vendor) diff --git a/cmake/Options.cmake b/cmake/Options.cmake index 89cdaef0e8d596..d6cc8582ea2e89 100644 --- a/cmake/Options.cmake +++ b/cmake/Options.cmake @@ -48,6 +48,16 @@ else() message(FATAL_ERROR "Unsupported architecture: ${CMAKE_SYSTEM_PROCESSOR}") endif() +if(LINUX) + if(EXISTS "/etc/alpine-release") + set(DEFAULT_ABI "musl") + else() + set(DEFAULT_ABI "gnu") + endif() + + optionx(ABI "musl|gnu" "The ABI to use (e.g. musl, gnu)" DEFAULT ${DEFAULT_ABI}) +endif() + if(ARCH STREQUAL "x64") optionx(ENABLE_BASELINE BOOL "If baseline features should be used for older CPUs (e.g. disables AVX, AVX2)" DEFAULT OFF) endif() diff --git a/cmake/targets/BuildBun.cmake b/cmake/targets/BuildBun.cmake index c27d820afee4ba..20cbb8293e91de 100644 --- a/cmake/targets/BuildBun.cmake +++ b/cmake/targets/BuildBun.cmake @@ -1163,7 +1163,7 @@ if(NOT BUN_CPP_ONLY) if(CI) set(bunTriplet bun-${OS}-${ARCH}) - if(ABI STREQUAL "musl") + if(LINUX AND ABI STREQUAL "musl") set(bunTriplet ${bunTriplet}-musl) endif() if(ENABLE_BASELINE) diff --git a/cmake/tools/SetupLLVM.cmake b/cmake/tools/SetupLLVM.cmake index 5e5fd3a9532a71..9db637b60d5fce 100644 --- a/cmake/tools/SetupLLVM.cmake +++ b/cmake/tools/SetupLLVM.cmake @@ -4,7 +4,7 @@ if(NOT ENABLE_LLVM) return() endif() -if(CMAKE_HOST_WIN32 OR CMAKE_HOST_APPLE OR ABI STREQUAL "musl") +if(CMAKE_HOST_WIN32 OR CMAKE_HOST_APPLE OR EXISTS "/etc/alpine-release") set(DEFAULT_LLVM_VERSION "18.1.8") else() set(DEFAULT_LLVM_VERSION "16.0.6") diff --git a/cmake/tools/SetupWebKit.cmake b/cmake/tools/SetupWebKit.cmake index dd263335c441da..e7cb26be5e59b4 100644 --- a/cmake/tools/SetupWebKit.cmake +++ b/cmake/tools/SetupWebKit.cmake @@ -63,7 +63,7 @@ else() message(FATAL_ERROR "Unsupported architecture: ${CMAKE_SYSTEM_PROCESSOR}") endif() -if(ABI STREQUAL "musl") +if(LINUX AND ABI STREQUAL "musl") set(WEBKIT_SUFFIX "-musl") endif()