CI: run all ELFs from riscv-tests/isa. #873
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 and test the Docker image | |
on: | |
push: | |
branches: | |
- main | |
pull_request: | |
jobs: | |
build: | |
name: Build/simulate/synthesisze mtkcpu | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Checkout the project | |
uses: actions/checkout@v2 | |
- name: Build the Docker image | |
shell: bash | |
run: make build-docker | |
- name: Run unit tests | |
shell: bash | |
run: ./docker_run.py --cmd 'poetry run pytest -n15 ./mtkcpu/' | |
- name: Run simulation with UART on stdout | |
shell: bash | |
run: | | |
./docker_run.py --cmd 'poetry run mtkcpu/cli/top.py gen_linker_script' | |
./docker_run.py --cmd 'make -B -C sw/uart_tx' | |
bash -c 'timeout 30 ./docker_run.py --cmd "poetry run ./mtkcpu/cli/top.py sim -e sw/uart_tx/build/uart_tx.elf" || true' | tee log.txt | |
grep -q "Hello from mtkCPU" log.txt | |
- name: Run OCD tests | |
shell: bash | |
run: ./docker_run.py --cmd 'poetry run python3 mtkcpu/tests/test_jtag.py && cat ckpt.log' | |
- name: Run (external) riscv-tests tests | |
shell: bash | |
run: | | |
make fetch-riscv-tests-isa # 'isa' directory will be created locally. | |
ln -s ./isa sw/ | |
./docker_run.py --cmd 'poetry run python3 mtkcpu/tests/test_external_riscv_tests.py /toolchain/sw/isa' # NOTE issues with host-docker boundary | |
- name: Synthesisze SoC | |
shell: bash | |
run: | | |
./docker_run.py --cmd 'poetry run mtkcpu/cli/top.py gen_linker_script' | |
./docker_run.py --cmd 'make -B -C sw/uart_tx' | |
: # TODO - the confusing reason why we copy bitstream to /toolchain/sw is that we need to somehow pass it from docker guest to host (github action artifact), and 'docker_run.py' only mounts 'sw' directory. | |
./docker_run.py --cmd 'PROJ_NAME=uart_tx ; poetry run ./mtkcpu/cli/top.py build -e sw/$PROJ_NAME/build/$PROJ_NAME.elf ; cp build/top.bin /toolchain/sw' | |
- name: Upload artifact | |
uses: actions/upload-artifact@v2 | |
with: | |
name: iceBreaker bitstream | |
path: sw/top.bin |