aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/python/usrp_mpm
diff options
context:
space:
mode:
Diffstat (limited to 'mpm/python/usrp_mpm')
-rw-r--r--mpm/python/usrp_mpm/simulator/chdr_stream.py3
-rw-r--r--mpm/python/usrp_mpm/simulator/noc_block_regs.py8
2 files changed, 10 insertions, 1 deletions
diff --git a/mpm/python/usrp_mpm/simulator/chdr_stream.py b/mpm/python/usrp_mpm/simulator/chdr_stream.py
index f63fba050..7147a98b5 100644
--- a/mpm/python/usrp_mpm/simulator/chdr_stream.py
+++ b/mpm/python/usrp_mpm/simulator/chdr_stream.py
@@ -195,6 +195,9 @@ class ChdrOutputStream:
if num_samps_left == 0:
break
header.seq_num = seq_num
+ timestamp = self.stream_spec.init_timestamp \
+ if seq_num == 0 and self.stream_spec.is_timed \
+ else None
packet = ChdrPacket(self.chdr_w, header, bytes(0))
packet_samples = self.stream_spec.packet_samples
if num_samps_left is not None:
diff --git a/mpm/python/usrp_mpm/simulator/noc_block_regs.py b/mpm/python/usrp_mpm/simulator/noc_block_regs.py
index b488ed43f..de6bd22a0 100644
--- a/mpm/python/usrp_mpm/simulator/noc_block_regs.py
+++ b/mpm/python/usrp_mpm/simulator/noc_block_regs.py
@@ -26,6 +26,8 @@ REGS_PER_PORT = 16
REG_RX_MAX_WORDS_PER_PKT = 0x28
REG_RX_CMD_NUM_WORDS_HI = 0x1C
REG_RX_CMD_NUM_WORDS_LO = 0x18
+REG_RX_CMD_TIME_LO = 0x20
+REG_RX_CMD_TIME_HI = 0x24
REG_RX_CMD = 0x14
RX_CMD_CONTINUOUS = 0x2
@@ -207,10 +209,14 @@ class NocBlockRegs:
self.get_stream_spec().set_num_words_hi(value)
elif reg == REG_RX_CMD_NUM_WORDS_LO:
self.get_stream_spec().set_num_words_lo(value)
+ elif reg == REG_RX_CMD_TIME_HI:
+ self.get_stream_spec().set_timestamp_hi(value)
+ elif reg == REG_RX_CMD_TIME_LO:
+ self.get_stream_spec().set_timestamp_lo(value)
elif reg == REG_RX_CMD:
if value & (1 << 31) != 0:
- self.log.warn("Timed Streams are not supported. Starting immediately")
value = value & ~(1 << 31) # Clear the flag
+ self.get_stream_spec().is_timed = True
if value == RX_CMD_STOP:
sep_block_id = self.resolve_ep_towards_outputs((self.get_radio_port(), chan))
self.stop_tx_stream(sep_block_id)