mirror of
https://github.com/m-labs/artiq.git
synced 2024-12-24 10:54:02 +08:00
drtio: break some RT features into manager, add echo request CSR
This commit is contained in:
parent
1145a193dd
commit
df7294792c
@ -55,9 +55,12 @@ class DRTIOMaster(Module):
|
|||||||
self.submodules.rt_packets = rt_packets.RTPacketMaster(self.link_layer)
|
self.submodules.rt_packets = rt_packets.RTPacketMaster(self.link_layer)
|
||||||
self.submodules.rt_controller = rt_controller.RTController(
|
self.submodules.rt_controller = rt_controller.RTController(
|
||||||
self.rt_packets, channel_count, fine_ts_width)
|
self.rt_packets, channel_count, fine_ts_width)
|
||||||
|
self.submodules.rt_manager = rt_controller.RTManager(self.rt_packets)
|
||||||
|
|
||||||
def get_kernel_csrs(self):
|
def get_kernel_csrs(self):
|
||||||
return self.rt_controller.get_kernel_csrs()
|
return self.rt_controller.get_kernel_csrs()
|
||||||
|
|
||||||
def get_csrs(self):
|
def get_csrs(self):
|
||||||
return self.link_layer.get_csrs() + self.rt_controller.get_csrs()
|
return (self.link_layer.get_csrs() +
|
||||||
|
self.rt_controller.get_csrs() +
|
||||||
|
self.rt_manager.get_csrs())
|
||||||
|
@ -22,25 +22,20 @@ class _CSRs(AutoCSR):
|
|||||||
self.o_reset_channel_status = CSR()
|
self.o_reset_channel_status = CSR()
|
||||||
self.o_wait = CSRStatus()
|
self.o_wait = CSRStatus()
|
||||||
|
|
||||||
self.err_present = CSR()
|
|
||||||
self.err_code = CSRStatus(8)
|
|
||||||
|
|
||||||
self.dbg_update_packet_cnt = CSR()
|
|
||||||
self.dbg_packet_cnt_tx = CSRStatus(32)
|
|
||||||
self.dbg_packet_cnt_rx = CSRStatus(32)
|
|
||||||
|
|
||||||
|
|
||||||
class RTController(Module):
|
class RTController(Module):
|
||||||
def __init__(self, rt_packets, channel_count, fine_ts_width):
|
def __init__(self, rt_packets, channel_count, fine_ts_width):
|
||||||
self.kcsrs = KernelCSRs()
|
self.kcsrs = KernelCSRs()
|
||||||
self.csrs = _CSRs()
|
self.csrs = _CSRs()
|
||||||
|
|
||||||
|
# channel selection
|
||||||
chan_sel = Signal(16)
|
chan_sel = Signal(16)
|
||||||
self.comb += chan_sel.eq(
|
self.comb += chan_sel.eq(
|
||||||
Mux(self.csrs.chan_sel_override_en.storage,
|
Mux(self.csrs.chan_sel_override_en.storage,
|
||||||
self.csrs.chan_sel_override.storage,
|
self.csrs.chan_sel_override.storage,
|
||||||
self.kcsrs.chan_sel.storage))
|
self.kcsrs.chan_sel.storage))
|
||||||
|
|
||||||
|
# master RTIO counter and counter synchronization
|
||||||
self.submodules.counter = RTIOCounter(64-fine_ts_width)
|
self.submodules.counter = RTIOCounter(64-fine_ts_width)
|
||||||
self.sync += If(self.kcsrs.counter_update.re,
|
self.sync += If(self.kcsrs.counter_update.re,
|
||||||
self.kcsrs.counter.status.eq(self.counter.value_sys))
|
self.kcsrs.counter.status.eq(self.counter.value_sys))
|
||||||
@ -57,6 +52,7 @@ class RTController(Module):
|
|||||||
If(self.csrs.set_time.re, rt_packets.set_time_stb.eq(1))
|
If(self.csrs.set_time.re, rt_packets.set_time_stb.eq(1))
|
||||||
]
|
]
|
||||||
|
|
||||||
|
# remote channel status cache
|
||||||
fifo_spaces_mem = Memory(16, channel_count)
|
fifo_spaces_mem = Memory(16, channel_count)
|
||||||
fifo_spaces = fifo_spaces_mem.get_port(write_capable=True)
|
fifo_spaces = fifo_spaces_mem.get_port(write_capable=True)
|
||||||
self.specials += fifo_spaces_mem, fifo_spaces
|
self.specials += fifo_spaces_mem, fifo_spaces
|
||||||
@ -64,6 +60,7 @@ class RTController(Module):
|
|||||||
last_timestamps = last_timestamps_mem.get_port(write_capable=True)
|
last_timestamps = last_timestamps_mem.get_port(write_capable=True)
|
||||||
self.specials += last_timestamps_mem, last_timestamps
|
self.specials += last_timestamps_mem, last_timestamps
|
||||||
|
|
||||||
|
# common packet fields
|
||||||
rt_packets_fifo_request = Signal()
|
rt_packets_fifo_request = Signal()
|
||||||
self.comb += [
|
self.comb += [
|
||||||
fifo_spaces.adr.eq(chan_sel),
|
fifo_spaces.adr.eq(chan_sel),
|
||||||
@ -172,22 +169,40 @@ class RTController(Module):
|
|||||||
)
|
)
|
||||||
]
|
]
|
||||||
|
|
||||||
# errors
|
|
||||||
self.comb += [
|
|
||||||
self.csrs.err_present.w.eq(rt_packets.error_not),
|
|
||||||
rt_packets.error_not_ack.eq(self.csrs.err_present.re),
|
|
||||||
self.csrs.err_code.status.eq(rt_packets.error_code)
|
|
||||||
]
|
|
||||||
|
|
||||||
# packet counters
|
|
||||||
self.sync += \
|
|
||||||
If(self.csrs.dbg_update_packet_cnt.re,
|
|
||||||
self.csrs.dbg_packet_cnt_tx.status.eq(rt_packets.packet_cnt_tx),
|
|
||||||
self.csrs.dbg_packet_cnt_rx.status.eq(rt_packets.packet_cnt_rx)
|
|
||||||
)
|
|
||||||
|
|
||||||
def get_kernel_csrs(self):
|
def get_kernel_csrs(self):
|
||||||
return self.kcsrs.get_csrs()
|
return self.kcsrs.get_csrs()
|
||||||
|
|
||||||
def get_csrs(self):
|
def get_csrs(self):
|
||||||
return self.csrs.get_csrs()
|
return self.csrs.get_csrs()
|
||||||
|
|
||||||
|
|
||||||
|
class RTManager(Module, AutoCSR):
|
||||||
|
def __init__(self, rt_packets):
|
||||||
|
self.request_echo = CSR()
|
||||||
|
|
||||||
|
self.err_present = CSR()
|
||||||
|
self.err_code = CSRStatus(8)
|
||||||
|
|
||||||
|
self.update_packet_cnt = CSR()
|
||||||
|
self.packet_cnt_tx = CSRStatus(32)
|
||||||
|
self.packet_cnt_rx = CSRStatus(32)
|
||||||
|
|
||||||
|
# # #
|
||||||
|
|
||||||
|
self.comb += self.request_echo.w.eq(rt_packets.echo_stb)
|
||||||
|
self.sync += [
|
||||||
|
If(rt_packets.echo_ack, rt_packets.echo_stb.eq(0)),
|
||||||
|
If(self.request_echo.re, rt_packets.echo_stb.eq(1))
|
||||||
|
]
|
||||||
|
|
||||||
|
self.comb += [
|
||||||
|
self.err_present.w.eq(rt_packets.error_not),
|
||||||
|
rt_packets.error_not_ack.eq(self.err_present.re),
|
||||||
|
self.err_code.status.eq(rt_packets.error_code)
|
||||||
|
]
|
||||||
|
|
||||||
|
self.sync += \
|
||||||
|
If(self.update_packet_cnt.re,
|
||||||
|
self.packet_cnt_tx.status.eq(rt_packets.packet_cnt_tx),
|
||||||
|
self.packet_cnt_rx.status.eq(rt_packets.packet_cnt_rx)
|
||||||
|
)
|
||||||
|
@ -59,6 +59,7 @@ class TestFullStack(unittest.TestCase):
|
|||||||
dut = DUT(2)
|
dut = DUT(2)
|
||||||
kcsrs = dut.master.rt_controller.kcsrs
|
kcsrs = dut.master.rt_controller.kcsrs
|
||||||
csrs = dut.master.rt_controller.csrs
|
csrs = dut.master.rt_controller.csrs
|
||||||
|
mgr = dut.master.rt_manager
|
||||||
|
|
||||||
ttl_changes = []
|
ttl_changes = []
|
||||||
correct_ttl_changes = [
|
correct_ttl_changes = [
|
||||||
@ -157,7 +158,7 @@ class TestFullStack(unittest.TestCase):
|
|||||||
self.assertEqual(wlen, 2)
|
self.assertEqual(wlen, 2)
|
||||||
|
|
||||||
def test_tsc_error():
|
def test_tsc_error():
|
||||||
err_present = yield from csrs.err_present.read()
|
err_present = yield from mgr.err_present.read()
|
||||||
self.assertEqual(err_present, 0)
|
self.assertEqual(err_present, 0)
|
||||||
yield from csrs.tsc_correction.write(10000000)
|
yield from csrs.tsc_correction.write(10000000)
|
||||||
yield from csrs.set_time.write(1)
|
yield from csrs.set_time.write(1)
|
||||||
@ -167,13 +168,13 @@ class TestFullStack(unittest.TestCase):
|
|||||||
yield from write(0, 1)
|
yield from write(0, 1)
|
||||||
for i in range(10):
|
for i in range(10):
|
||||||
yield
|
yield
|
||||||
err_present = yield from csrs.err_present.read()
|
err_present = yield from mgr.err_present.read()
|
||||||
err_code = yield from csrs.err_code.read()
|
err_code = yield from mgr.err_code.read()
|
||||||
self.assertEqual(err_present, 1)
|
self.assertEqual(err_present, 1)
|
||||||
self.assertEqual(err_code, 3)
|
self.assertEqual(err_code, 3)
|
||||||
yield from csrs.err_present.write(1)
|
yield from mgr.err_present.write(1)
|
||||||
yield
|
yield
|
||||||
err_present = yield from csrs.err_present.read()
|
err_present = yield from mgr.err_present.read()
|
||||||
self.assertEqual(err_present, 0)
|
self.assertEqual(err_present, 0)
|
||||||
|
|
||||||
def test():
|
def test():
|
||||||
|
Loading…
Reference in New Issue
Block a user