summaryrefslogtreecommitdiff
path: root/tb/models/smp.py
diff options
context:
space:
mode:
Diffstat (limited to 'tb/models/smp.py')
-rw-r--r--tb/models/smp.py22
1 files changed, 22 insertions, 0 deletions
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