commit 41594c19034bc609066870f2fc5011929d820ade (tree)
parent b3c8c0df0dc1a23625d823a1c1878004c6b0bc9e
Author: Alex Rønne Petersen <alex@alexrp.com>
Date: Sat, 28 Feb 2026 08:19:51 +0100
Merge pull request 'enable `aarch64-freebsd` CI' (#31354) from alexrp/zig:aarch64-freebsd-ci into master
Reviewed-on: https://codeberg.org/ziglang/zig/pulls/31354
Diffstat:
4 files changed, 154 insertions(+), 0 deletions(-)
diff --git a/.forgejo/workflows/ci.yaml b/.forgejo/workflows/ci.yaml
@@ -17,6 +17,27 @@ permissions:
contents: read
jobs:
+ aarch64-freebsd-debug:
+ runs-on: [self-hosted, aarch64-freebsd]
+ steps:
+ - name: Checkout
+ uses: https://codeberg.org/ziglang/checkout@19af6bac491e2534a4687a50ee84fa7f13258d28
+ with:
+ fetch-depth: 0
+ - name: Build and Test
+ run: sh ci/aarch64-freebsd-debug.sh
+ timeout-minutes: 240
+ aarch64-freebsd-release:
+ runs-on: [self-hosted, aarch64-freebsd]
+ steps:
+ - name: Checkout
+ uses: https://codeberg.org/ziglang/checkout@19af6bac491e2534a4687a50ee84fa7f13258d28
+ with:
+ fetch-depth: 0
+ - name: Build and Test
+ run: sh ci/aarch64-freebsd-release.sh
+ timeout-minutes: 180
+
aarch64-linux-debug:
runs-on: [self-hosted, aarch64-linux]
steps:
diff --git a/ci/aarch64-freebsd-debug.sh b/ci/aarch64-freebsd-debug.sh
@@ -0,0 +1,63 @@
+#!/bin/sh
+
+# Requires cmake ninja-build
+
+set -x
+set -e
+
+TARGET="aarch64-freebsd-none"
+MCPU="baseline"
+CACHE_BASENAME="zig+llvm+lld+clang-$TARGET-0.16.0-dev.2287+eb3f16db5"
+PREFIX="$HOME/deps/$CACHE_BASENAME"
+ZIG="$PREFIX/bin/zig"
+
+# Override the cache directories because they won't actually help other CI runs
+# which will be testing alternate versions of zig, and ultimately would just
+# fill up space on the hard drive for no reason.
+export ZIG_GLOBAL_CACHE_DIR="$PWD/zig-global-cache"
+export ZIG_LOCAL_CACHE_DIR="$PWD/zig-local-cache"
+
+mkdir build-debug
+cd build-debug
+
+export CC="$ZIG cc -target $TARGET -mcpu=$MCPU"
+export CXX="$ZIG c++ -target $TARGET -mcpu=$MCPU"
+
+cmake .. \
+ -DCMAKE_INSTALL_PREFIX="stage3-debug" \
+ -DCMAKE_PREFIX_PATH="$PREFIX" \
+ -DCMAKE_BUILD_TYPE=Debug \
+ -DZIG_TARGET_TRIPLE="$TARGET" \
+ -DZIG_TARGET_MCPU="$MCPU" \
+ -DZIG_STATIC=ON \
+ -DZIG_NO_LIB=ON \
+ -GNinja \
+ -DCMAKE_C_LINKER_DEPFILE_SUPPORTED=FALSE \
+ -DCMAKE_CXX_LINKER_DEPFILE_SUPPORTED=FALSE
+# https://github.com/ziglang/zig/issues/22213
+
+# Now cmake will use zig as the C/C++ compiler. We reset the environment variables
+# so that installation and testing do not get affected by them.
+unset CC
+unset CXX
+
+ninja install
+
+stage3-debug/bin/zig build test docs \
+ --maxrss ${ZSF_MAX_RSS:-0} \
+ -Dstatic-llvm \
+ -Dskip-non-native \
+ -Dskip-test-incremental \
+ --search-prefix "$PREFIX" \
+ --zig-lib-dir "$PWD/../lib" \
+ --test-timeout 2m
+
+stage3-debug/bin/zig build \
+ --prefix stage4-debug \
+ -Denable-llvm \
+ -Dno-lib \
+ -Dtarget=$TARGET \
+ -Duse-zig-libcxx \
+ -Dversion-string="$(stage3-debug/bin/zig version)"
+
+stage4-debug/bin/zig test ../test/behavior.zig
diff --git a/ci/aarch64-freebsd-release.sh b/ci/aarch64-freebsd-release.sh
@@ -0,0 +1,69 @@
+#!/bin/sh
+
+# Requires cmake ninja-build
+
+set -x
+set -e
+
+TARGET="aarch64-freebsd-none"
+MCPU="baseline"
+CACHE_BASENAME="zig+llvm+lld+clang-$TARGET-0.16.0-dev.2287+eb3f16db5"
+PREFIX="$HOME/deps/$CACHE_BASENAME"
+ZIG="$PREFIX/bin/zig"
+
+# Override the cache directories because they won't actually help other CI runs
+# which will be testing alternate versions of zig, and ultimately would just
+# fill up space on the hard drive for no reason.
+export ZIG_GLOBAL_CACHE_DIR="$PWD/zig-global-cache"
+export ZIG_LOCAL_CACHE_DIR="$PWD/zig-local-cache"
+
+mkdir build-release
+cd build-release
+
+export CC="$ZIG cc -target $TARGET -mcpu=$MCPU"
+export CXX="$ZIG c++ -target $TARGET -mcpu=$MCPU"
+
+cmake .. \
+ -DCMAKE_INSTALL_PREFIX="stage3-release" \
+ -DCMAKE_PREFIX_PATH="$PREFIX" \
+ -DCMAKE_BUILD_TYPE=Release \
+ -DZIG_TARGET_TRIPLE="$TARGET" \
+ -DZIG_TARGET_MCPU="$MCPU" \
+ -DZIG_STATIC=ON \
+ -DZIG_NO_LIB=ON \
+ -GNinja \
+ -DCMAKE_C_LINKER_DEPFILE_SUPPORTED=FALSE \
+ -DCMAKE_CXX_LINKER_DEPFILE_SUPPORTED=FALSE
+# https://github.com/ziglang/zig/issues/22213
+
+# Now cmake will use zig as the C/C++ compiler. We reset the environment variables
+# so that installation and testing do not get affected by them.
+unset CC
+unset CXX
+
+ninja install
+
+stage3-release/bin/zig build test docs \
+ --maxrss ${ZSF_MAX_RSS:-0} \
+ -Dstatic-llvm \
+ -Dskip-non-native \
+ -Dskip-test-incremental \
+ --search-prefix "$PREFIX" \
+ --zig-lib-dir "$PWD/../lib" \
+ --test-timeout 2m
+
+# Ensure that stage3 and stage4 are byte-for-byte identical.
+stage3-release/bin/zig build \
+ --prefix stage4-release \
+ -Denable-llvm \
+ -Dno-lib \
+ -Doptimize=ReleaseFast \
+ -Dstrip \
+ -Dtarget=$TARGET \
+ -Duse-zig-libcxx \
+ -Dversion-string="$(stage3-release/bin/zig version)"
+
+# diff returns an error code if the files differ.
+echo "If the following command fails, it means nondeterminism has been"
+echo "introduced, making stage3 and stage4 no longer byte-for-byte identical."
+diff stage3-release/bin/zig stage4-release/bin/zig
diff --git a/test/error_traces.zig b/test/error_traces.zig
@@ -435,6 +435,7 @@ pub fn addCases(cases: *@import("tests.zig").ErrorTracesContext) void {
.{ .x86_64, .netbsd },
.{ .x86_64, .linux },
.{ .x86, .linux },
+ .{ .aarch64, .freebsd },
.{ .aarch64, .linux },
.{ .loongarch64, .linux },
.{ .powerpc64le, .linux },