Improve output register filling

This commit is contained in:
Alex Forencich 2014-10-22 15:13:42 -07:00
parent d82ebcce17
commit 0b8a36d5e7

View File

@ -115,7 +115,7 @@ reg output_axis_tvalid_int;
reg output_axis_tready_int = 0; reg output_axis_tready_int = 0;
reg output_axis_tlast_int; reg output_axis_tlast_int;
reg output_axis_tuser_int; reg output_axis_tuser_int;
wire output_axis_tready_int_early = output_axis_tready; wire output_axis_tready_int_early;
reg input_axis_tready_reg = 0, input_axis_tready_next; reg input_axis_tready_reg = 0, input_axis_tready_next;
assign input_axis_tready = input_axis_tready_reg; assign input_axis_tready = input_axis_tready_reg;
@ -376,6 +376,9 @@ assign output_axis_tvalid = output_axis_tvalid_reg;
assign output_axis_tlast = output_axis_tlast_reg; assign output_axis_tlast = output_axis_tlast_reg;
assign output_axis_tuser = output_axis_tuser_reg; assign output_axis_tuser = output_axis_tuser_reg;
// enable ready input next cycle if output is ready or if there is space in both output registers or if there is space in the temp register that will not be filled next cycle
assign output_axis_tready_int_early = output_axis_tready | (~temp_axis_tvalid_reg & ~output_axis_tvalid_reg) | (~temp_axis_tvalid_reg & ~output_axis_tvalid_int);
always @(posedge clk or posedge rst) begin always @(posedge clk or posedge rst) begin
if (rst) begin if (rst) begin
output_axis_tdata_reg <= 0; output_axis_tdata_reg <= 0;
@ -391,8 +394,7 @@ always @(posedge clk or posedge rst) begin
temp_axis_tuser_reg <= 0; temp_axis_tuser_reg <= 0;
end else begin end else begin
// transfer sink ready state to source // transfer sink ready state to source
// also enable ready input next cycle if output is currently not valid and will not become valid next cycle output_axis_tready_int <= output_axis_tready_int_early;
output_axis_tready_int <= output_axis_tready | (~output_axis_tvalid_reg & ~output_axis_tvalid_int);
if (output_axis_tready_int) begin if (output_axis_tready_int) begin
// input is ready // input is ready
@ -418,6 +420,11 @@ always @(posedge clk or posedge rst) begin
output_axis_tvalid_reg <= temp_axis_tvalid_reg; output_axis_tvalid_reg <= temp_axis_tvalid_reg;
output_axis_tlast_reg <= temp_axis_tlast_reg; output_axis_tlast_reg <= temp_axis_tlast_reg;
output_axis_tuser_reg <= temp_axis_tuser_reg; output_axis_tuser_reg <= temp_axis_tuser_reg;
temp_axis_tdata_reg <= 0;
temp_axis_tkeep_reg <= 0;
temp_axis_tvalid_reg <= 0;
temp_axis_tlast_reg <= 0;
temp_axis_tuser_reg <= 0;
end end
end end
end end