From 05d4f2d33d5721626ea4db1519c43ddcd7d706f0 Mon Sep 17 00:00:00 2001 From: Noah Boorstin Date: Mon, 25 Jan 2021 19:45:26 -0500 Subject: [PATCH] fix speculation ignoring for PC fetching --- wally-pipelined/regression/wally-busybear.do | 3 +++ .../testbench/testbench-busybear.sv | 24 +++++++++++-------- 2 files changed, 17 insertions(+), 10 deletions(-) diff --git a/wally-pipelined/regression/wally-busybear.do b/wally-pipelined/regression/wally-busybear.do index 967ea6eda..cd834b6af 100644 --- a/wally-pipelined/regression/wally-busybear.do +++ b/wally-pipelined/regression/wally-busybear.do @@ -43,6 +43,9 @@ 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 /testbench_busybear/lastInstrF +add wave /testbench_busybear/speculative +add wave /testbench_busybear/lastPC2 add wave -divider # registers! add wave -hex /testbench_busybear/rfExpected diff --git a/wally-pipelined/testbench/testbench-busybear.sv b/wally-pipelined/testbench/testbench-busybear.sv index d848554cc..fd41f9d3b 100644 --- a/wally-pipelined/testbench/testbench-busybear.sv +++ b/wally-pipelined/testbench/testbench-busybear.sv @@ -115,22 +115,26 @@ module testbench_busybear(); end end - logic speculative, nextSpec; + logic speculative; initial begin speculative = 0; - nextSpec = 0; + speculative = 0; end + logic [63:0] lastInstrF, lastPC, lastPC2; integer instrs; initial begin instrs = 0; end always @(PCF) begin - speculative <= nextSpec; - if (speculative) begin - nextSpec <= (PCF != pcExpected); + lastInstrF = InstrF; + lastPC <= PCF; + lastPC2 <= lastPC; + if (speculative && lastPC != pcExpected) begin + speculative = (PCF != pcExpected); end - if (~speculative) begin + else begin + //if (~speculative) begin // first read instruction scan_file_PC = $fscanf(data_file_PC, "%x\n", InstrF); // then expected PC value @@ -142,17 +146,17 @@ module testbench_busybear(); $stop; end // are we at a branch/jump? - case (InstrF[6:0]) //todo: add C versions of these + case (lastInstrF[6:0]) //todo: add C versions of these 7'b1101111, //JAL 7'b1100111, //JALR 7'b1100011: //B - nextSpec <= 1; + speculative = 1; default: - nextSpec <= 0; + speculative = 0; endcase //check things! - if ((~nextSpec) && (PCF !== pcExpected)) begin + if ((~speculative) && (PCF !== pcExpected)) begin $display("%t ps: PC does not equal PC expected: %x, %x", $time, PCF, pcExpected); // $stop; end