module one_to_two #(
parameter WORD_LEN = 33
)
(
input clk,
input arst,
input [WORD_LEN-1:0] i_din,
input i_din_valid,
output o_din_ready,
output [2*WORD_LEN-1:0] o_dout,
input i_dout_ready,
output o_dout_valid
);
reg [WORD_LEN * 2 - 1 : 0] store_data;
reg [1 : 0] dat_cnt;
always @(posedge clk or negedge arst)
if(!arst)
store_data <= {2*WORD_LEN{1'b0}};
else if(i_din_valid && o_din_ready)
store_data <= {store_data[WORD_LEN - 1 : 0],i_din};
always @(posedge clk or negedge arst)
if(!arst)
dat_cnt <= 2'd0;
else if(i_dout_ready && o_dout_valid)
dat_cnt <= 2'd0;
else if(i_din_valid && o_din_ready)
dat_cnt <= dat_cnt + 2'd1;
assign o_dout = (dat_cnt == 2'd2) ?store_data : {store_data[WORD_LEN - 1 : 0],i_din};
assign o_din_ready = dat_cnt == 2'd0 || (dat_cnt == 2'd1 && i_dout_ready);
assign o_dout_valid = dat_cnt == 2'd2 || (dat_cnt == 2'd1 && i_din_valid);文章来源:https://www.toymoban.com/news/detail-647933.html
endmodule文章来源地址https://www.toymoban.com/news/detail-647933.html
到了这里,关于握手信号输入一倍,输出两倍[verilog]的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!