1
0
forked from M-Labs/artiq

enable spread in satellite, use high watermark

This commit is contained in:
mwojcik 2024-05-23 16:07:40 +08:00 committed by Sébastien Bourdeauducq
parent 4de3273e7a
commit c2d645ed0a
6 changed files with 15 additions and 9 deletions

View File

@ -28,6 +28,7 @@ Highlights:
clock, to facilitate implementation of local processing on DRTIO satellites, and to slightly clock, to facilitate implementation of local processing on DRTIO satellites, and to slightly
reduce RTIO latency. reduce RTIO latency.
* Support for DRTIO-over-EEM, used with Shuttler. * Support for DRTIO-over-EEM, used with Shuttler.
* Enabled event spreading on DRTIO satellites, using high watermark for lane switching.
* Added channel names to RTIO error messages. * Added channel names to RTIO error messages.
* GUI: * GUI:
- Implemented Applet Request Interfaces which allow applets to modify datasets and set the - Implemented Applet Request Interfaces which allow applets to modify datasets and set the

View File

@ -61,8 +61,8 @@ class SyncRTIO(Module):
self.submodules.outputs = ClockDomainsRenamer("rio")( self.submodules.outputs = ClockDomainsRenamer("rio")(
SED(channels, tsc.glbl_fine_ts_width, SED(channels, tsc.glbl_fine_ts_width,
lane_count=lane_count, fifo_depth=fifo_depth, lane_count=lane_count, fifo_depth=fifo_depth,
enable_spread=False, report_buffer_space=True, enable_spread=True, fifo_high_watermark=0.75,
interface=self.cri)) report_buffer_space=True, interface=self.cri))
self.comb += self.outputs.coarse_timestamp.eq(tsc.coarse_ts) self.comb += self.outputs.coarse_timestamp.eq(tsc.coarse_ts)
self.sync += self.outputs.minimum_coarse_timestamp.eq(tsc.coarse_ts + 16) self.sync += self.outputs.minimum_coarse_timestamp.eq(tsc.coarse_ts + 16)

View File

@ -12,10 +12,13 @@ __all__ = ["SED"]
class SED(Module): class SED(Module):
def __init__(self, channels, glbl_fine_ts_width, def __init__(self, channels, glbl_fine_ts_width,
lane_count=8, fifo_depth=128, enable_spread=True, lane_count=8, fifo_depth=128, fifo_high_watermark=1.0, enable_spread=True,
quash_channels=[], report_buffer_space=False, interface=None): quash_channels=[], report_buffer_space=False, interface=None):
seqn_width = layouts.seqn_width(lane_count, fifo_depth) seqn_width = layouts.seqn_width(lane_count, fifo_depth)
fifo_high_watermark = int(fifo_high_watermark * fifo_depth)
assert fifo_depth >= fifo_high_watermark
self.submodules.lane_dist = LaneDistributor(lane_count, seqn_width, self.submodules.lane_dist = LaneDistributor(lane_count, seqn_width,
layouts.fifo_payload(channels), layouts.fifo_payload(channels),
[channel.interface.o.delay for channel in channels], [channel.interface.o.delay for channel in channels],
@ -23,7 +26,7 @@ class SED(Module):
enable_spread=enable_spread, enable_spread=enable_spread,
quash_channels=quash_channels, quash_channels=quash_channels,
interface=interface) interface=interface)
self.submodules.fifos = FIFOs(lane_count, fifo_depth, self.submodules.fifos = FIFOs(lane_count, fifo_depth, fifo_high_watermark,
layouts.fifo_payload(channels), report_buffer_space) layouts.fifo_payload(channels), report_buffer_space)
self.submodules.gates = Gates(lane_count, seqn_width, self.submodules.gates = Gates(lane_count, seqn_width,
layouts.fifo_payload(channels), layouts.fifo_payload(channels),

View File

@ -11,7 +11,7 @@ __all__ = ["FIFOs"]
class FIFOs(Module): class FIFOs(Module):
def __init__(self, lane_count, fifo_depth, layout_payload, report_buffer_space=False): def __init__(self, lane_count, fifo_depth, high_watermark, layout_payload, report_buffer_space=False):
seqn_width = layouts.seqn_width(lane_count, fifo_depth) seqn_width = layouts.seqn_width(lane_count, fifo_depth)
self.input = [Record(layouts.fifo_ingress(seqn_width, layout_payload)) self.input = [Record(layouts.fifo_ingress(seqn_width, layout_payload))
for _ in range(lane_count)] for _ in range(lane_count)]
@ -33,6 +33,7 @@ class FIFOs(Module):
fifo.din.eq(Cat(input.seqn, input.payload.raw_bits())), fifo.din.eq(Cat(input.seqn, input.payload.raw_bits())),
fifo.we.eq(input.we), fifo.we.eq(input.we),
input.writable.eq(fifo.writable), input.writable.eq(fifo.writable),
input.high_watermark.eq(fifo.level >= high_watermark),
Cat(output.seqn, output.payload.raw_bits()).eq(fifo.dout), Cat(output.seqn, output.payload.raw_bits()).eq(fifo.dout),
output.readable.eq(fifo.readable), output.readable.eq(fifo.readable),

View File

@ -154,8 +154,10 @@ class LaneDistributor(Module):
self.comb += lio.payload.timestamp.eq(compensated_timestamp) self.comb += lio.payload.timestamp.eq(compensated_timestamp)
# cycle #3, read status # cycle #3, read status
current_lane_high_watermark = Signal()
current_lane_writable = Signal() current_lane_writable = Signal()
self.comb += [ self.comb += [
current_lane_high_watermark.eq(Array(lio.high_watermark for lio in self.output)[current_lane]),
current_lane_writable.eq(Array(lio.writable for lio in self.output)[current_lane]), current_lane_writable.eq(Array(lio.writable for lio in self.output)[current_lane]),
o_status_wait.eq(~current_lane_writable) o_status_wait.eq(~current_lane_writable)
] ]
@ -170,12 +172,10 @@ class LaneDistributor(Module):
self.sequence_error_channel.eq(self.cri.chan_sel[:16]) self.sequence_error_channel.eq(self.cri.chan_sel[:16])
] ]
# current lane has been full, spread events by switching to the next. # current lane has reached high watermark, spread events by switching to the next.
if enable_spread: if enable_spread:
current_lane_writable_r = Signal(reset=1)
self.sync += [ self.sync += [
current_lane_writable_r.eq(current_lane_writable), If(current_lane_high_watermark | ~current_lane_writable,
If(~current_lane_writable_r & current_lane_writable,
force_laneB.eq(1) force_laneB.eq(1)
), ),
If(do_write, If(do_write,

View File

@ -31,6 +31,7 @@ def fifo_ingress(seqn_width, layout_payload):
return [ return [
("we", 1, DIR_M_TO_S), ("we", 1, DIR_M_TO_S),
("writable", 1, DIR_S_TO_M), ("writable", 1, DIR_S_TO_M),
("high_watermark", 1, DIR_S_TO_M),
("seqn", seqn_width, DIR_M_TO_S), ("seqn", seqn_width, DIR_M_TO_S),
("payload", [(a, b, DIR_M_TO_S) for a, b in layout_payload]) ("payload", [(a, b, DIR_M_TO_S) for a, b in layout_payload])
] ]