From 5b0070ac0b45bc6960ae957c416d9a624185a70f Mon Sep 17 00:00:00 2001 From: Noah Boorstin Date: Fri, 22 Jan 2021 15:05:58 -0500 Subject: [PATCH] Start adding register checking I'm now realizing we need to simulate loads, or else these will all be wrong --- wally-pipelined/src/testbench-busybear.sv | 12 ++++++++ wally-pipelined/wally-busybear.do | 35 +++++++++++++++++++++++ 2 files changed, 47 insertions(+) diff --git a/wally-pipelined/src/testbench-busybear.sv b/wally-pipelined/src/testbench-busybear.sv index 5f8880b5e..2e4638d17 100644 --- a/wally-pipelined/src/testbench-busybear.sv +++ b/wally-pipelined/src/testbench-busybear.sv @@ -44,10 +44,22 @@ module testbench_busybear #(parameter XLEN=64, MISA=32'h00000104, ZCSR = 1, ZCOU // //end // end end + logic [63:0] rfExpected[31:1]; + logic [63:0] pcExpected; always @(PCF) begin //$display("%x", PCF); scan_file = $fscanf(data_file, "%x\n", InstrF); + for(int i=1; i < 32; i++) begin + scan_file = $fscanf(data_file, "%x\n", rfExpected[i]); + end + scan_file = $fscanf(data_file, "%x\n", pcExpected); + //check things! + if (PCF != pcExpected) begin + $display("PC does not equal PC expected: %x, %x", PCF, pcExpected); + end + + //$display("%x", InstrF); end diff --git a/wally-pipelined/wally-busybear.do b/wally-pipelined/wally-busybear.do index 259358cba..259bf02d1 100644 --- a/wally-pipelined/wally-busybear.do +++ b/wally-pipelined/wally-busybear.do @@ -40,8 +40,43 @@ view wave add wave /testbench_busybear/clk add wave /testbench_busybear/reset add wave -divider +add wave -hex /testbench_busybear/pcExpected add wave -hex /testbench_busybear/dut/dp/PCF add wave -hex /testbench_busybear/dut/dp/InstrF +add wave -divider +# registers! +add wave -hex /testbench_busybear/rfExpected +add wave -hex /testbench_busybear/dut/dp/regf/rf[1] +add wave -hex /testbench_busybear/dut/dp/regf/rf[2] +add wave -hex /testbench_busybear/dut/dp/regf/rf[3] +add wave -hex /testbench_busybear/dut/dp/regf/rf[4] +add wave -hex /testbench_busybear/dut/dp/regf/rf[5] +add wave -hex /testbench_busybear/dut/dp/regf/rf[6] +add wave -hex /testbench_busybear/dut/dp/regf/rf[7] +add wave -hex /testbench_busybear/dut/dp/regf/rf[8] +add wave -hex /testbench_busybear/dut/dp/regf/rf[9] +add wave -hex /testbench_busybear/dut/dp/regf/rf[10] +add wave -hex /testbench_busybear/dut/dp/regf/rf[11] +add wave -hex /testbench_busybear/dut/dp/regf/rf[12] +add wave -hex /testbench_busybear/dut/dp/regf/rf[13] +add wave -hex /testbench_busybear/dut/dp/regf/rf[14] +add wave -hex /testbench_busybear/dut/dp/regf/rf[15] +add wave -hex /testbench_busybear/dut/dp/regf/rf[16] +add wave -hex /testbench_busybear/dut/dp/regf/rf[17] +add wave -hex /testbench_busybear/dut/dp/regf/rf[18] +add wave -hex /testbench_busybear/dut/dp/regf/rf[19] +add wave -hex /testbench_busybear/dut/dp/regf/rf[20] +add wave -hex /testbench_busybear/dut/dp/regf/rf[21] +add wave -hex /testbench_busybear/dut/dp/regf/rf[22] +add wave -hex /testbench_busybear/dut/dp/regf/rf[23] +add wave -hex /testbench_busybear/dut/dp/regf/rf[24] +add wave -hex /testbench_busybear/dut/dp/regf/rf[25] +add wave -hex /testbench_busybear/dut/dp/regf/rf[26] +add wave -hex /testbench_busybear/dut/dp/regf/rf[27] +add wave -hex /testbench_busybear/dut/dp/regf/rf[28] +add wave -hex /testbench_busybear/dut/dp/regf/rf[29] +add wave -hex /testbench_busybear/dut/dp/regf/rf[30] +add wave -hex /testbench_busybear/dut/dp/regf/rf[31] #add wave /testbench_busybear/InstrFName ##add wave -hex /testbench_busybear/dut/dp/PCD #add wave -hex /testbench_busybear/dut/dp/InstrD