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()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|