soc/integration: update add_adapter to convert between AXILite/Wishbone

This commit is contained in:
Jędrzej Boczar 2020-07-14 14:44:28 +02:00
parent 6671eb6218
commit 35149c4e80
1 changed files with 15 additions and 0 deletions
litex/soc/integration

View File

@ -280,6 +280,21 @@ class SoCBusHandler(Module):
# Add Master/Slave ----------------------------------------------------------------------------- # Add Master/Slave -----------------------------------------------------------------------------
def add_adapter(self, name, interface, direction="m2s"): def add_adapter(self, name, interface, direction="m2s"):
assert direction in ["m2s", "s2m"] assert direction in ["m2s", "s2m"]
if isinstance(interface, axi.AXILiteInterface):
self.logger.info("{} Bus {} from {} to {}.".format(
colorer(name),
colorer("converted", color="cyan"),
colorer("AXILite"),
colorer("Wishbone")))
new_interface = wishbone.Interface(data_width=interface.data_width)
if direction == "m2s":
converter = axi.AXILite2Wishbone(axi_lite=interface, wishbone=new_interface)
elif direction == "s2m":
converter = axi.Wishbone2AXILite(wishbone=new_interface, axi_lite=interface)
self.submodules += converter
interface = new_interface
if interface.data_width != self.data_width: if interface.data_width != self.data_width:
self.logger.info("{} Bus {} from {}-bit to {}-bit.".format( self.logger.info("{} Bus {} from {}-bit to {}-bit.".format(
colorer(name), colorer(name),