diff options
author | Alex Richardson <arichardson@FreeBSD.org> | 2020-09-23 12:54:37 +0000 |
---|---|---|
committer | Alex Richardson <arichardson@FreeBSD.org> | 2020-09-23 12:54:37 +0000 |
commit | 1e266857ad7f3fa9681654af44d3699252904215 (patch) | |
tree | 681667a2732205695f7c86d0b0efdb8a36f78527 /.github/workflows | |
parent | 254c54c65ab7ccdf34cd6daf9f0dc187427d8f27 (diff) | |
download | src-test-1e266857ad7f3fa9681654af44d3699252904215.tar.gz src-test-1e266857ad7f3fa9681654af44d3699252904215.zip |
Add github CI for testing cross-building from Linux and macOS
This builds the kernel-toolchain target and an amd64 GENERIC kernel on
Ubuntu 18.04, 20.04 and the latest macOS to ensure that new changes
don't regress building on non-FreeBSD hosts.
Reviewed By: emaste, lwhsu
Differential Revision: https://reviews.freebsd.org/D26512
Notes
Notes:
svn path=/head/; revision=366074
Diffstat (limited to '.github/workflows')
-rw-r--r-- | .github/workflows/cross-bootstrap-tools.yml | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/.github/workflows/cross-bootstrap-tools.yml b/.github/workflows/cross-bootstrap-tools.yml new file mode 100644 index 0000000000000..5a51fa8890044 --- /dev/null +++ b/.github/workflows/cross-bootstrap-tools.yml @@ -0,0 +1,35 @@ +name: Cross-build CI + +on: + push: + branches: [ master ] + pull_request: + branches: [ master ] + +jobs: + build: + name: ${{ matrix.os }} + runs-on: ${{ matrix.os }} + strategy: + matrix: + os: [ubuntu-18.04, ubuntu-20.04, macOS-latest] + + steps: + - uses: actions/checkout@v2 + - name: install LLVM+libarchive (Ubuntu) + run: | + wget -O /tmp/llvm.sh https://apt.llvm.org/llvm.sh + chmod +x /tmp/llvm.sh + sudo /tmp/llvm.sh 11 + sudo apt install -y libarchive-dev + echo "::set-env name=EXTRA_MAKE_ARGS::--cross-bindir=/usr/lib/llvm-11/bin" + if: ${{ startsWith(matrix.os, 'ubuntu') }} + - name: install LLVM+libarchive (macOS) + run: brew install llvm coreutils libarchive xz + if: ${{ startsWith(matrix.os, 'macOS') }} + - name: create build dir + run: rm -rf ../build && mkdir -p ../build + - name: make kernel-toolchain + run: env MAKEOBJDIRPREFIX=`realpath ../build` ./tools/build/make.py $EXTRA_MAKE_ARGS TARGET=amd64 TARGET_ARCH=amd64 kernel-toolchain -s -j$(nproc) + - name: make buildkernel + run: env MAKEOBJDIRPREFIX=`realpath ../build` ./tools/build/make.py $EXTRA_MAKE_ARGS TARGET=amd64 TARGET_ARCH=amd64 KERNCONF=GENERIC NO_MODULES=yes buildkernel -s -j$(nproc) |