2015-09-07 18:58:03 -04:00
|
|
|
from misoclib.com.liteethmini.common import *
|
2015-04-13 04:20:02 -04:00
|
|
|
|
2015-02-09 06:57:05 -05:00
|
|
|
class LiteEthMACGap(Module):
|
2015-04-13 03:53:43 -04:00
|
|
|
def __init__(self, dw, ack_on_gap=False):
|
|
|
|
self.sink = sink = Sink(eth_phy_description(dw))
|
|
|
|
self.source = source = Source(eth_phy_description(dw))
|
2015-04-13 05:23:27 -04:00
|
|
|
|
|
|
|
# # #
|
|
|
|
|
2015-04-13 03:53:43 -04:00
|
|
|
gap = math.ceil(eth_interpacket_gap/(dw//8))
|
|
|
|
self.submodules.counter = counter = Counter(max=gap)
|
2015-02-09 06:57:05 -05:00
|
|
|
|
2015-04-13 03:53:43 -04:00
|
|
|
self.submodules.fsm = fsm = FSM(reset_state="COPY")
|
|
|
|
fsm.act("COPY",
|
|
|
|
counter.reset.eq(1),
|
|
|
|
Record.connect(sink, source),
|
|
|
|
If(sink.stb & sink.eop & sink.ack,
|
|
|
|
NextState("GAP")
|
|
|
|
)
|
|
|
|
)
|
|
|
|
fsm.act("GAP",
|
|
|
|
counter.ce.eq(1),
|
|
|
|
sink.ack.eq(int(ack_on_gap)),
|
|
|
|
If(counter.value == (gap-1),
|
|
|
|
NextState("COPY")
|
|
|
|
)
|
|
|
|
)
|