ci: add build for copy_and_run and fix coremark #5
This file contains 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 tests for XiangShan | |
on: | |
push: | |
branches: [ master ] | |
pull_request: | |
branches: [ master ] | |
env: | |
MAKE_FLAGS: ARCH=riscv64-xs CROSS_COMPILE=riscv64-linux-gnu- | |
jobs: | |
build: | |
runs-on: ubuntu-24.04 | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Install Dependency | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y gcc-riscv64-linux-gnu g++-riscv64-linux-gnu gfortran-riscv64-linux-gnu binutils-riscv64-linux-gnu | |
- name: Setup env | |
run: | | |
echo "AM_HOME=$GITHUB_WORKSPACE" >> $GITHUB_ENV | |
- name: Build normal tests | |
env: | |
tests: | |
tests/cputest | |
tests/softprefetchtest | |
tests/dualcoretest | |
tests/cacheoptest/dcache | |
tests/cacheoptest/icache | |
tests/cacheoptest/llc | |
tests/aliastest | |
run: | | |
for one_test in $tests; do | |
echo ::group::$one_test | |
cd $GITHUB_WORKSPACE/$one_test | |
make clean | |
make ${{ env.MAKE_FLAGS }} | |
mkdir -p $GITHUB_WORKSPACE/build/$one_test | |
cp build/*.{elf,bin,txt} $GITHUB_WORKSPACE/build/$one_test | |
cd $GITHUB_WORKSPACE | |
echo "::endgroup::" | |
done | |
- name: Build Microbench | |
run: | | |
cd $GITHUB_WORKSPACE/apps/microbench | |
make clean | |
make ${{ env.MAKE_FLAGS }} mainargs=test | |
mkdir -p $GITHUB_WORKSPACE/build/apps/microbench | |
cp build/*.{elf,bin,txt} $GITHUB_WORKSPACE/build/apps/microbench | |
cd $GITHUB_WORKSPACE | |
- name: Build coremark 1 iteration | |
run: | | |
cd $GITHUB_WORKSPACE/apps/coremark | |
make clean | |
make ${{ env.MAKE_FLAGS }} ITERATIONS=1 | |
mkdir -p $GITHUB_WORKSPACE/build/apps/coremark | |
cp build/*.{elf,bin,txt} $GITHUB_WORKSPACE/build/apps/coremark | |
cd $GITHUB_WORKSPACE | |
- name: Build copy_and_run_coremark | |
env: | |
MAKE_FLAGS: ARCH=riscv64-xs-flash CROSS_COMPILE=riscv64-linux-gnu- | |
run: | | |
cd $GITHUB_WORKSPACE/apps/loader | |
make ${{ env.MAKE_FLAGS }} ELF_PATH=$GITHUB_WORKSPACE/build/apps/coremark/coremark-riscv64-xs.bin NAME=copy_and_run_coremark | |
cp build/*.{elf,bin,txt} $GITHUB_WORKSPACE/build/apps/coremark | |
cd $GITHUB_WORKSPACE | |
- name: Build amtest | |
run: | | |
mkdir -p $GITHUB_WORKSPACE/build/amtest/ | |
cd $GITHUB_WORKSPACE/tests/amtest | |
# Thanks to the brilliant framework of amtest, tests have to be compiled one by on. | |
# external_intr | |
echo ::group::external_intr | |
make clean | |
make ${{ env.MAKE_FLAGS }} mainargs=e NAME=external_intr | |
cp build/*.{elf,bin,txt} $GITHUB_WORKSPACE/build/amtest | |
make clean | |
echo "::endgroup::" | |
# pmp_test | |
echo ::group::pmp_test | |
make clean | |
make ${{ env.MAKE_FLAGS }} mainargs=c NAME=pmp_test | |
mkdir -p $GITHUB_WORKSPACE/build/amtest/ | |
cp build/*.{elf,bin,txt} $GITHUB_WORKSPACE/build/amtest | |
make clean | |
echo "::endgroup::" | |
# sv39_hp_atom_test | |
echo ::group::sv39_hp_atom_test | |
make clean | |
make ${{ env.MAKE_FLAGS }} mainargs=f NAME=sv39_hp_atom_test | |
mkdir -p $GITHUB_WORKSPACE/build/amtest/ | |
cp build/*.{elf,bin,txt} $GITHUB_WORKSPACE/build/amtest | |
make clean | |
echo "::endgroup::" | |
- name: Upload artifacts | |
uses: actions/upload-artifact@v4 | |
with: | |
name: nexus-am-workloads | |
path: build |