mirror of
https://github.com/enjoy-digital/litedram.git
synced 2025-01-04 09:52:25 -05:00
core: replace adr with addr on native interface (closer to AXI and allow some simplifications)
This commit is contained in:
parent
050670829a
commit
9c729ae7b5
7 changed files with 37 additions and 41 deletions
|
@ -56,14 +56,14 @@ class TimingSettings:
|
|||
|
||||
def cmd_layout(address_width):
|
||||
return [
|
||||
("valid", 1, DIR_M_TO_S),
|
||||
("ready", 1, DIR_S_TO_M),
|
||||
("we", 1, DIR_M_TO_S),
|
||||
("adr", address_width, DIR_M_TO_S),
|
||||
("lock", 1, DIR_S_TO_M), # only used internally
|
||||
("valid", 1, DIR_M_TO_S),
|
||||
("ready", 1, DIR_S_TO_M),
|
||||
("we", 1, DIR_M_TO_S),
|
||||
("addr", address_width, DIR_M_TO_S),
|
||||
("lock", 1, DIR_S_TO_M), # only used internally
|
||||
|
||||
("wdata_ready", 1, DIR_S_TO_M),
|
||||
("rdata_valid", 1, DIR_S_TO_M)
|
||||
("wdata_ready", 1, DIR_S_TO_M),
|
||||
("rdata_valid", 1, DIR_S_TO_M)
|
||||
]
|
||||
|
||||
|
||||
|
@ -91,7 +91,7 @@ class LiteDRAMInterface(Record):
|
|||
def cmd_description(address_width):
|
||||
return [
|
||||
("we", 1),
|
||||
("adr", address_width)
|
||||
("addr", address_width)
|
||||
]
|
||||
|
||||
def wdata_description(data_width, with_bank):
|
||||
|
|
|
@ -42,14 +42,14 @@ class BankMachine(Module):
|
|||
auto_precharge = Signal()
|
||||
|
||||
# Command buffer
|
||||
cmd_buffer_layout = [("we", 1), ("adr", len(req.adr))]
|
||||
cmd_buffer_layout = [("we", 1), ("addr", len(req.addr))]
|
||||
cmd_buffer_lookahead = stream.SyncFIFO(
|
||||
cmd_buffer_layout, settings.cmd_buffer_depth,
|
||||
buffered=settings.cmd_buffer_buffered)
|
||||
cmd_buffer = stream.Buffer(cmd_buffer_layout) # 1 depth buffer to detect row change
|
||||
self.submodules += cmd_buffer_lookahead, cmd_buffer
|
||||
self.comb += [
|
||||
req.connect(cmd_buffer_lookahead.sink, keep={"valid", "ready", "we", "adr"}),
|
||||
req.connect(cmd_buffer_lookahead.sink, keep={"valid", "ready", "we", "addr"}),
|
||||
cmd_buffer_lookahead.source.connect(cmd_buffer.sink),
|
||||
cmd_buffer.source.ready.eq(req.wdata_ready | req.rdata_valid),
|
||||
req.lock.eq(cmd_buffer_lookahead.source.valid | cmd_buffer.source.valid),
|
||||
|
@ -61,7 +61,7 @@ class BankMachine(Module):
|
|||
has_openrow = Signal()
|
||||
openrow = Signal(settings.geom.rowbits, reset_less=True)
|
||||
hit = Signal()
|
||||
self.comb += hit.eq(openrow == slicer.row(cmd_buffer.source.adr))
|
||||
self.comb += hit.eq(openrow == slicer.row(cmd_buffer.source.addr))
|
||||
track_open = Signal()
|
||||
track_close = Signal()
|
||||
self.sync += \
|
||||
|
@ -69,17 +69,17 @@ class BankMachine(Module):
|
|||
has_openrow.eq(0)
|
||||
).Elif(track_open,
|
||||
has_openrow.eq(1),
|
||||
openrow.eq(slicer.row(cmd_buffer.source.adr))
|
||||
openrow.eq(slicer.row(cmd_buffer.source.addr))
|
||||
)
|
||||
|
||||
# Address generation
|
||||
sel_row_adr = Signal()
|
||||
sel_row_addr = Signal()
|
||||
self.comb += [
|
||||
cmd.ba.eq(n),
|
||||
If(sel_row_adr,
|
||||
cmd.a.eq(slicer.row(cmd_buffer.source.adr))
|
||||
If(sel_row_addr,
|
||||
cmd.a.eq(slicer.row(cmd_buffer.source.addr))
|
||||
).Else(
|
||||
cmd.a.eq((auto_precharge << 10) | slicer.col(cmd_buffer.source.adr))
|
||||
cmd.a.eq((auto_precharge << 10) | slicer.col(cmd_buffer.source.addr))
|
||||
)
|
||||
]
|
||||
|
||||
|
@ -93,7 +93,7 @@ class BankMachine(Module):
|
|||
if settings.with_auto_precharge:
|
||||
self.comb += [
|
||||
If(cmd_buffer_lookahead.source.valid & cmd_buffer.source.valid,
|
||||
If(slicer.row(cmd_buffer_lookahead.source.adr) != slicer.row(cmd_buffer.source.adr),
|
||||
If(slicer.row(cmd_buffer_lookahead.source.addr) != slicer.row(cmd_buffer.source.addr),
|
||||
auto_precharge.eq((track_close == 0))
|
||||
)
|
||||
)
|
||||
|
@ -151,7 +151,7 @@ class BankMachine(Module):
|
|||
track_close.eq(1)
|
||||
)
|
||||
fsm.act("ACTIVATE",
|
||||
sel_row_adr.eq(1),
|
||||
sel_row_addr.eq(1),
|
||||
track_open.eq(1),
|
||||
cmd.valid.eq(ras_allowed),
|
||||
cmd.is_cmd.eq(1),
|
||||
|
|
|
@ -23,7 +23,7 @@ class LiteDRAMNativePortCDC(Module):
|
|||
# # #
|
||||
|
||||
cmd_fifo = stream.AsyncFIFO(
|
||||
[("we", 1), ("adr", address_width)], cmd_depth)
|
||||
[("we", 1), ("addr", address_width)], cmd_depth)
|
||||
cmd_fifo = ClockDomainsRenamer(
|
||||
{"write": clock_domain_from,
|
||||
"read": clock_domain_to})(cmd_fifo)
|
||||
|
@ -94,7 +94,7 @@ class LiteDRAMNativePortDownConverter(Module):
|
|||
fsm.act("CONVERT",
|
||||
port_to.cmd.valid.eq(1),
|
||||
port_to.cmd.we.eq(port_from.cmd.we),
|
||||
port_to.cmd.adr.eq(port_from.cmd.adr*ratio + counter),
|
||||
port_to.cmd.addr.eq(port_from.cmd.addr*ratio + counter),
|
||||
If(port_to.cmd.ready,
|
||||
counter_ce.eq(1),
|
||||
If(counter == ratio - 1,
|
||||
|
@ -164,7 +164,7 @@ class LiteDRAMNativeWritePortUpConverter(Module):
|
|||
If(port_from.cmd.valid,
|
||||
counter_ce.eq(1),
|
||||
NextValue(we, port_from.cmd.we),
|
||||
NextValue(address, port_from.cmd.adr),
|
||||
NextValue(address, port_from.cmd.addr),
|
||||
NextState("RECEIVE")
|
||||
)
|
||||
)
|
||||
|
@ -180,7 +180,7 @@ class LiteDRAMNativeWritePortUpConverter(Module):
|
|||
fsm.act("GENERATE",
|
||||
port_to.cmd.valid.eq(1),
|
||||
port_to.cmd.we.eq(we),
|
||||
port_to.cmd.adr.eq(address[log2_int(ratio):]),
|
||||
port_to.cmd.addr.eq(address[log2_int(ratio):]),
|
||||
If(port_to.cmd.ready,
|
||||
NextState("IDLE")
|
||||
)
|
||||
|
@ -235,7 +235,7 @@ class LiteDRAMNativeReadPortUpConverter(Module):
|
|||
If(port_from.cmd.valid,
|
||||
If(counter == 0,
|
||||
port_to.cmd.valid.eq(1),
|
||||
port_to.cmd.adr.eq(port_from.cmd.adr[log2_int(ratio):]),
|
||||
port_to.cmd.addr.eq(port_from.cmd.addr[log2_int(ratio):]),
|
||||
port_from.cmd.ready.eq(port_to.cmd.ready),
|
||||
counter_ce.eq(port_to.cmd.ready)
|
||||
).Else(
|
||||
|
|
|
@ -164,7 +164,7 @@ class LiteDRAMAXI2NativeW(Module):
|
|||
port.cmd.valid.eq(aw.valid & can_write),
|
||||
aw.ready.eq(port.cmd.ready & can_write),
|
||||
port.cmd.we.eq(1),
|
||||
port.cmd.adr.eq(aw.addr >> ashift)
|
||||
port.cmd.addr.eq(aw.addr >> ashift)
|
||||
)
|
||||
]
|
||||
|
||||
|
@ -234,7 +234,7 @@ class LiteDRAMAXI2NativeR(Module):
|
|||
port.cmd.valid.eq(ar.valid & can_read),
|
||||
ar.ready.eq(port.cmd.ready & can_read),
|
||||
port.cmd.we.eq(0),
|
||||
port.cmd.adr.eq(ar.addr >> ashift)
|
||||
port.cmd.addr.eq(ar.addr >> ashift)
|
||||
)
|
||||
]
|
||||
|
||||
|
|
|
@ -54,10 +54,10 @@ class LiteDRAMCrossbar(Module):
|
|||
# data width convertion
|
||||
if data_width != self.controller.data_width:
|
||||
if data_width > self.controller.data_width:
|
||||
adr_shift = -log2_int(data_width//self.controller.data_width)
|
||||
addr_shift = -log2_int(data_width//self.controller.data_width)
|
||||
else:
|
||||
adr_shift = log2_int(self.controller.data_width//data_width)
|
||||
new_port = LiteDRAMNativePort(mode, port.address_width + adr_shift, data_width, clock_domain, port.id, with_reordering)
|
||||
addr_shift = log2_int(self.controller.data_width//data_width)
|
||||
new_port = LiteDRAMNativePort(mode, port.address_width + addr_shift, data_width, clock_domain, port.id, with_reordering)
|
||||
self.submodules += ClockDomainsRenamer(clock_domain)(LiteDRAMNativePortConverter(new_port, port, reverse))
|
||||
port = new_port
|
||||
|
||||
|
@ -113,7 +113,7 @@ class LiteDRAMCrossbar(Module):
|
|||
|
||||
# route requests
|
||||
self.comb += [
|
||||
bank.adr.eq(Array(m_rca)[arbiter.grant]),
|
||||
bank.addr.eq(Array(m_rca)[arbiter.grant]),
|
||||
bank.we.eq(Array(self.masters)[arbiter.grant].cmd.we),
|
||||
bank.valid.eq(Array(bank_requested)[arbiter.grant])
|
||||
]
|
||||
|
@ -183,15 +183,15 @@ class LiteDRAMCrossbar(Module):
|
|||
cba = Signal(self.bank_bits)
|
||||
rca = Signal(self.rca_bits)
|
||||
cba_upper = cba_shift + bank_bits
|
||||
self.comb += cba.eq(master.cmd.adr[cba_shift:cba_upper])
|
||||
self.comb += cba.eq(master.cmd.addr[cba_shift:cba_upper])
|
||||
if cba_shift < self.rca_bits:
|
||||
if cba_shift:
|
||||
self.comb += rca.eq(Cat(master.cmd.adr[:cba_shift],
|
||||
master.cmd.adr[cba_upper:]))
|
||||
self.comb += rca.eq(Cat(master.cmd.addr[:cba_shift],
|
||||
master.cmd.addr[cba_upper:]))
|
||||
else:
|
||||
self.comb += rca.eq(master.cmd.adr[cba_upper:])
|
||||
self.comb += rca.eq(master.cmd.addr[cba_upper:])
|
||||
else:
|
||||
self.comb += rca.eq(master.cmd.adr[:cba_shift])
|
||||
self.comb += rca.eq(master.cmd.addr[:cba_shift])
|
||||
|
||||
ba = cba
|
||||
|
||||
|
|
|
@ -57,10 +57,8 @@ class LiteDRAMDMAReader(Module):
|
|||
|
||||
if is_native:
|
||||
self.comb += cmd.we.eq(0)
|
||||
self.comb += cmd.adr.eq(sink.address) # FIXME: use addr for both
|
||||
if is_axi:
|
||||
self.comb += cmd.addr.eq(sink.address) # FIXME: use addr for both
|
||||
self.comb += [
|
||||
cmd.addr.eq(sink.address),
|
||||
cmd.valid.eq(sink.valid & request_enable),
|
||||
sink.ready.eq(cmd.ready & request_enable),
|
||||
request_issued.eq(cmd.valid & cmd.ready)
|
||||
|
@ -133,10 +131,8 @@ class LiteDRAMDMAWriter(Module):
|
|||
|
||||
if is_native:
|
||||
self.comb += cmd.we.eq(1)
|
||||
self.comb += cmd.adr.eq(sink.address) # FIXME: use addr for both
|
||||
if is_axi:
|
||||
self.comb += cmd.addr.eq(sink.address) # FIXME: use addr for both
|
||||
self.comb += [
|
||||
cmd.addr.eq(sink.address),
|
||||
cmd.valid.eq(fifo.sink.ready & sink.valid),
|
||||
sink.ready.eq(fifo.sink.ready & cmd.ready),
|
||||
fifo.sink.valid.eq(sink.valid & cmd.ready),
|
||||
|
|
|
@ -43,7 +43,7 @@ class LiteDRAMWishbone2Native(Module):
|
|||
|
||||
# Address / Datapath
|
||||
self.comb += [
|
||||
port.cmd.adr.eq(wishbone.adr),
|
||||
port.cmd.addr.eq(wishbone.adr),
|
||||
port.wdata.we.eq(wishbone.sel),
|
||||
port.wdata.data.eq(wishbone.dat_w),
|
||||
wishbone.dat_r.eq(port.rdata.data)
|
||||
|
|
Loading…
Reference in a new issue