From 8caf537870048aaf1cc5e72ab7ba657addf05c7e Mon Sep 17 00:00:00 2001 From: RICCIARDI-Adrien Date: Thu, 7 Dec 2023 22:51:25 +0100 Subject: [PATCH 1/2] ci: Used the prebuild Buildroot images to increase the build speed. Also added the support for 32-bit and 64-bit RISC-V architectures. Signed-off-by: RICCIARDI-Adrien --- .github/workflows/buildroot.yaml | 63 +++++++++++++++----------------- 1 file changed, 29 insertions(+), 34 deletions(-) diff --git a/.github/workflows/buildroot.yaml b/.github/workflows/buildroot.yaml index edfcdf94..1e43de02 100644 --- a/.github/workflows/buildroot.yaml +++ b/.github/workflows/buildroot.yaml @@ -12,42 +12,37 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - defconfig_name: [qemu_x86_defconfig, qemu_x86_64_defconfig, raspberrypi4_defconfig, raspberrypi4_64_defconfig, qemu_ppc64le_pseries_defconfig, qemu_mips32r2_malta_defconfig, qemu_mips64_malta_defconfig] - libc_name: [glibc, uclibc, musl] + defconfig_name: + - qemu_x86_defconfig + - qemu_x86_64_defconfig + - raspberrypi4_defconfig + - raspberrypi4_64_defconfig + - qemu_ppc64le_pseries_defconfig + - qemu_mips32r2_malta_defconfig + - qemu_mips64_malta_defconfig + - qemu_riscv32_virt_defconfig + - qemu_riscv64_virt_defconfig + libc_name: + - glibc + - uclibc + - musl + env: + CI_VERSION: v1.0 + BUILDROOT_DIRECTORY_NAME: buildroot-${{ matrix.defconfig_name }}-${{ matrix.libc_name }} steps: - - name: Checkout Buildroot sources - # Builroot 2021.02 is the first stable version to natively support radvd 2.19, this avoids a lot of package modifications - run: git clone --depth=1 --branch=2021.02 https://git.busybox.net/buildroot - - name: Select latest radvd development version - working-directory: buildroot/package/radvd + - name: Retrieve prebuilt Buildroot image + working-directory: /home/runner run: | - # Do not check for package hash, so there is no need to compute it - rm radvd.hash - # Get package sources from head of master branch - sed -i "/RADVD_VERSION =/c\\RADVD_VERSION = ${GITHUB_SHA}" radvd.mk - sed -i '/RADVD_SITE =/c\\RADVD_SITE = https://github.com/radvd-project/radvd' radvd.mk - sed -i '9iRADVD_SITE_METHOD = git' radvd.mk - # Autotools "configure" script is missing, tell Buildroot to generate it before building - sed -i '18iRADVD_AUTORECONF = YES' radvd.mk - - name: Enable radvd build - working-directory: buildroot + wget https://github.com/radvd-project/radvd-ci/releases/download/${{ env.CI_VERSION }}/${{ env.BUILDROOT_DIRECTORY_NAME }}.tar.zst + tar --zstd --strip-components=2 -xf ${{ env.BUILDROOT_DIRECTORY_NAME }}.tar.zst + - name: Select the latest radvd upstream version + working-directory: /home/runner/${{ env.BUILDROOT_DIRECTORY_NAME }}/package/radvd run: | - echo "BR2_PACKAGE_RADVD=y" >> configs/${{ matrix.defconfig_name }} - - name: Select glibc - if: ${{ matrix.libc_name == 'glibc' }} - working-directory: buildroot - run: echo "BR2_TOOLCHAIN_BUILDROOT_GLIBC=y" >> configs/${{ matrix.defconfig_name }} - - name: Select uClibc - if: ${{ matrix.libc_name == 'uclibc' }} - working-directory: buildroot - run: echo "BR2_TOOLCHAIN_BUILDROOT_UCLIBC=y" >> configs/${{ matrix.defconfig_name }} - - name: Select musl - if: ${{ matrix.libc_name == 'musl' }} - working-directory: buildroot - run: echo "BR2_TOOLCHAIN_BUILDROOT_MUSL=y" >> configs/${{ matrix.defconfig_name }} - - name: Configure Buildroot - working-directory: buildroot - run: make ${{ matrix.defconfig_name }} + # Get package sources from head of current branch + sed -i "/RADVD_VERSION =/c\\RADVD_VERSION = ${GITHUB_SHA}" radvd.mk + - name: Trigger a radvd package rebuild + working-directory: /home/runner/${{ env.BUILDROOT_DIRECTORY_NAME }}/output/build + run: rm -rf radvd* - name: Build - working-directory: buildroot + working-directory: /home/runner/${{ env.BUILDROOT_DIRECTORY_NAME }} run: make From 19e784cb1bf9f96f33e6411bd92f6786810298bd Mon Sep 17 00:00:00 2001 From: RICCIARDI-Adrien Date: Thu, 7 Dec 2023 22:58:41 +0100 Subject: [PATCH 2/2] ci: Stopped waiting for the Linux CI to terminate to start Buildroot CI, because the Buildroot CI is now fast. Signed-off-by: RICCIARDI-Adrien --- .github/workflows/buildroot.yaml | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/.github/workflows/buildroot.yaml b/.github/workflows/buildroot.yaml index 1e43de02..e5b4cd74 100644 --- a/.github/workflows/buildroot.yaml +++ b/.github/workflows/buildroot.yaml @@ -1,14 +1,8 @@ name: Buildroot -on: - workflow_run: - workflows: [Linux] - types: - - completed +on: [push, pull_request] jobs: buildroot: - # Only run this job if the triggering job (Linux) passed - if: ${{ github.event.workflow_run.conclusion == 'success' }} runs-on: ubuntu-latest strategy: matrix: