mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
Add on-chip SRAM
This commit is contained in:
parent
6fde54c5aa
commit
28f00c3a9a
2 changed files with 31 additions and 2 deletions
27
milkymist/sram/__init__.py
Normal file
27
milkymist/sram/__init__.py
Normal file
|
@ -0,0 +1,27 @@
|
|||
from migen.fhdl.structure import *
|
||||
from migen.bus import wishbone
|
||||
|
||||
class SRAM:
|
||||
def __init__(self, depth):
|
||||
self.bus = wishbone.Slave("sram")
|
||||
self.depth = depth
|
||||
|
||||
def get_fragment(self):
|
||||
# generate write enable signal
|
||||
we = Signal(BV(4))
|
||||
comb = [we[i].eq(self.bus.cyc_i & self.bus.stb_i & self.bus.sel_i[3-i])
|
||||
for i in range(4)]
|
||||
# split address
|
||||
nbits = bits_for(self.depth-1)
|
||||
partial_adr = Signal(BV(nbits))
|
||||
comb.append(partial_adr.eq(self.bus.adr_i[:nbits]))
|
||||
# generate ack
|
||||
sync = [
|
||||
self.bus.ack_o.eq(0),
|
||||
If(self.bus.cyc_i & self.bus.stb_i & ~self.bus.ack_o,
|
||||
self.bus.ack_o.eq(1)
|
||||
)
|
||||
]
|
||||
# memory
|
||||
port = MemoryPort(partial_adr, self.bus.dat_o, we, self.bus.dat_i, we_granularity=8)
|
||||
return Fragment(comb, sync, memories=[Memory(32, self.depth, port)])
|
6
top.py
6
top.py
|
@ -2,22 +2,24 @@ from migen.fhdl.structure import *
|
|||
from migen.fhdl import tools, verilog, autofragment
|
||||
from migen.bus import wishbone, csr, wishbone2csr
|
||||
|
||||
from milkymist import m1reset, clkfx, lm32, norflash, uart
|
||||
from milkymist import m1reset, clkfx, lm32, norflash, uart, sram
|
||||
import constraints
|
||||
|
||||
def get():
|
||||
MHz = 1000000
|
||||
clk_freq = 80*MHz
|
||||
sram_size = 4096 # in kilobytes
|
||||
|
||||
clkfx_sys = clkfx.ClkFX(50*MHz, clk_freq)
|
||||
reset0 = m1reset.M1Reset()
|
||||
|
||||
cpu0 = lm32.LM32()
|
||||
norflash0 = norflash.NorFlash(25, 12)
|
||||
sram0 = sram.SRAM(sram_size//4)
|
||||
wishbone2csr0 = wishbone2csr.WB2CSR()
|
||||
wishbonecon0 = wishbone.InterconnectShared(
|
||||
[cpu0.ibus, cpu0.dbus],
|
||||
[(0, norflash0.bus), (3, wishbone2csr0.wishbone)],
|
||||
[(0, norflash0.bus), (1, sram0.bus), (3, wishbone2csr0.wishbone)],
|
||||
register=True,
|
||||
offset=1)
|
||||
uart0 = uart.UART(0, clk_freq, baud=115200)
|
||||
|
|
Loading…
Reference in a new issue