利用双fifo实现3个数值相加。实现10排0-85 每三排的数实现竖直相加。FPGA——双fifo的使用

module fifo(
input wire clk ,
input wire rst_n ,
input wire[7:0] dina ,
input wire wr_en ,
output reg[7:0] douta ,
output reg flag ,
output wire full1 ,
output wire empty1 ,
output wire full2 ,
output wire empty2
);
reg[6:0] cnt_r;
reg rd_en1;
reg rd_en2;
reg wr_en1;
reg wr_en2;
reg[3:0] row;
wire[7:0] douta1;
wire[7:0] douta2;
parameter ROW_MAX=10;
parameter CNT_R_MAX=85;
[email protected](posedge clk or negedge rst_n)
if(rst_n==0)
cnt_r<= 7’b0;
else if(cnt_r==CNT_R_MAX&&wr_en==1)
cnt_r<= 7’b0;
else if(wr_en==1)
cnt_r <= cnt_r +7’b1;

[email protected](posedge clk or negedge rst_n)
if(rst_n==0)
row <= 0;
else if(row==ROW_MAX)
row <= 0;
else if(cnt_r==CNT_R_MAX&&wr_en==1)
row <= row + 1;

[email protected](posedge clk or negedge rst_n)
if(rst_n==0)
wr_en1 <= 0;
else if(row>=0&&row<=ROW_MAX-2)
wr_en1 <= wr_en;
else
wr_en1 <= 0;

[email protected](posedge clk or negedge rst_n)
if(rst_n==0)
rd_en1 <= 0;
else if(row>=1&&row<=ROW_MAX-1)
rd_en1 <= wr_en;
else
rd_en1 <= 0;
reg wr_en2_dly;
[email protected](posedge clk or negedge rst_n)
if(rst_n==0)
wr_en2_dly <= 0;
else if(row>=1&&row

相关文章: