1
0
mirror of https://github.com/myhdl/myhdl.git synced 2024-12-14 07:44:38 +08:00
myhdl/example/manual/sparseMemory.py

125 lines
2.2 KiB
Python
Raw Normal View History

2003-03-06 09:25:29 +00:00
from __future__ import generators
from myhdl import Signal, Simulation, posedge, negedge, delay, StopSimulation
class Error(Exception):
pass
def sparseMemory(dout, din, addr, we, en, clk):
2003-03-06 19:10:15 +00:00
2003-03-06 09:25:29 +00:00
""" Sparse memory model based on a dictionary.
Ports:
dout -- data out
din -- data in
addr -- address bus
we -- write enable: write if 1, read otherwise
en -- interface enable: enabled if 1
clk -- clock input
"""
2003-03-06 19:10:15 +00:00
memory = {}
while 1:
yield posedge(clk)
if not en:
continue
if we:
memory[addr] = din.val
else:
dout.next = memory[addr]
def sparseMemory2(dout, din, addr, we, en, clk):
2003-03-06 09:25:29 +00:00
2003-03-06 19:10:15 +00:00
""" Sparse memory model based on a dictionary.
Ports:
dout -- data out
din -- data in
addr -- address bus
we -- write enable: write if 1, read otherwise
en -- interface enable: enabled if 1
clk -- clock input
"""
2003-03-06 09:25:29 +00:00
memory = {}
while 1:
yield posedge(clk)
if not en:
continue
if we:
memory[addr] = din.val
else:
try:
dout.next = memory[addr]
except KeyError:
2003-03-06 19:16:06 +00:00
raise Error, "Uninitialized address %s" % hex(addr)
2003-03-06 09:25:29 +00:00
dout, din, addr, we, en, clk = args = [Signal(0) for i in range(6)]
2003-03-06 19:10:15 +00:00
dut = sparseMemory2(*args)
2003-03-06 09:25:29 +00:00
def clkGen():
while 1:
yield delay(10)
clk.next = not clk
def read(address):
yield negedge(clk)
en.next = 1
we.next = 0
addr.next = address
yield posedge(clk)
yield delay(1)
en.next = 0
we.next = 0
def write(data, address):
yield negedge(clk)
addr.next = address
din.next = data
en.next = 1
we.next = 1
yield posedge(clk)
en.next = 0
we.next = 0
def test():
yield write(0x55, 0x55)
yield write(0x77, 0x77)
yield write(0x111, 0x111)
yield read(0x77)
print hex(dout)
yield read(0x55)
2003-03-06 19:10:15 +00:00
print hex(dout)
2003-03-06 09:25:29 +00:00
yield read(0x33)
sim = Simulation(clkGen(), test(), dut)
if __name__ == "__main__":
sim.run()