From d04c1fb6076f390356d7aa66625c912eebb7beb2 Mon Sep 17 00:00:00 2001 From: Daniel Lockyer Date: Sat, 30 Dec 2023 09:40:31 +0100 Subject: [PATCH 1/2] Removed Node version from matrix title - we only run CI on one version so it's not needed any more --- .github/workflows/ci.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index f7cd894e..01945178 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -37,7 +37,7 @@ jobs: node: 18 host: arm64 target: arm64 - name: ${{ matrix.os }} (node=${{ matrix.node }}, host=${{ matrix.host }}, target=${{ matrix.target }}) + name: ${{ matrix.os }} (host=${{ matrix.host }}, target=${{ matrix.target }}) steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 - uses: actions/setup-node@v4 From 9233494677bea73e8127086bc0e2b13351b2b20e Mon Sep 17 00:00:00 2001 From: Daniel Lockyer Date: Sat, 30 Dec 2023 09:41:10 +0100 Subject: [PATCH 2/2] Moved Linux ARM64 compilation to native builder - Docker ends up being really slow for cross compilation and we should be able to do it as a cross compilation step from x64 --- .github/workflows/ci.yml | 28 +++++++++++++++++++++++++--- 1 file changed, 25 insertions(+), 3 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 01945178..a61a2bb4 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -29,6 +29,10 @@ jobs: node: - 18 include: + - os: ubuntu-20.04 + node: 18 + host: x64 + target: arm64 - os: windows-latest node: 18 host: x86 @@ -82,19 +86,38 @@ jobs: echo "CFLAGS=${CFLAGS:-} -include ../src/gcc-preinclude.h" >> $GITHUB_ENV echo "CXXFLAGS=${CXXFLAGS:-} -include ../src/gcc-preinclude.h" >> $GITHUB_ENV + - name: Setup cross compilation for Linux ARM64 + if: contains(matrix.os, 'ubuntu') && matrix.target == 'arm64' + run: | + sudo apt-get install -y gcc-aarch64-linux-gnu g++-aarch64-linux-gnu binutils-aarch64-linux-gnu + echo "AS=aarch64-linux-gnu-as" >> $GITHUB_ENV + echo "STRIP=aarch64-linux-gnu-strip" >> $GITHUB_ENV + echo "AR=aarch64-linux-gnu-ar" >> $GITHUB_ENV + echo "CC=aarch64-linux-gnu-gcc" >> $GITHUB_ENV + echo "CPP=aarch64-linux-gnu-cpp" >> $GITHUB_ENV + echo "CXX=aarch64-linux-gnu-g++" >> $GITHUB_ENV + echo "LD=aarch64-linux-gnu-ld" >> $GITHUB_ENV + echo "FC=aarch64-linux-gnu-gfortran" >> $GITHUB_ENV + echo "PKG_CONFIG_PATH=/usr/lib/aarch64-linux-gnu/pkgconfig" >> $GITHUB_ENV + - name: Build binaries run: yarn prebuild -a ${{ env.TARGET }} - name: Print binary info if: contains(matrix.os, 'ubuntu') run: | - ldd build/**/node_sqlite3.node + if [ "${{ matrix.target }}" = "arm64" ]; then + PREFIX=aarch64-linux-gnu- + fi + + ${PREFIX}readelf -d build/**/node_sqlite3.node | grep "Shared library" echo "---" - nm build/**/node_sqlite3.node | grep "GLIBC_" | c++filt || true + ${PREFIX}nm build/**/node_sqlite3.node | grep "GLIBC_" | ${PREFIX}c++filt || true echo "---" file build/**/node_sqlite3.node - name: Run tests + if: matrix.target != 'arm64' && !contains(matrix.os, 'ubuntu') run: yarn test - name: Upload binaries to commit artifacts @@ -120,7 +143,6 @@ jobs: target: - linux/arm64 variant: - - bullseye - alpine3.15 include: # musl x64 builds