make packetizer/depacketizer generic and use it for all layers

This commit is contained in:
Florent Kermarrec 2015-01-29 00:25:55 +01:00
parent dc5e1aa1ad
commit 5b37068393
9 changed files with 98 additions and 24 deletions

View file

@ -0,0 +1,19 @@
from liteeth.common import *
from liteeth.generic.depacketizer import LiteEthDepacketizer
from liteeth.generic.packetizer import LiteEthPacketizer
class LiteEthARPDepacketizer(LiteEthDepacketizer):
def __init__(self):
LiteEthDepacketizer.__init__(self,
eth_mac_description(8),
eth_arp_description(8),
arp_header,
arp_header_length)
class LiteEthARPPacketizer(LiteEthDepacketizer):
def __init__(self):
LiteEthDepacketizer.__init__(self,
eth_arp_description(8),
eth_mac_description(8),
arp_header,
arp_header_length)

View file

@ -1,7 +1,7 @@
from collections import OrderedDict
from migen.fhdl.std import *
from migen.fhdl.std import *
from migen.fhdl.decorators import ModuleDecorator
from migen.genlib.resetsync import AsyncResetSynchronizer
from migen.genlib.record import *
from migen.genlib.fsm import FSM, NextState
@ -160,3 +160,4 @@ class BufferizeEndpoints(ModuleDecorator):
self.submodules += buf
self.comb += Record.connect(source, buf.d)
setattr(self, name, buf.q)

View file

View file

@ -1,5 +1,3 @@
import math
from liteeth.common import *
def _decode_header(h_dict, h_signal, obj):
@ -10,14 +8,14 @@ def _decode_header(h_dict, h_signal, obj):
r.append(getattr(obj, k).eq(h_signal[start:end]))
return r
class LiteEthMACDepacketizer(Module):
def __init__(self):
self.sink = sink = Sink(eth_mac_description(8))
self.source = source = Source(eth_phy_description(8))
class LiteEthDepacketizer(Module):
def __init__(self, sink_description, source_description, header_type, header_length):
self.sink = sink = Sink(sink_description)
self.source = source = Source(source_description)
###
shift = Signal()
header = Signal(mac_header_length*8)
counter = Counter(max=mac_header_length)
header = Signal(header_length*8)
counter = Counter(max=header_length)
self.submodules += counter
fsm = FSM(reset_state="IDLE")
@ -36,7 +34,7 @@ class LiteEthMACDepacketizer(Module):
If(sink.stb,
counter.ce.eq(1),
shift.eq(1),
If(counter.value == mac_header_length-2,
If(counter.value == header_length-2,
NextState("COPY")
)
)
@ -52,7 +50,7 @@ class LiteEthMACDepacketizer(Module):
source.eop.eq(sink.eop),
source.data.eq(sink.data),
source.error.eq(sink.error),
_decode_header(mac_header, header, source)
_decode_header(header_type, header, source)
]
fsm.act("COPY",
sink.ack.eq(source.ack),

View file

@ -8,19 +8,19 @@ def _encode_header(h_dict, h_signal, obj):
r.append(h_signal[start:end].eq(getattr(obj, k)))
return r
class LiteEthMACPacketizer(Module):
def __init__(self):
self.sink = sink = Sink(eth_phy_description(8))
self.source = source = Source(eth_mac_description(8))
class LiteEthPacketizer(Module):
def __init__(self, sink_description, source_description, header_type, header_length):
self.sink = sink = Sink(sink_description)
self.source = source = Source(source_description)
###
header = Signal(mac_header_length*8)
header_reg = Signal(mac_header_length*8)
header = Signal(header_length*8)
header_reg = Signal(header_length*8)
load = Signal()
shift = Signal()
counter = Counter(max=mac_header_length)
counter = Counter(max=header_length)
self.submodules += counter
self.comb += header.eq(_encode_header(mac_header, header, sink))
self.comb += header.eq(_encode_header(header_type, header, sink))
self.sync += [
If(load,
header_reg.eq(header)
@ -53,7 +53,7 @@ class LiteEthMACPacketizer(Module):
source.data.eq(header_reg[8:16]),
If(source.stb & source.ack,
sink.ack.eq(1),
If(counter == mac_header_length-2,
If(counter == header_length-2,
NextState("COPY")
)
)

View file

@ -0,0 +1,19 @@
from liteeth.common import *
from liteeth.generic.depacketizer import LiteEthDepacketizer
from liteeth.generic.packetizer import LiteEthPacketizer
class LiteEthIPV4Depacketizer(LiteEthDepacketizer):
def __init__(self):
LiteEthDepacketizer.__init__(self,
eth_mac_description(8),
eth_ipv4_description(8),
ipv4_header,
ipv4_header_length)
class LiteEthIPV4Packetizer(LiteEthDepacketizer):
def __init__(self):
LiteEthDepacketizer.__init__(self,
eth_ipv4_description(8),
eth_mac_description(8),
ipv4_header,
ipv4_header_length)

View file

@ -1,6 +1,24 @@
from liteeth.common import *
from liteeth.mac.core import LiteEthMACCore
from liteeth.mac.frontend import wishbone
from liteeth.generic.depacketizer import LiteEthDepacketizer
from liteeth.generic.packetizer import LiteEthPacketizer
class LiteEthMACDepacketizer(LiteEthDepacketizer):
def __init__(self):
LiteEthDepacketizer.__init__(self,
eth_phy_description(8),
eth_mac_description(8),
mac_header,
mac_header_length)
class LiteEthMACPacketizer(LiteEthDepacketizer):
def __init__(self):
LiteEthDepacketizer.__init__(self,
eth_mac_description(8),
eth_phy_description(8),
mac_header,
mac_header_length)
class LiteEthMAC(Module, AutoCSR):
def __init__(self, phy, dw, interface="core", endianness="be",

View file

@ -15,11 +15,11 @@ class TB(Module):
self.submodules.hostmac = mac.MAC(self.hostphy, debug=False, loopback=True)
self.submodules.ethmac = LiteEthMAC(phy=self.hostphy, dw=32, interface="core", with_hw_preamble_crc=True)
self.submodules.streamer = PacketStreamer(eth_mac_description(32), last_be=1)
self.submodules.streamer_randomizer = AckRandomizer(eth_mac_description(32), level=50)
self.submodules.streamer = PacketStreamer(eth_phy_description(32), last_be=1)
self.submodules.streamer_randomizer = AckRandomizer(eth_phy_description(32), level=50)
self.submodules.logger_randomizer = AckRandomizer(eth_mac_description(32), level=50)
self.submodules.logger = PacketLogger(eth_mac_description(32))
self.submodules.logger_randomizer = AckRandomizer(eth_phy_description(32), level=50)
self.submodules.logger = PacketLogger(eth_phy_description(32))
# use sys_clk for each clock_domain
self.clock_domains.cd_eth_rx = ClockDomain()

View file

@ -0,0 +1,19 @@
from liteeth.common import *
from liteeth.generic.depacketizer import LiteEthDepacketizer
from liteeth.generic.packetizer import LiteEthPacketizer
class LiteEthUDPDepacketizer(LiteEthDepacketizer):
def __init__(self):
LiteEthDepacketizer.__init__(self,
eth_ipv4_description(8),
eth_udp_description(8),
udp_header,
udp_header_length)
class LiteEthUDPPacketizer(LiteEthDepacketizer):
def __init__(self):
LiteEthDepacketizer.__init__(self,
eth_udp_description(8),
eth_ipv4_description(8),
udp_header,
udp_header_length)