1
0
forked from M-Labs/artiq

gateware/test/serwb: use unittest for in test_etherbone

This commit is contained in:
Florent Kermarrec 2017-08-29 17:31:01 +02:00
parent 7d7f6be7ce
commit 9ba50098a8

View File

@ -1,3 +1,6 @@
import unittest
import random
from migen import * from migen import *
from misoc.interconnect.wishbone import SRAM from misoc.interconnect.wishbone import SRAM
@ -25,7 +28,7 @@ class DUT(Module):
master_packetizer = packet.Packetizer() master_packetizer = packet.Packetizer()
self.submodules += master_depacketizer, master_packetizer self.submodules += master_depacketizer, master_packetizer
master_etherbone = etherbone.Etherbone(mode="master") master_etherbone = etherbone.Etherbone(mode="master")
master_sram = SRAM(1024, bus=master_etherbone.wishbone.bus) master_sram = SRAM(64, bus=master_etherbone.wishbone.bus)
self.submodules += master_etherbone, master_sram self.submodules += master_etherbone, master_sram
self.comb += [ self.comb += [
master_depacketizer.source.connect(master_etherbone.sink), master_depacketizer.source.connect(master_etherbone.sink),
@ -53,14 +56,15 @@ class DUT(Module):
self.wishbone = slave_etherbone.wishbone.bus self.wishbone = slave_etherbone.wishbone.bus
def main_generator(dut): class TestEtherbone(unittest.TestCase):
for i in range(8): def test_write_read_sram(self):
yield from dut.wishbone.write(0x100 + i, i)
for i in range(8):
data = (yield from dut.wishbone.read(0x100 + i))
print("0x{:08x}".format(data))
if __name__ == "__main__":
dut = DUT() dut = DUT()
run_simulation(dut, main_generator(dut), vcd_name="sim.vcd") prng = random.Random(1)
def generator(dut):
datas = [prng.randrange(0, 2**32-1) for i in range(16)]
for i in range(16):
yield from dut.wishbone.write(i, datas[i])
for i in range(16):
data = (yield from dut.wishbone.read(i))
self.assertEqual(data, datas[i])
run_simulation(dut, generator(dut))