From 7bd59d3b03257687f82bbdf6aa5c6f9f2a6414c7 Mon Sep 17 00:00:00 2001 From: Steve Hoover Date: Wed, 12 Aug 2020 21:23:13 -0400 Subject: [PATCH] Fixed speculative use of packet head/tail that should have been non-speculative (presumably). --- warp-v.tlv | 12 +++++++----- warp-v_includes | 2 +- 2 files changed, 8 insertions(+), 6 deletions(-) diff --git a/warp-v.tlv b/warp-v.tlv index aa28ad63..3b3e6e34 100644 --- a/warp-v.tlv +++ b/warp-v.tlv @@ -954,7 +954,7 @@ m4+definitions([' ']) \SV m4_ifexpr(M4_CORE_CNT > 1, ['m4_include_lib(['https://raw.githubusercontent.com/stevehoover/tlv_flow_lib/4bcf06b71272556ec7e72269152561902474848e/pipeflow_lib.tlv'])']) - m4_ifelse(M4_ISA, ['RISCV'], ['m4_include_lib(['https://raw.githubusercontent.com/stevehoover/warp-v_includes/7e3109c23ea22e36bca8ae93faaa463037b40483/risc-v_defs.tlv'])']) + m4_ifelse(M4_ISA, ['RISCV'], ['m4_include_lib(['https://raw.githubusercontent.com/stevehoover/warp-v_includes/5100bc4424dd272ffd495dcb7d9653fb6b200e88/risc-v_defs.tlv'])']) @@ -3294,9 +3294,10 @@ m4+definitions([' $pkt_wr_blocked = $is_pkt_wr && |egress_in/skid_buffer>>1$push_blocked; @1 $valid_pkt_wr = $is_pkt_wr && $commit; - $insert_header = |egress_in/skid_buffer$is_pkt_wr && ! $InPacket; + $valid_pkt_tail = $valid_pkt_wr && $is_csr_pkttail; + $insert_header = |egress_in/skid_buffer$valid_pkt_wr && ! $InPacket; // Assert after inserting header up to insertion of tail. - $InPacket <= $insert_header || ($InPacket && ! (|egress_in/skid_buffer$is_csr_pkttail && ! |egress_in/skid_buffer$push_blocked)); + $InPacket <= $insert_header || ($InPacket && ! (|egress_in/skid_buffer$valid_pkt_tail && ! |egress_in/skid_buffer$push_blocked)); @1 /skid_buffer @@ -3304,7 +3305,7 @@ m4+definitions([' // Hold the write if blocked, including the write of the header in separate signals. // This give 1 cycle of slop so we have time to check validity and generate a replay if blocked. // Note that signals in this scope are captured versions reflecting the flit and its producing instruction. - $push_blocked = $valid_pkt_wr && (/_cpu/vc[$csr_pktwrvc]|egress_in$blocked || ! |egress_in/instr$InPacket); + $push_blocked = $valid_pkt_wr && (/_cpu/vc[$vc]|egress_in$blocked || ! |egress_in/instr$InPacket); // Header // Construct header flit. $src[M4_CORE_INDEX_RANGE] = #m4_strip_prefix(/_cpu); @@ -3314,8 +3315,9 @@ m4+definitions([' $csr_pktdest[m4_echo(M4_CORE_INDEX_RANGE)] }; /flit + // TODO. ADD a WHEN condition. {$tail, $flit[M4_WORD_RANGE]} = |egress_in/instr$insert_header ? {1'b0, |egress_in/skid_buffer$header_flit} : - {|egress_in/skid_buffer$is_csr_pkttail, |egress_in/skid_buffer$csr_wr_value}; + {|egress_in/skid_buffer$valid_pkt_tail, |egress_in/skid_buffer$csr_wr_value}; /vc[*] |egress_in @1 diff --git a/warp-v_includes b/warp-v_includes index 7e3109c2..5100bc44 160000 --- a/warp-v_includes +++ b/warp-v_includes @@ -1 +1 @@ -Subproject commit 7e3109c23ea22e36bca8ae93faaa463037b40483 +Subproject commit 5100bc4424dd272ffd495dcb7d9653fb6b200e88