mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
axi/axi_lite_to_wishbone: Add different address shift when Wishbone is byte/word addressed.
This commit is contained in:
parent
dde9605a5d
commit
b19b7ed001
1 changed files with 14 additions and 2 deletions
|
@ -17,10 +17,15 @@ from litex.soc.interconnect.axi.axi_lite import *
|
|||
|
||||
class AXILite2Wishbone(LiteXModule):
|
||||
def __init__(self, axi_lite, wishbone, base_address=0x00000000):
|
||||
wishbone_adr_shift = log2_int(axi_lite.data_width//8)
|
||||
# Parameters/Checks.
|
||||
wishbone_adr_shift = {
|
||||
"word" : log2_int(axi_lite.data_width//8),
|
||||
"byte" : 0
|
||||
}[wishbone.addressing]
|
||||
assert axi_lite.data_width == len(wishbone.dat_r)
|
||||
assert axi_lite.address_width == len(wishbone.adr) + wishbone_adr_shift
|
||||
|
||||
# Signals.
|
||||
_data = Signal(axi_lite.data_width)
|
||||
_r_addr = Signal(axi_lite.address_width)
|
||||
_w_addr = Signal(axi_lite.address_width)
|
||||
|
@ -28,6 +33,7 @@ class AXILite2Wishbone(LiteXModule):
|
|||
self.comb += _r_addr.eq(axi_lite.ar.addr - base_address)
|
||||
self.comb += _w_addr.eq(axi_lite.aw.addr - base_address)
|
||||
|
||||
# FSM.
|
||||
self.fsm = fsm = FSM(reset_state="IDLE")
|
||||
fsm.act("IDLE",
|
||||
If(axi_lite.ar.valid & axi_lite.aw.valid,
|
||||
|
@ -92,15 +98,21 @@ class AXILite2Wishbone(LiteXModule):
|
|||
|
||||
class Wishbone2AXILite(LiteXModule):
|
||||
def __init__(self, wishbone, axi_lite, base_address=0x00000000):
|
||||
wishbone_adr_shift = log2_int(axi_lite.data_width//8)
|
||||
# Parameters/Checks.
|
||||
wishbone_adr_shift = {
|
||||
"word" : log2_int(axi_lite.data_width//8),
|
||||
"byte" : 0
|
||||
}[wishbone.addressing]
|
||||
assert axi_lite.data_width == len(wishbone.dat_r)
|
||||
assert axi_lite.address_width == len(wishbone.adr) + wishbone_adr_shift
|
||||
|
||||
# Signals.
|
||||
_cmd_done = Signal()
|
||||
_data_done = Signal()
|
||||
_addr = Signal(len(wishbone.adr))
|
||||
self.comb += _addr.eq(wishbone.adr - base_address//4)
|
||||
|
||||
# FSM.
|
||||
self.fsm = fsm = FSM(reset_state="IDLE")
|
||||
fsm.act("IDLE",
|
||||
NextValue(_cmd_done, 0),
|
||||
|
|
Loading…
Reference in a new issue