Merge pull request #94 from enjoy-digital/probe_fifo

frontend/etherbone: Add 1-Slot PacketFIFO on LiteEthEtherboneProbe to prevent deadlock situation.
This commit is contained in:
enjoy-digital 2021-11-09 11:35:27 +01:00 committed by GitHub
commit 4dd95ea2a2
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -139,14 +139,21 @@ class LiteEthEtherboneProbe(Module):
# # #
self.submodules.fifo = fifo = PacketFIFO(eth_etherbone_packet_user_description(32),
payload_depth = 1,
param_depth = 1,
buffered = False
)
self.comb += sink.connect(fifo.sink)
self.submodules.fsm = fsm = FSM(reset_state="IDLE")
fsm.act("IDLE",
If(sink.valid,
If(fifo.source.valid,
NextState("PROBE_RESPONSE")
)
)
fsm.act("PROBE_RESPONSE",
sink.connect(source),
fifo.source.connect(source),
source.pf.eq(0),
source.pr.eq(1),
If(source.valid & source.ready,