mirror of
https://github.com/enjoy-digital/liteeth.git
synced 2025-01-03 03:43:37 -05:00
core/mac/sram: fix reception of frames larger than mtu
-use 32bits length CSR (allow software to detect frames larger than mtu) -drop remaining bytes larger than mtu
This commit is contained in:
parent
072969ff58
commit
e1da2df97d
1 changed files with 2 additions and 3 deletions
|
@ -4,14 +4,13 @@ from litex.soc.interconnect.csr import *
|
|||
from litex.soc.interconnect.csr_eventmanager import *
|
||||
|
||||
|
||||
|
||||
class LiteEthMACSRAMWriter(Module, AutoCSR):
|
||||
def __init__(self, dw, depth, nslots=2):
|
||||
self.sink = sink = stream.Endpoint(eth_phy_description(dw))
|
||||
self.crc_error = Signal()
|
||||
|
||||
slotbits = max(log2_int(nslots), 1)
|
||||
lengthbits = log2_int(depth*4) # length in bytes
|
||||
lengthbits = 32
|
||||
|
||||
self._slot = CSRStatus(slotbits)
|
||||
self._length = CSRStatus(lengthbits)
|
||||
|
@ -73,7 +72,7 @@ class LiteEthMACSRAMWriter(Module, AutoCSR):
|
|||
)
|
||||
fsm.act("WRITE",
|
||||
counter_ce.eq(sink.valid),
|
||||
ongoing.eq(1),
|
||||
ongoing.eq(counter < eth_mtu),
|
||||
If(sink.valid & sink.last,
|
||||
If((sink.error & sink.last_be) != 0,
|
||||
NextState("DISCARD")
|
||||
|
|
Loading…
Reference in a new issue