add tx_write_only flag

This can save some resources in case reading the tx buffer is not needed.
It also makes it easier for synthesis to infer BRAM, tested on Spartan6.
This commit is contained in:
Arne Jansen 2023-06-27 16:35:50 +02:00
parent 65ef1930f5
commit e83fd55fe8
2 changed files with 4 additions and 2 deletions

View file

@ -18,6 +18,7 @@ class LiteEthMAC(Module, AutoCSR):
with_preamble_crc = True,
nrxslots = 2,
ntxslots = 2,
tx_write_only = False,
hw_mac = None,
timestamp = None,
full_memory_we = False,
@ -55,6 +56,7 @@ class LiteEthMAC(Module, AutoCSR):
ntxslots = ntxslots,
endianness = endianness,
timestamp = timestamp,
tx_write_only = tx_write_only,
)
# On some targets (Intel/Altera), the complex ports aren't inferred
# as block ram, but are created with LUTs. FullMemoryWe splits such

View file

@ -16,7 +16,7 @@ from litex.soc.interconnect import wishbone
# MAC Wishbone Interface ---------------------------------------------------------------------------
class LiteEthMACWishboneInterface(Module, AutoCSR):
def __init__(self, dw, nrxslots=2, ntxslots=2, endianness="big", timestamp=None):
def __init__(self, dw, nrxslots=2, ntxslots=2, endianness="big", timestamp=None, tx_write_only=False):
self.sink = stream.Endpoint(eth_phy_description(dw))
self.source = stream.Endpoint(eth_phy_description(dw))
self.bus = wishbone.Interface(data_width=dw)
@ -43,7 +43,7 @@ class LiteEthMACWishboneInterface(Module, AutoCSR):
for n in range(ntxslots):
wb_tx_sram_ifs.append(wishbone.SRAM(
mem_or_size = self.sram.reader.mems[n],
read_only = False,
write_only = tx_write_only,
bus = wishbone.Interface(data_width = dw)
))