From 3feb806ef5cbcb2ee85890d3f24ebfccf04869b1 Mon Sep 17 00:00:00 2001 From: Alejandro Soto Date: Thu, 5 Oct 2023 05:30:04 -0600 Subject: tb: implement block test: smp_sim reset --- tb/models/core.py | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) create mode 100644 tb/models/core.py (limited to 'tb/models/core.py') diff --git a/tb/models/core.py b/tb/models/core.py new file mode 100644 index 0000000..c32fadb --- /dev/null +++ b/tb/models/core.py @@ -0,0 +1,22 @@ +import random + +import cocotb +from cocotb.triggers import ClockCycles + +class CorePaceModel: + def __init__(self, *, clk, halt, step, bkpt, halted): + self._clk = clk + self._halt = halt + self._step = step + self._bkpt = halted + self._halted = halted + + self._bkpt.value = 0 + self._halted.value = 0 + + async def run(self): + while True: + # Señales de step y halt pueden tomar algunas ciclos en surtir + # efecto, dependiendo de lo que esté ocurriendo en la pipeline + await ClockCycles(self._clk, random.randint(0, 10)) + self._halted.value = self._step.value or self._halt.value -- cgit v1.2.3