名称:FIFO存储器设计1024*8bit
软件:Quartus
语言:Verilog
本代码为FIFO通用代码,其他深度和位宽可简单修改以下参数得到
reg [7:0] ram [1023:0];//RAM。深度1024,宽度8
代码功能:
设计一个基于FPGA的FIFO存储器,使之能提供以下功能
1.存储空间至少1024 储器
2.存储位宽8bit
3.拓展功能:存储器空、满报警
演示视频:http://www.hdlcode.com/index.php?m=home&c=View&a=index&aid=206
FPGA代码资源下载网:hdlcode.com
代码下载:
部分代码展示
//fifo 1024*8bit fifo
//存储空间1024
//位宽8bit
module a_fifo
(
input clk,//时钟
input rst,//复位
input [7:0] din,//fifo写数据
input wr_en,//写使能
input rd_en,//读使能
output reg [7:0] dout,//读数据
output empty,//空信号
output full//满信号
);
reg [7:0] ram [1023:0];//RAM。深度1024,宽度8
reg [11:0] count=12'd0;
reg [11:0] rp=12'd0;
reg [11:0] wp=12'd0;
integer i;
always@(posedge clk)
if(rst)begin//复位
wp<=12'd0;
rp<=12'd0;
dout<=8'd0;
count<=12'd0;
for(i=0;i<1024;i=i+1)
ram[i]<=8'b00000000;//清零
end
else
case({rd_en,wr_en})
2'b00:count<=count;
2'b01://单写FIFO
if(~full)begin//未满
ram[wp]<=din;//存入fifo
if(wp>=12'd1023)
wp<=12'd0;//写地址循环累加
else
wp<=wp+12'd1;
count<=count+12'd1;
rp<=rp;
end
2'b10://单读FIFO
if(~empty)begin//未空
dout<=ram[rp];//读fifo
if(rp>=12'd1023)
rp<=12'd0;//读地址循环累加
else
rp<=rp+12'd1;
count<=count-12'd1;
end
2'b11://同时读写FIFO
if(empty)begin//FIFO为空,只能写
设计文档:
- 工程文件
data:image/s3,"s3://crabby-images/c8ed4/c8ed45145d20ed2ea75aecdeb21f817fac219168" alt=""
- 程序文件
data:image/s3,"s3://crabby-images/b5ebb/b5ebbc56f98d6f72a34776e6b86795105d590456" alt=""
- 程序编译
data:image/s3,"s3://crabby-images/529bc/529bce6dee6cfec71695dad03c9457855f9c1a80" alt=""
- Testebnch
data:image/s3,"s3://crabby-images/11b82/11b82eadf377afd78d30800676acc2f5acdded9b" alt=""
data:image/s3,"s3://crabby-images/e7260/e72605cf83e6e6d953e2115f143b5292ae66ff9d" alt=""
- 仿真图
仿真图依次仿真了如下功能:
data:image/s3,"s3://crabby-images/eaa0b/eaa0b676269ae9fcbc0bcd218e934944419c6791" alt=""
具体功能1/2/3对应如下:
1:写FIFO 20次,再读20次,FIFO读空
data:image/s3,"s3://crabby-images/270d4/270d4912c1742c485718c4fdca745a8e695d857a" alt=""
- 写FIFO 10次,然后同时读写20次,最后读10次,FIFO读空
data:image/s3,"s3://crabby-images/cbe91/cbe91a69fdeb769455b5b0a8446ef81f980c52a4" alt=""
- 连续写FIFO 2048次,FIFO写满
data:image/s3,"s3://crabby-images/1394a/1394aec803207396d205a4c654cfa78d1a9b11d7" alt=""