soc/interconnect/axi: add Wishbone2AXI converter
authorGabriel Somlo <gsomlo@gmail.com>
Sat, 1 Aug 2020 21:06:02 +0000 (17:06 -0400)
committerGabriel Somlo <gsomlo@gmail.com>
Mon, 3 Aug 2020 16:50:00 +0000 (12:50 -0400)
litex/soc/interconnect/axi.py

index 958061a9bbee575280e12e9c9845285a6affbde9..ec25bbaeae405f666353cd392ac46085167049bf 100644 (file)
@@ -649,6 +649,15 @@ class Wishbone2AXILite(Module):
             NextState("IDLE")
         )
 
+# Wishbone to AXI ----------------------------------------------------------------------------------
+
+class Wishbone2AXI(Module):
+    def __init__(self, wishbone, axi, base_address=0x00000000):
+        axi_lite          = AXILiteInterface(axi.data_width, axi.address_width)
+        wishbone2axi_lite = Wishbone2AXILite(wishbone, axi_lite, base_address)
+        axi_lite2axi      = AXILite2AXI(axi_lite, axi)
+        self.submodules += wishbone2axi_lite, axi_lite2axi
+
 # AXILite to CSR -----------------------------------------------------------------------------------
 
 def axi_lite_to_simple(axi_lite, port_adr, port_dat_r, port_dat_w=None, port_we=None):