interconnect/axi: Add AXI version to AXIInterface (default to AXI4) and handle AXI3/AXI4 differences.

- Max burst length of 16 in AXI3, 256 in AXI4.
- No WID in AXI4.
This commit is contained in:
Florent Kermarrec 2022-10-13 11:04:00 +02:00
parent a8070051b5
commit 84db6a0b3a
2 changed files with 20 additions and 6 deletions

View File

@ -72,6 +72,8 @@ def connect_to_pads(bus, pads, mode="master", axi_full=False):
if channel in ["w", "r"] and axi_full:
sig_list += [("last", 1)]
for name, width in sig_list:
if (channel == "w") and (name == "id") and (bus.version == "axi4"):
continue # No WID on AXI4.
sig = getattr(ch, name)
pad = getattr(pads, channel + name)
if mode == "master":

View File

@ -19,12 +19,13 @@ from litex.soc.interconnect.axi.axi_stream import AXIStreamInterface
# AXI Definition -----------------------------------------------------------------------------------
def ax_description(address_width):
def ax_description(address_width, version="axi4"):
len_width = {"axi3":4, "axi4":8}[version]
# * present for interconnect with others cores but not used by LiteX.
return [
("addr", address_width), # Address Width.
("burst", 2), # Burst type.
("len", 8), # Number of data (-1) transfers (up to 256).
("len", len_width), # Number of data (-1) transfers (up to 16 (AXI3) or 256 (AXI4)).
("size", 4), # Number of bytes (-1) of each data transfer (up to 1024 bits).
("lock", 2), # *
("prot", 3), # *
@ -49,30 +50,39 @@ def r_description(data_width):
]
class AXIInterface:
def __init__(self, data_width=32, address_width=32, id_width=1, clock_domain="sys", name=None, bursting=False,
def __init__(self, data_width=32, address_width=32, id_width=1, version="axi4", clock_domain="sys",
name = None,
bursting = False,
aw_user_width = 0,
w_user_width = 0,
b_user_width = 0,
ar_user_width = 0,
r_user_width = 0
):
# Parameters checks.
# ------------------
assert data_width in [32, 64, 128, 256, 512, 1024]
assert version in ["axi3", "axi4"]
# Parameters.
# -----------
self.data_width = data_width
self.address_width = address_width
self.id_width = id_width
self.version = version
self.clock_domain = clock_domain
self.bursting = bursting # FIXME: Use or add check.
# Write Channels.
# ---------------
self.aw = AXIStreamInterface(name=name,
layout = ax_description(address_width),
layout = ax_description(address_width=address_width, version=version),
id_width = id_width,
user_width = aw_user_width
)
self.w = AXIStreamInterface(name=name,
layout = w_description(data_width),
id_width = id_width,
id_width = {"axi3":0,"axi4":id_width}[version], # No WID on AXI4.
user_width = w_user_width
)
self.b = AXIStreamInterface(name=name,
@ -84,7 +94,7 @@ class AXIInterface:
# Read Channels.
# --------------
self.ar = AXIStreamInterface(name=name,
layout = ax_description(address_width),
layout = ax_description(address_width=address_width, version=version),
id_width = id_width,
user_width = ar_user_width
)
@ -108,6 +118,8 @@ class AXIInterface:
channel_layout = (getattr(self, channel).description.payload_layout +
getattr(self, channel).description.param_layout)
for name, width in channel_layout:
if (channel == "w") and (name == "id") and (self.version == "axi4"):
continue # No WID on AXI4.
subsignals.append(Subsignal(channel + name, Pins(width)))
ios = [(bus_name , 0) + tuple(subsignals)]
return ios