mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
fhdl/structure: add Memory.get_port API
This commit is contained in:
parent
9d3e218863
commit
0f6215a13a
1 changed files with 24 additions and 1 deletions
|
@ -308,6 +308,7 @@ class Instance(HUID):
|
|||
|
||||
(READ_FIRST, WRITE_FIRST, NO_CHANGE) = range(3)
|
||||
|
||||
# NOTE: Direct use of MemoryPort is deprecated. Use Memory.get_port() instead.
|
||||
class MemoryPort:
|
||||
def __init__(self, adr, dat_r, we=None, dat_w=None,
|
||||
async_read=False, re=None, we_granularity=0, mode=WRITE_FIRST,
|
||||
|
@ -322,13 +323,35 @@ class MemoryPort:
|
|||
self.mode = mode
|
||||
self.clock_domain = clock_domain
|
||||
|
||||
# NOTE: ports parameter will be removed
|
||||
class Memory(HUID):
|
||||
def __init__(self, width, depth, *ports, init=None):
|
||||
super().__init__()
|
||||
self.width = width
|
||||
self.depth = depth
|
||||
self.ports = ports
|
||||
self.ports = list(ports)
|
||||
self.init = init
|
||||
|
||||
def get_port(self, write_capable=False, async_read=False,
|
||||
has_re=False, we_granularity=0, mode=WRITE_FIRST,
|
||||
clock_domain="sys"):
|
||||
adr = Signal(BV(bits_for(self.depth-1)))
|
||||
dat_r = Signal(BV(self.width))
|
||||
if write_capable:
|
||||
we = Signal()
|
||||
dat_w = Signal(BV(self.width))
|
||||
else:
|
||||
we = None
|
||||
dat_w = None
|
||||
if has_re:
|
||||
re = Signal()
|
||||
else:
|
||||
re = None
|
||||
mp = MemoryPort(adr, dat_r, we, dat_w,
|
||||
async_read, re, we_granularity, mode,
|
||||
clock_domain)
|
||||
self.ports.append(mp)
|
||||
return mp
|
||||
|
||||
#
|
||||
|
||||
|
|
Loading…
Reference in a new issue