frontend/stream/LiteEthUDP2StreamRX: Pass last signal from Sink to Source.

This commit is contained in:
Florent Kermarrec 2021-09-22 12:05:09 +02:00
parent 9b88c0f299
commit 393158f2a5

View file

@ -72,20 +72,18 @@ class LiteEthUDP2StreamRX(Module):
valid = Signal()
self.comb += valid.eq(
(sink.ip_address == ip_address) &
(sink.dst_port == udp_port)
(sink.dst_port == udp_port)
)
if fifo_depth is None:
self.comb += [
sink.connect(source, keep={"last", "ready", "data"}),
source.valid.eq(sink.valid & valid),
source.data.eq(sink.data),
sink.ready.eq(source.ready)
]
else:
self.submodules.fifo = fifo = stream.SyncFIFO([("data", 8)], fifo_depth)
self.comb += [
sink.connect(fifo.sink, keep={"last", "ready", "data"}),
fifo.sink.valid.eq(sink.valid & valid),
fifo.sink.data.eq(sink.data),
sink.ready.eq(fifo.sink.ready),
fifo.source.connect(source)
]