litex/test/test_icap.py
Florent Kermarrec 99f3498f2d cores/icap/ICAP: Add Register read capability.
Useful to get some internal status, ex the IDCode or know if the executed bistream
in a multiboot configuration is the operational or fallback one.
2021-10-04 17:22:57 +02:00

101 lines
2.7 KiB
Python

#
# This file is part of LiteX.
#
# Copyright (c) 2019-2021 Florent Kermarrec <florent@enjoy-digital.fr>
# SPDX-License-Identifier: BSD-2-Clause
import unittest
from migen import *
from litex.soc.cores.icap import *
# References ---------------------------------------------------------------------------------------
iprog_sequence = [
# csib rdwrb data
"0 0 0xaa995566",
"0 0 0x20000000",
"0 0 0x20000000",
"0 0 0x30008001",
"0 0 0x0000000f",
"0 0 0x20000000",
"0 0 0x20000000",
"0 0 0x30008001",
"0 0 0x0000000d",
"0 0 0x20000000",
"0 0 0x20000000",
]
bootsts_sequence = [
# csib rdwrb data
"0 0 0xaa995566",
"0 0 0x20000000",
"0 0 0x20000000",
"0 0 0x2802c001",
"0 0 0x20000000",
"0 0 0x20000000",
"1 1 0x20000000",
"0 1 0x20000000",
"0 1 0x20000000",
"0 1 0x20000000",
"0 1 0x20000000",
"0 0 0x30008001",
"0 0 0x0000000d",
"0 0 0x20000000",
"0 0 0x20000000",
]
# Test ICAP ----------------------------------------------------------------------------------------
class TestICAP(unittest.TestCase):
def test_icap_command_reload(self):
def generator(dut):
# Send IPROG Write Sequence.
yield dut.addr.eq(ICAPRegisters.CMD)
yield dut.write_data.eq(ICAPCMDs.IPROG)
yield dut.write.eq(1)
# Wait.
while not (yield dut.done):
yield
yield dut.write.eq(0)
# Delay
for i in range(16):
yield
# Send BOOTSTS Read Sequence.
yield dut.addr.eq(ICAPRegisters.BOOTSTS)
yield dut.read.eq(1)
# Wait.
while not (yield dut.done):
yield
yield dut.read.eq(0)
yield
def check(dut):
# Check IPROG Write Sequence.
while (yield dut._i) != ICAP_SYNC:
yield
for ref_w in iprog_sequence:
cur_w = f"{(yield dut._csib)} {(yield dut._rdwrb)} 0x{(yield dut._i):08x}"
self.assertEqual(ref_w, cur_w)
#print(cur_w)
yield
# Check BOOTSTS Read Sequence.
while (yield dut._i) != ICAP_SYNC:
yield
for ref_w in bootsts_sequence:
cur_w = f"{(yield dut._csib)} {(yield dut._rdwrb)} 0x{(yield dut._i):08x}"
self.assertEqual(ref_w, cur_w)
#print(cur_w)
yield
dut = ICAP(with_csr=False, simulation=True)
clocks = {"sys": 10, "icap": 10}
run_simulation(dut, [generator(dut), check(dut)], clocks, vcd_name="icap.vcd")
def test_icap_bitstream_syntax(self):
dut = ICAPBitstream(simulation=True)