From a6ffb4cef31a71d48f3110050838f017113b6d85 Mon Sep 17 00:00:00 2001 From: Ross Thompson Date: Wed, 21 Dec 2022 09:18:00 -0600 Subject: [PATCH] Added timeout check to testbench. A watchdog checks the value of PCW. If it does not change within 1M cycles immediately stop simulation and report an error. --- pipelined/testbench/testbench.sv | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/pipelined/testbench/testbench.sv b/pipelined/testbench/testbench.sv index bd1f4bb66..030f348d5 100644 --- a/pipelined/testbench/testbench.sv +++ b/pipelined/testbench/testbench.sv @@ -428,6 +428,27 @@ logic [3:0] dummy; end end end + + // check for hange up. + logic [`XLEN-1:0] OldPCW; + integer WatchDogTimerCount; + localparam WatchDogTimerThreshold = 1000000; + logic WatchDogTimeOut; + always_ff @(posedge clk) begin + OldPCW <= PCW; + if(OldPCW == PCW) WatchDogTimerCount = WatchDogTimerCount + 1'b1; + else WatchDogTimerCount = '0; + end + + always_comb begin + WatchDogTimeOut = WatchDogTimerCount >= WatchDogTimerThreshold; + if(WatchDogTimeOut) begin + $display("FAILURE: Watch Dog Time Out triggered. PCW stuck at %x for more than %d cycles", PCW, WatchDogTimerCount); + $stop; + end + end + + endmodule module riscvassertions;