srl16e fifo verilog

复制代码
 1 module srl16e_fifo ( clk, datain, wr, dataout, rd, fullness);
 2   parameter WIDTH = 8;
 3 
 4   input clk;
 5   input [WIDTH-1:0] datain;
 6   input wr;
 7   output [WIDTH-1:0] dataout;
 8   input rd;
 9   output reg [4:0] fullness;
10 
11   always @(posedge clk)
12   begin
13     fullness <= (fullness + wr - rd);
14   end
15   wire [3:0] readaddr = (fullness - 1);
16 
17   genvar i;
18 
19   generate
20     for (i = 0; i < WIDTH; i=i+1) begin : srl16
21       SRL16E fifo16(
22         .CLK(clk),
23         .CE(wr),
24         .D(datain[i]),
25         .A0(readaddr[0]),
26         .A1(readaddr[1]),
27         .A2(readaddr[2]),
28         .A3(readaddr[3]),
29         .Q(dataout[i]));
30     end
31   endgenerate
32 
33 endmodule
复制代码
posted @   IAmAProgrammer  阅读(723)  评论(0编辑  收藏  举报
(评论功能已被禁用)
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
点击右上角即可分享
微信分享提示