soc/integration/soc: Fix CSRBridge Bus Width conversion

Wishbone2CSR and AXILite2CSR bridges are incapable for performing
bus width conversion, which means it's Bus slave port must have same
width as CSRs.

Use CSR width to create slave bus to allow width adaptar to be inserted
by add_slave. Also add relevant assertion.

Signed-off-by: Jiaxun Yang <jiaxun.yang@flygoat.com>
This commit is contained in:
Jiaxun Yang 2024-12-17 23:28:55 +00:00
parent d05b6613e9
commit c52a2ca5df
4 changed files with 9 additions and 4 deletions

View File

@ -1138,13 +1138,14 @@ class SoC(LiteXModule, SoCCoreCompat):
}[self.bus.standard] }[self.bus.standard]
csr_bridge_name = f"{name}_bridge" csr_bridge_name = f"{name}_bridge"
self.check_if_exists(csr_bridge_name) self.check_if_exists(csr_bridge_name)
data_width = self.csr.data_width
csr_bridge = csr_bridge_cls( csr_bridge = csr_bridge_cls(
bus_bridge_cls( bus_bridge_cls(
address_width = self.bus.address_width, address_width = self.bus.address_width,
data_width = self.bus.data_width), data_width = data_width),
bus_csr = csr_bus.Interface( bus_csr = csr_bus.Interface(
address_width = self.csr.address_width, address_width = self.csr.address_width,
data_width = self.csr.data_width), data_width = data_width),
register = register) register = register)
self.logger.info("CSR Bridge {} {}.".format( self.logger.info("CSR Bridge {} {}.".format(
colorer(name, color="underline"), colorer(name, color="underline"),

View File

@ -29,6 +29,8 @@ class AXILite2CSR(LiteXModule):
self.axi_lite = axi_lite self.axi_lite = axi_lite
self.csr = bus_csr self.csr = bus_csr
assert axi_lite.data_width == bus_csr.data_width
fsm, comb = axi_lite_to_simple( fsm, comb = axi_lite_to_simple(
axi_lite = self.axi_lite, axi_lite = self.axi_lite,
port_adr = self.csr.adr, port_adr = self.csr.adr,

View File

@ -588,6 +588,8 @@ class Wishbone2CSR(LiteXModule):
# If no Wishbone bus provided, create it with default parameters. # If no Wishbone bus provided, create it with default parameters.
self.wishbone = Interface() self.wishbone = Interface()
assert self.wishbone.data_width == self.csr.data_width
# # # # # #
wishbone_adr_shift = { wishbone_adr_shift = {

View File

@ -258,8 +258,8 @@ class TestAXILite(unittest.TestCase):
class DUT(Module): class DUT(Module):
def __init__(self): def __init__(self):
self.axi_lite = AXILiteInterface() self.axi_lite = AXILiteInterface(data_width=32)
self.csr = csr_bus.Interface() self.csr = csr_bus.Interface(data_width=32)
self.submodules.axilite2csr = AXILite2CSR(self.axi_lite, self.csr) self.submodules.axilite2csr = AXILite2CSR(self.axi_lite, self.csr)
self.errors = 0 self.errors = 0