Skip to content

Commit

Permalink
id_queue: Add parameter to cut a critical path (#220)
Browse files Browse the repository at this point in the history
With the parameter enabled, cut the path from the output pop and the
input gnt with minimal impact to buffering.
  • Loading branch information
micprog authored Apr 19, 2024
1 parent 7773d97 commit bf98ae5
Showing 1 changed file with 4 additions and 2 deletions.
6 changes: 4 additions & 2 deletions src/id_queue.sv
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ module id_queue #(
parameter int ID_WIDTH = 0,
parameter int CAPACITY = 0,
parameter bit FULL_BW = 0,
parameter bit CUT_OUP_POP_INP_GNT = 0,
parameter type data_t = logic[31:0],
// Dependent parameters, DO NOT OVERRIDE!
localparam type id_t = logic[ID_WIDTH-1:0]
Expand Down Expand Up @@ -185,8 +186,9 @@ module id_queue #(
// Data potentially freed by the output.
assign oup_data_free_idx = head_tail_q[match_out_idx].head;

// Data can be accepted if the linked list pool is not full, or some data is simultaneously.
assign inp_gnt_o = ~full || (oup_data_popped && FULL_BW);
// Data can be accepted if the linked list pool is not full, or if some data is simultaneously
// popped (given FULL_BW & !CUT_OUP_POP_INP_GNT).
assign inp_gnt_o = ~full || (oup_data_popped && FULL_BW && ~CUT_OUP_POP_INP_GNT);
always_comb begin
match_in_id = '0;
match_out_id = '0;
Expand Down

0 comments on commit bf98ae5

Please sign in to comment.