Merge pull request #724 from sergachev/master

soc/interconnect/axi: let connect_to_pads() be used by AXIInterface too
This commit is contained in:
enjoy-digital 2020-12-08 13:45:12 +01:00 committed by GitHub
commit a80398d2ab
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -79,6 +79,35 @@ def _connect_axi(master, slave, keep=None, omit=None):
r.extend(m.connect(s, keep=keep, omit=omit)) r.extend(m.connect(s, keep=keep, omit=omit))
return r return r
def connect_to_pads(bus, pads, mode="master"):
assert mode in ["slave", "master"]
r = []
def swap_mode(mode): return "master" if mode == "slave" else "slave"
channel_modes = {
"aw": mode,
"w" : mode,
"b" : swap_mode(mode),
"ar": mode,
"r" : swap_mode(mode),
}
for channel, mode in channel_modes.items():
ch = getattr(bus, channel)
for name, width in [("valid", 1)] + ch.description.payload_layout:
sig = getattr(ch, name)
pad = getattr(pads, channel + name)
if mode == "master":
r.append(pad.eq(sig))
else:
r.append(sig.eq(pad))
for name, width in [("ready", 1)]:
sig = getattr(ch, name)
pad = getattr(pads, channel + name)
if mode == "master":
r.append(sig.eq(pad))
else:
r.append(pad.eq(sig))
return r
def _axi_layout_flat(axi): def _axi_layout_flat(axi):
# yields tuples (channel, name, direction) # yields tuples (channel, name, direction)
def get_dir(channel, direction): def get_dir(channel, direction):
@ -110,6 +139,9 @@ class AXIInterface:
self.ar = stream.Endpoint(ax_description(address_width, id_width)) self.ar = stream.Endpoint(ax_description(address_width, id_width))
self.r = stream.Endpoint(r_description(data_width, id_width)) self.r = stream.Endpoint(r_description(data_width, id_width))
def connect_to_pads(self, pads, mode="master"):
return connect_to_pads(self, pads, mode)
def connect(self, slave, **kwargs): def connect(self, slave, **kwargs):
return _connect_axi(self, slave, **kwargs) return _connect_axi(self, slave, **kwargs)
@ -159,32 +191,7 @@ class AXILiteInterface:
return ios return ios
def connect_to_pads(self, pads, mode="master"): def connect_to_pads(self, pads, mode="master"):
assert mode in ["slave", "master"] return connect_to_pads(self, pads, mode)
r = []
def swap_mode(mode): return "master" if mode == "slave" else "slave"
channel_modes = {
"aw": mode,
"w" : mode,
"b" : swap_mode(mode),
"ar": mode,
"r" : swap_mode(mode),
}
for channel, mode in channel_modes.items():
for name, width in [("valid", 1)] + getattr(self, channel).description.payload_layout:
sig = getattr(getattr(self, channel), name)
pad = getattr(pads, channel + name)
if mode == "master":
r.append(pad.eq(sig))
else:
r.append(sig.eq(pad))
for name, width in [("ready", 1)]:
sig = getattr(getattr(self, channel), name)
pad = getattr(pads, channel + name)
if mode == "master":
r.append(sig.eq(pad))
else:
r.append(pad.eq(sig))
return r
def connect(self, slave, **kwargs): def connect(self, slave, **kwargs):
return _connect_axi(self, slave, **kwargs) return _connect_axi(self, slave, **kwargs)