Skip to content

Commit

Permalink
Add reset states to axi_atop_filter to fix zero time sim hang
Browse files Browse the repository at this point in the history
  • Loading branch information
uge authored and micprog committed Jul 18, 2024
1 parent 3e88ef2 commit 4b386fe
Showing 1 changed file with 10 additions and 6 deletions.
16 changes: 10 additions & 6 deletions src/axi_atop_filter.sv
Original file line number Diff line number Diff line change
Expand Up @@ -67,11 +67,11 @@ module axi_atop_filter #(
cnt_t w_cnt_d, w_cnt_q;

typedef enum logic [2:0] {
W_FEEDTHROUGH, BLOCK_AW, ABSORB_W, HOLD_B, INJECT_B, WAIT_R
W_RESET, W_FEEDTHROUGH, BLOCK_AW, ABSORB_W, HOLD_B, INJECT_B, WAIT_R
} w_state_e;
w_state_e w_state_d, w_state_q;

typedef enum logic [1:0] { R_FEEDTHROUGH, INJECT_R, R_HOLD } r_state_e;
typedef enum logic [1:0] { R_RESET, R_FEEDTHROUGH, INJECT_R, R_HOLD } r_state_e;
r_state_e r_state_d, r_state_q;

typedef logic [AxiIdWidth-1:0] id_t;
Expand Down Expand Up @@ -116,6 +116,8 @@ module axi_atop_filter #(
w_state_d = w_state_q;

unique case (w_state_q)
W_RESET: w_state_d = W_FEEDTHROUGH;

W_FEEDTHROUGH: begin
// Feed AW channel through if the maximum number of outstanding bursts is not reached.
if (complete_w_without_aw_downstream || (w_cnt_q.cnt < AxiMaxWriteTxns)) begin
Expand Down Expand Up @@ -238,7 +240,7 @@ module axi_atop_filter #(
end
end

default: w_state_d = W_FEEDTHROUGH;
default: w_state_d = W_RESET;
endcase
end
// Connect signals on AW and W channel that are not managed by the control FSM from slave port to
Expand Down Expand Up @@ -266,6 +268,8 @@ module axi_atop_filter #(
r_state_d = r_state_q;

unique case (r_state_q)
R_RESET: r_state_d = R_FEEDTHROUGH;

R_FEEDTHROUGH: begin
if (mst_resp_i.r_valid && !slv_req_i.r_ready) begin
r_state_d = R_HOLD;
Expand Down Expand Up @@ -301,7 +305,7 @@ module axi_atop_filter #(
end
end

default: r_state_d = R_FEEDTHROUGH;
default: r_state_d = R_RESET;
endcase
end
// Feed all signals on AR through.
Expand Down Expand Up @@ -329,9 +333,9 @@ module axi_atop_filter #(
if (!rst_ni) begin
id_q <= '0;
r_beats_q <= '0;
r_state_q <= R_FEEDTHROUGH;
r_state_q <= R_RESET;
w_cnt_q <= '{default: '0};
w_state_q <= W_FEEDTHROUGH;
w_state_q <= W_RESET;
end else begin
id_q <= id_d;
r_beats_q <= r_beats_d;
Expand Down

0 comments on commit 4b386fe

Please sign in to comment.