From 69e8d0bb0ddeb9db3e3cb47d9a76dab2b0ff89cb Mon Sep 17 00:00:00 2001 From: "C.Lee Taylor" <47312074+leet4tari@users.noreply.github.com> Date: Tue, 23 Aug 2022 17:11:38 +0200 Subject: [PATCH] fix(build): switch linux-arm64 builds to cross-rs (#4524) Description Move the linux-arm64 binary build from cross-compile on GHA Ubuntu-18.04 to cross-rs docker build Motivation and Context GHA ubuntu-18.04 environment has been deprecated and will not build in future. How Has This Been Tested? Build binaries in local fork successfully. Not tested the Raspberry Pi 4 bins just yet. --- .github/workflows/base_node_binaries.json | 3 ++- .github/workflows/base_node_binaries.yml | 27 +++-------------------- Cross.toml | 21 ++++++++++++++++++ 3 files changed, 26 insertions(+), 25 deletions(-) diff --git a/.github/workflows/base_node_binaries.json b/.github/workflows/base_node_binaries.json index c8d1ecf817..68641b7952 100644 --- a/.github/workflows/base_node_binaries.json +++ b/.github/workflows/base_node_binaries.json @@ -13,7 +13,8 @@ "runs-on": "ubuntu-latest", "rust": "stable", "target": "aarch64-unknown-linux-gnu", - "cross": false, + "cross": true, + "target_bins": "--bin tari_base_node --bin tari_console_wallet --bin tari_merge_mining_proxy --bin tari_miner", "target_cpu": "generic", "features": "safe" }, diff --git a/.github/workflows/base_node_binaries.yml b/.github/workflows/base_node_binaries.yml index 3e497bb099..7904f73ae4 100644 --- a/.github/workflows/base_node_binaries.yml +++ b/.github/workflows/base_node_binaries.yml @@ -108,7 +108,7 @@ jobs: override: true - name: Install Linux dependencies - Ubuntu - if: startsWith(runner.os,'Linux') + if: ${{ startsWith(runner.os,'Linux') && matrix.builds.name != 'linux-arm64' }} run: | sudo apt-get update sudo apt-get -y install \ @@ -125,11 +125,7 @@ jobs: protobuf-compiler \ libncurses5-dev \ libncursesw5-dev \ - zip \ - gcc-aarch64-linux-gnu \ - g++-aarch64-linux-gnu - sudo apt-get -y --purge remove \ - clang-9 clang-format-9 libclang-common-9-dev libclang-cpp9 libclang1-9 + zip - name: Install macOS dependencies if: startsWith(runner.os,'macOS') @@ -182,25 +178,8 @@ jobs: - name: Cache cargo files and outputs uses: Swatinem/rust-cache@v1 - # Fix me soon! - - name: Build rust binaries - hardcoded (linux-arm64) - if: ${{ matrix.builds.name == 'linux-arm64' }} - shell: bash - run: | - export RUSTFLAGS="-C target_cpu=generic" - export ROARING_ARCH=generic - export BUILD_TARGET="aarch64-unknown-linux-gnu/" - export RUST_TARGET="--target=aarch64-unknown-linux-gnu" - export ARCH=generic - export FEATURES=safe - export CARGO_TARGET_AARCH64_UNKNOWN_LINUX_GNU_LINKER=aarch64-linux-gnu-gcc - export CC_aarch64_unknown_linux_gnu=aarch64-linux-gnu-gcc - export CXX_aarch64_unknown_linux_gnu=aarch64-linux-gnu-g++ - export BINDGEN_EXTRA_CLANG_ARGS="--sysroot /usr/aarch64-linux-gnu/include/" - cargo build --release --target ${{ matrix.builds.target }} --features ${{ matrix.builds.features }} ${{ matrix.builds.target_bins }} - - name: Build rust binaries - Normal - if: ${{ matrix.builds.name != 'linux-arm64' }} + #if: ${{ matrix.builds.name != 'linux-arm64' }} uses: actions-rs/cargo@v1 env: RUSTFLAGS: "-C target_cpu=${{ matrix.builds.target_cpu }}" diff --git a/Cross.toml b/Cross.toml index 8f7c328596..3104cfbd71 100644 --- a/Cross.toml +++ b/Cross.toml @@ -6,3 +6,24 @@ passthrough = ["CFLAGS"] [target.arm-linux-androideabi.env] passthrough = ["CFLAGS"] + +[target.aarch64-unknown-linux-gnu] +image = "ubuntu:18.04" +pre-build = [ + "apt-get update && apt-get install --assume-yes cmake gcc clang-10 pkg-config-aarch64-linux-gnu gcc-aarch64-linux-gnu g++-aarch64-linux-gnu && alias pkg-config=aarch64-linux-gnu-pkg-config" +] + +[target.aarch64-unknown-linux-gnu.env] +passthrough = [ + "RUST_DEBUG", + "RUSTFLAGS", + "ARCH", + "FEATURES", + "ROARING_ARCH", + "BUILD_TARGET=aarch64-unknown-linux-gnu/", + "RUST_TARGET=--target=aarch64-unknown-linux-gnu", + "CARGO_TARGET_AARCH64_UNKNOWN_LINUX_GNU_LINKER=aarch64-linux-gnu-gcc", + "CC_aarch64_unknown_linux_gnu=aarch64-linux-gnu-gcc", + "CXX_aarch64_unknown_linux_gnu=aarch64-linux-gnu-g++", + "BINDGEN_EXTRA_CLANG_ARGS=--sysroot /usr/aarch64-linux-gnu/include/", +]