forked from M-Labs/artiq-zynq
pipeline GW: increase buf len to 512 for event pak
This commit is contained in:
parent
d46c5434de
commit
19fe570924
|
@ -11,7 +11,7 @@ word_dw = 32
|
||||||
word_layout = [("data", word_dw), ("k", word_dw//8)]
|
word_layout = [("data", word_dw), ("k", word_dw//8)]
|
||||||
|
|
||||||
buffer_count = 4
|
buffer_count = 4
|
||||||
buffer_depth = 128
|
buffer_depth = 512
|
||||||
|
|
||||||
def K(x, y):
|
def K(x, y):
|
||||||
return ((y << 5) | x)
|
return ((y << 5) | x)
|
||||||
|
@ -182,7 +182,7 @@ class Trigger_ACK_Inserter(Module):
|
||||||
@FullMemoryWE()
|
@FullMemoryWE()
|
||||||
class TX_Command_Packet(Module, AutoCSR):
|
class TX_Command_Packet(Module, AutoCSR):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.tx_word_len = CSRStorage(bits_for(buffer_depth))
|
self.tx_word_len = CSRStorage(log2_int(buffer_depth))
|
||||||
self.tx = CSR()
|
self.tx = CSR()
|
||||||
|
|
||||||
# # #
|
# # #
|
||||||
|
@ -193,7 +193,7 @@ class TX_Command_Packet(Module, AutoCSR):
|
||||||
|
|
||||||
|
|
||||||
tx_done = Signal()
|
tx_done = Signal()
|
||||||
addr_next = Signal(bits_for(buffer_depth))
|
addr_next = Signal(log2_int(buffer_depth))
|
||||||
addr = Signal.like(addr_next)
|
addr = Signal.like(addr_next)
|
||||||
addr_rst = Signal()
|
addr_rst = Signal()
|
||||||
addr_inc = Signal()
|
addr_inc = Signal()
|
||||||
|
@ -419,14 +419,11 @@ class CXP_Data_Packet_Decode(Module):
|
||||||
self.write_ptr_sys = Signal.like(write_ptr)
|
self.write_ptr_sys = Signal.like(write_ptr)
|
||||||
self.specials += MultiReg(write_ptr, self.write_ptr_sys),
|
self.specials += MultiReg(write_ptr, self.write_ptr_sys),
|
||||||
|
|
||||||
self.read_ptr_rx = Signal.like(write_ptr)
|
|
||||||
|
|
||||||
self.comb += [
|
self.comb += [
|
||||||
mem_port.adr[:addr_nbits].eq(addr),
|
mem_port.adr[:addr_nbits].eq(addr),
|
||||||
mem_port.adr[addr_nbits:].eq(write_ptr),
|
mem_port.adr[addr_nbits:].eq(write_ptr),
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
# For control ack, event packet
|
# For control ack, event packet
|
||||||
fsm.act("LOAD_BUFFER",
|
fsm.act("LOAD_BUFFER",
|
||||||
mem_port.we.eq(0),
|
mem_port.we.eq(0),
|
||||||
|
@ -448,6 +445,7 @@ class CXP_Data_Packet_Decode(Module):
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
self.read_ptr_rx = Signal.like(write_ptr)
|
||||||
fsm.act("MOVE_BUFFER_PTR",
|
fsm.act("MOVE_BUFFER_PTR",
|
||||||
self.sink.ack.eq(0),
|
self.sink.ack.eq(0),
|
||||||
If(write_ptr + 1 == self.read_ptr_rx,
|
If(write_ptr + 1 == self.read_ptr_rx,
|
||||||
|
|
Loading…
Reference in New Issue