From: Luke Kenneth Casson Leighton Date: Thu, 30 Jul 2020 09:39:43 +0000 (+0100) Subject: ha! found source of XICS test bug: wishbone stb was being left HI X-Git-Tag: semi_working_ecp5~488 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=63eba0f286fb6ea4717db37aa6d5491a4c22700c;p=soc.git ha! found source of XICS test bug: wishbone stb was being left HI for more than one cycle in the *unit* test, thereby putting spurious data onto the bus and corrupting transactions --- diff --git a/src/soc/interrupts/xics.py b/src/soc/interrupts/xics.py index 3bcb1ceb..3cf2a129 100644 --- a/src/soc/interrupts/xics.py +++ b/src/soc/interrupts/xics.py @@ -401,6 +401,7 @@ def wb_write(dut, addr, data, sel=True): if ack: break yield # loop until ack + yield dut.bus.stb.eq(0) # drop stb so only 1 thing into pipeline # leave cyc/stb valid for 1 cycle while writing yield @@ -430,6 +431,7 @@ def wb_read(dut, addr, sel=True): if ack: break yield # loop until ack + yield dut.bus.stb.eq(0) # drop stb so only 1 thing into pipeline # get data on same cycle that ack raises data = yield dut.bus.dat_r @@ -512,8 +514,6 @@ def sim_xics_icp(dut): yield from wb_write(dut, XIRR, data) print ("xirr written", hex(data), bin(data)) - assert (yield dut.core_irq_o) == 0 # write takes 1 cycle to propagate - yield # wait for it... assert (yield dut.core_irq_o) == 1 # ok *now* it should be set # read wb XIRR_POLL @@ -521,17 +521,11 @@ def sim_xics_icp(dut): print ("xirr poll", hex(data), bin(data)) assert (yield dut.core_irq_o) == 1 # should not clear - yield # XXX only works if there is a 2-clock delay between POLL and XIRR - yield - # read wb XIRR (8-bit) data = yield from wb_read(dut, XIRR, False) print ("xirr", hex(data), bin(data)) - yield assert (yield dut.core_irq_o) == 1 # should not clear - yield - # read wb XIRR (32-bit) data = yield from wb_read(dut, XIRR) print ("xirr", hex(data), bin(data)) @@ -596,8 +590,7 @@ def sim_xics(icp, ics): # raise XIVE 1 (just for fun) yield ics.int_level_i.eq(1<<1) - yield - yield + yield # wait for interrupt to propagate through from ics to icp... # read XIVE1 data = yield from wb_read(ics, 0x804) @@ -635,9 +628,6 @@ def sim_xics(icp, ics): yield from wb_write(ics, 0x804, data) print ("XIVE1 priority written", hex(data), bin(data)) - yield - yield - ###################### # write XIRR data = 0xfe @@ -646,9 +636,6 @@ def sim_xics(icp, ics): assert (yield icp.core_irq_o) == 1 # ok *now* it should be set - yield - yield - # read wb XIRR (32-bit) data = yield from wb_read(icp, XIRR) print ("xirr", hex(data), bin(data))