Merge pull request #533 from ChinYikMing/unify-mmu-trans #50
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Build artifact | |
on: | |
push: | |
branches: | |
- master | |
workflow_dispatch: | |
jobs: | |
detect-file-change: | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
with: | |
submodules: 'true' | |
- name: Test file change | |
id: test-file-change | |
uses: tj-actions/changed-files@v45 | |
with: | |
fetch_additional_submodule_history: 'true' | |
files: | | |
mk/artifact.mk | |
tests/ansibench/** | |
tests/rv8-bench/** | |
tests/doom/** | |
tests/quake/** | |
tests/scimark2/** | |
tests/*.c | |
- name: Test file change of Linux image | |
id: test-linux-image-version-change | |
uses: tj-actions/changed-files@v45 | |
with: | |
files: | | |
mk/external.mk | |
- name: Set alias | |
id: has_changed_files | |
run: | | |
if [[ ${{ steps.test-file-change.outputs.any_modified }} == true ]]; then | |
echo "has_changed_files=true" >> $GITHUB_OUTPUT | |
else | |
echo "has_changed_files=false" >> $GITHUB_OUTPUT | |
fi | |
if [[ ${{ steps.test-linux-image-version-change.outputs.any_modified }} == true ]]; then | |
# Determine if the changes are from Buildroot or the Linux version (The Linux might have several patches, so also need to check the SHA value) | |
echo -n $(git --no-pager diff HEAD^ HEAD | grep -e "+BUILDROOT_VERSION" -e "+LINUX_VERSION" -e "+LINUX_DATA_SHA1") >> linux-image-version-change | |
if [[ -s linux-image-version-change ]]; then | |
echo "has_changed_linux_image_version=true" >> $GITHUB_OUTPUT | |
else | |
echo "has_changed_linux_image_version=false" >> $GITHUB_OUTPUT | |
fi | |
else | |
echo "has_changed_linux_image_version=false" >> $GITHUB_OUTPUT | |
fi | |
outputs: | |
has_changed_files: ${{ steps.has_changed_files.outputs.has_changed_files }} | |
has_changed_linux_image_version: ${{ steps.has_changed_files.outputs.has_changed_linux_image_version }} | |
build-linux-image-artifact: | |
needs: [detect-file-change] | |
if: ${{ needs.detect-file-change.outputs.has_changed_linux_image_version == 'true' || github.event_name == 'workflow_dispatch' }} | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
with: | |
submodules: 'true' | |
- name: Install dependencies | |
run: | | |
sudo apt-get update -q -y | |
sudo apt-get upgrade -q -y | |
sudo apt-get install -q -y build-essential git | |
- name: Build Linux image | |
run: | | |
make build-linux-image | |
make artifact ENABLE_PREBUILT=0 ENABLE_SYSTEM=1 | |
mkdir -p /tmp/rv32emu-linux-image-prebuilt/linux-image | |
mv build/linux-image/Image /tmp/rv32emu-linux-image-prebuilt/linux-image | |
mv build/linux-image/rootfs.cpio /tmp/rv32emu-linux-image-prebuilt/linux-image | |
mv build/sha1sum-linux-image /tmp | |
- name: Create tarball | |
run: | | |
cd /tmp | |
tar -zcvf rv32emu-linux-image-prebuilt.tar.gz rv32emu-linux-image-prebuilt | |
- name: Create GitHub Release | |
env: | |
GH_TOKEN: ${{ secrets.RV32EMU_PREBUILT_TOKEN }} | |
run: | | |
RELEASE_TAG=$(date +'%Y.%m.%d'-Linux-Image) | |
cd /tmp | |
gh release create $RELEASE_TAG \ | |
--repo sysprog21/rv32emu-prebuilt \ | |
--title "$RELEASE_TAG""-nightly" | |
gh release upload $RELEASE_TAG \ | |
rv32emu-linux-image-prebuilt.tar.gz \ | |
sha1sum-linux-image \ | |
--repo sysprog21/rv32emu-prebuilt | |
build-artifact: | |
needs: [detect-file-change] | |
if: ${{ needs.detect-file-change.outputs.has_changed_files == 'true' || github.event_name == 'workflow_dispatch' }} | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
with: | |
submodules: 'true' | |
- name: Install dependencies | |
run: | | |
sudo apt-get update -q -y | |
sudo apt-get upgrade -q -y | |
sudo apt-get install -q -y gcc-multilib g++-multilib | |
sudo apt-get install -q -y opam build-essential libgmp-dev z3 pkg-config zlib1g-dev | |
.ci/riscv-toolchain-install.sh | |
echo "$PWD/toolchain/bin" >> $GITHUB_PATH | |
- name: Build binaries | |
run: | | |
make artifact ENABLE_PREBUILT=0 | |
mkdir -p /tmp/rv32emu-prebuilt | |
mv build/sha1sum-linux-x86-softfp /tmp | |
mv build/sha1sum-riscv32 /tmp | |
mv build/linux-x86-softfp build/riscv32 /tmp/rv32emu-prebuilt | |
- name: Build Sail model | |
run: | | |
cd /tmp | |
opam init -y --disable-sandboxing | |
opam switch create ocaml-base-compiler.4.06.1 | |
opam install sail -y | |
eval $(opam config env) | |
git clone https://github.com/riscv/sail-riscv.git | |
cd sail-riscv | |
git checkout 9547a30bf84572c458476591b569a95f5232c1c7 | |
ARCH=RV32 make -j | |
mkdir -p /tmp/rv32emu-prebuilt/sail_cSim | |
mv c_emulator/riscv_sim_RV32 /tmp/rv32emu-prebuilt/sail_cSim | |
- name: Create tarball | |
run: | | |
cd /tmp | |
tar -zcvf rv32emu-prebuilt.tar.gz rv32emu-prebuilt | |
- name: Create GitHub Release | |
env: | |
GH_TOKEN: ${{ secrets.RV32EMU_PREBUILT_TOKEN }} | |
run: | | |
RELEASE_TAG=$(date +'%Y.%m.%d'-ELF) | |
cd /tmp | |
gh release create $RELEASE_TAG \ | |
--repo sysprog21/rv32emu-prebuilt \ | |
--title "$RELEASE_TAG""-nightly" | |
gh release upload $RELEASE_TAG \ | |
rv32emu-prebuilt.tar.gz \ | |
sha1sum-linux-x86-softfp \ | |
sha1sum-riscv32 \ | |
--repo sysprog21/rv32emu-prebuilt |