mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
Add bios test mode for CI (#1076)
* Add bios test mode for CI This enables to test the booting of each CPU configurations with the bios in Verilator simulation.
This commit is contained in:
parent
8e448592f0
commit
2886fe1701
2 changed files with 66 additions and 1 deletions
7
.github/workflows/ci.yml
vendored
7
.github/workflows/ci.yml
vendored
|
@ -3,7 +3,7 @@ name: ci
|
|||
on: [push, pull_request]
|
||||
|
||||
jobs:
|
||||
build:
|
||||
regression-test:
|
||||
runs-on: ubuntu-18.04
|
||||
steps:
|
||||
# Checkout Repository
|
||||
|
@ -14,9 +14,13 @@ jobs:
|
|||
- name: Install Tools
|
||||
run: |
|
||||
sudo apt-get install wget build-essential python3
|
||||
sudo apt-get install verilator libevent-dev libjson-c-dev
|
||||
pip3 install setuptools
|
||||
pip3 install requests
|
||||
pip3 install meson
|
||||
pip3 install ninja
|
||||
pip3 install nmigen-yosys
|
||||
pip3 install pexpect
|
||||
|
||||
# Install (n)Migen / LiteX / Cores
|
||||
- name: Install LiteX
|
||||
|
@ -41,4 +45,5 @@ jobs:
|
|||
- name: Run Tests
|
||||
run: |
|
||||
export GITHUB_ACTIONS=1
|
||||
export PATH=$PATH:$(echo $PWD/../riscv64-*/bin/)
|
||||
python3 setup.py test
|
||||
|
|
60
test/test_boot.py
Normal file
60
test/test_boot.py
Normal file
|
@ -0,0 +1,60 @@
|
|||
#
|
||||
# This file is part of LiteX.
|
||||
#
|
||||
# Copyright (c) 2021 Navaneeth Bhardwaj <navan93@gmail.com>
|
||||
# SPDX-License-Identifier: BSD-2-Clause
|
||||
|
||||
import unittest
|
||||
import pexpect
|
||||
import sys
|
||||
|
||||
class TestCPU(unittest.TestCase):
|
||||
def boot_test(self, cpu_type):
|
||||
cmd = f'lxsim --cpu-type={cpu_type}'
|
||||
litex_prompt = [b'\033\[[0-9;]+mlitex\033\[[0-9;]+m>']
|
||||
is_success = True
|
||||
with open("/tmp/test_boot_log", "wb") as result_file:
|
||||
p = pexpect.spawn(cmd, timeout=None, logfile=result_file)
|
||||
try:
|
||||
match_id = p.expect(litex_prompt, timeout=1200)
|
||||
except pexpect.EOF:
|
||||
print('\n*** Premature termination')
|
||||
is_success = False
|
||||
except pexpect.TIMEOUT:
|
||||
print('\n*** Timeout ')
|
||||
is_success = False
|
||||
|
||||
if not is_success:
|
||||
print(f'*** {cpu_type} Boot Failure')
|
||||
with open("/tmp/test_boot_log", "r") as result_file:
|
||||
print(result_file.read())
|
||||
else:
|
||||
p.terminate(force=True)
|
||||
print(f'*** {cpu_type} Boot Success')
|
||||
|
||||
return is_success
|
||||
|
||||
def test_vexriscv(self):
|
||||
self.assertTrue(self.boot_test("vexriscv"))
|
||||
|
||||
def test_vexriscv_smp(self):
|
||||
self.assertTrue(self.boot_test("vexriscv_smp"))
|
||||
|
||||
def test_cv32e40p(self):
|
||||
self.assertTrue(self.boot_test("cv32e40p"))
|
||||
|
||||
def test_ibex(self):
|
||||
self.assertTrue(self.boot_test("ibex"))
|
||||
|
||||
def test_serv(self):
|
||||
self.assertTrue(self.boot_test("serv"))
|
||||
|
||||
def test_femtorv(self):
|
||||
self.assertTrue(self.boot_test("femtorv"))
|
||||
|
||||
def test_picorv32(self):
|
||||
self.assertTrue(self.boot_test("picorv32"))
|
||||
|
||||
def test_minerva(self):
|
||||
self.assertTrue(self.boot_test("minerva"))
|
||||
|
Loading…
Reference in a new issue