caravel/verilog/dv/cocotb/tests/temp_partial_test/partial.py

47 lines
1.5 KiB
Python
Raw Normal View History

import random
import cocotb
from cocotb.triggers import FallingEdge,RisingEdge,ClockCycles
import cocotb.log
from cpu import RiskV
from defsParser import Regs
from cocotb.result import TestSuccess
from tests.common_functions.test_functions import *
from tests.bitbang.bitbang_functions import *
from caravel import GPIO_MODE
reg = Regs()
"""Testbench of GPIO configuration through bit-bang method using the StriVe housekeeping SPI."""
@cocotb.test()
@repot_test
async def temp_partial(dut):
caravelEnv = await test_configure(dut,timeout_cycles=70000)
# Apply data 0x1809 (management standard output) to first block of
# user 1 and user 2 (GPIO 0 and 37) bits 0, 1, 9, and 12 are "1" (data go in backwards)
cpu = RiskV(dut)
cpu.cpu_force_reset()
cpu.cpu_release_reset()
while True:
if cpu.read_debug_reg2() == 0xAA:
break
await ClockCycles(caravelEnv.clk,1)
cpu.cpu_force_reset()
await ClockCycles(caravelEnv.clk,100)
await cpu.drive_data2address(reg.get_addr('reg_wb_enable'),1)
await cpu.drive_data2address(reg.get_addr('reg_debug_1'),0xAA)
# await cpu.drive_data2address(reg.get_addr('reg_debug_2'),0xBB)
await cpu.drive_data2address(reg.get_addr('reg_mprj_datal'),0x0)
# await ClockCycles(caravelEnv.clk,100)
cpu.cpu_release_reset()
while True:
if cpu.read_debug_reg2() == 0xBB:
break
await ClockCycles(caravelEnv.clk,1)
await ClockCycles(caravelEnv.clk,100)