mirror of
https://github.com/m-labs/artiq.git
synced 2025-01-26 18:38:13 +08:00
rtio/sed/LaneDistributor: support specifying existing CRI
This commit is contained in:
parent
1cb05f3ed5
commit
064503f224
@ -7,18 +7,19 @@ from artiq.gateware.rtio.sed import layouts
|
||||
__all__ = ["LaneDistributor"]
|
||||
|
||||
|
||||
|
||||
# CRI write happens in 3 cycles:
|
||||
# 1. set timestamp
|
||||
# 2. set other payload elements and issue write command
|
||||
# 3. check status
|
||||
|
||||
class LaneDistributor(Module):
|
||||
def __init__(self, lane_count, seqn_width, layout_payload, fine_ts_width, enable_spread=True):
|
||||
def __init__(self, lane_count, seqn_width, layout_payload, fine_ts_width, enable_spread=True, interface=None):
|
||||
if lane_count & (lane_count - 1):
|
||||
raise NotImplementedError("lane count must be a power of 2")
|
||||
|
||||
self.cri = cri.Interface()
|
||||
if interface is None:
|
||||
interface = cri.Interface()
|
||||
self.cri = interface
|
||||
self.minimum_coarse_timestamp = Signal(64-fine_ts_width)
|
||||
self.lane_io = [Record(layouts.fifo_ingress(seqn_width, layout_payload))
|
||||
for _ in range(lane_count)]
|
||||
|
Loading…
Reference in New Issue
Block a user