from migen.sim.generic import Simulator
def my_generator(n):
+ bank = n % 4
for x in range(4):
- t = TWrite(4*n+x, 0x100+x)
+ t = TWrite(4*bank+x, 0x1000*bank + 0x100*x)
yield t
- print("Wrote in {0} cycle(s)".format(t.latency))
+ print("{0}: Wrote in {1} cycle(s)".format(n, t.latency))
for x in range(4):
- t = TRead(4*n+x)
+ t = TRead(4*bank+x)
yield t
- print("Read {0:x} in {1:x} cycle(s)".format(t.data, t.latency))
+ print("{0}: Read {1:x} in {2} cycle(s)".format(n, t.data, t.latency))
+ assert(t.data == 0x1000*bank + 0x100*x)
class MyModel(lasmibus.TargetModel):
def read(self, bank, address):
- #print("read from bank {0} address {1}".format(bank, address))
- return 0x1000*bank + 0x200+address
+ r = 0x1000*bank + 0x100*address
+ #print("read from bank {0} address {1} -> {2:x}".format(bank, address, r))
+ return r
def write(self, bank, address, data, we):
print("write to bank {0} address {1:x} data {2:x}".format(bank, address, data))
+ assert(data == 0x1000*bank + 0x100*address)
class TB(Module):
def __init__(self):
- self.submodules.controller = lasmibus.Target(MyModel(), aw=4, dw=32, nbanks=4, read_latency=4, write_latency=1)
+ self.submodules.controller = lasmibus.Target(MyModel(), aw=4, dw=32, nbanks=4, req_queue_size=4,
+ read_latency=4, write_latency=1)
self.submodules.xbar = lasmibus.Crossbar([self.controller.bus], 4, 2)
self.initiators = [lasmibus.Initiator(my_generator(n), bus) for n, bus in enumerate(self.xbar.masters)]
self.submodules += self.initiators