summaryrefslogtreecommitdiff
path: root/tb/models
diff options
context:
space:
mode:
authorAlejandro Soto <alejandro@34project.org>2023-10-05 05:30:04 -0600
committerAlejandro Soto <alejandro@34project.org>2023-10-05 13:07:57 -0600
commit3feb806ef5cbcb2ee85890d3f24ebfccf04869b1 (patch)
tree862e2745d2aaa3607ea33fd17bfbc8b57f967008 /tb/models
parent4acd900c4602db0353d11bf6841ddadfd80c57b8 (diff)
tb: implement block test: smp_sim reset
Diffstat (limited to '')
-rw-r--r--tb/models/__init__.py3
-rw-r--r--tb/models/core.py22
-rw-r--r--tb/models/smp.py22
3 files changed, 47 insertions, 0 deletions
diff --git a/tb/models/__init__.py b/tb/models/__init__.py
new file mode 100644
index 0000000..4f14c05
--- /dev/null
+++ b/tb/models/__init__.py
@@ -0,0 +1,3 @@
+from .core import *
+from .smp import *
+
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
diff --git a/tb/models/smp.py b/tb/models/smp.py
new file mode 100644
index 0000000..a6439f8
--- /dev/null
+++ b/tb/models/smp.py
@@ -0,0 +1,22 @@
+__all__ = ['SmpModel']
+
+class SmpModel:
+ def __init__(self):
+ self._pe0 = SmpPe(0)
+ self._pe1 = SmpPe(1)
+ self._pe2 = SmpPe(1)
+ self._pe3 = SmpPe(1)
+
+ def read(self):
+ return self._pe0.read() \
+ | self._pe1.read() << 8 \
+ | self._pe2.read() << 16 \
+ | self._pe3.read() << 24
+
+class SmpPe:
+ def __init__(self, halt_on_reset):
+ self._bkpt = 0
+ self._halted = halt_on_reset
+
+ def read(self):
+ return self._bkpt << 1 | self._halted