软件:Quartus
语言:Verilog
代码功能:
同步FIFO设计。
内容及要求:
完成3bit宽、360深的同步FIFO。
(2)输入数据片内生成,输出侧由ISA时序读操作进行;
(3)满、空指示驱动LED;
(4)SRAM双口;
(5)读写信号同步于工作时钟,工作时钟100M;
(6)使用实验室的开发箱或自备开发板完成设计;
(7)完成全部流程:设计规范文档、模块设计、代码输入、功能仿真、约束与综合、时序仿真、下载验证等。
FPGA代码Verilog/VHDL代码资源下载:www.hdlcode.com
演示视频:
设计文档:
1. 工程文件
2. 程序文件
3. 程序编译
4. RTL图
5. 模块图
6. Testebnch
7. 仿真图
仿真图依次仿真了如下功能:
具体功能1/2/3对应如下:
1.写FIFO 4次,再读4次,FIFO读空
2.写FIFO 350次,然后同时读写5次,最后读5次,FIFO剩余345个空间
3.连续写FIFO 15次,FIFO写满
部分代码展示:
//fifo testbench
module fifo_test();
reg clk;
reg rst_n;
reg [2:0] data_in;
reg wr_en;
reg rd_en;
wire empty;
wire full;
wire [2:0] data_out;//读数据
//FIFO深度为360,数据宽度为3
fifo_top i_fifo_top
(
. clk (clk ),//时钟
. rst_n (rst_n ),//复位
. data_in (data_in ),//fifo写数据
. wr_en (wr_en),//写使能
. rd_en (rd_en),//读使能
. data_out (data_out ),//读数据
. empty (empty),//空信号
. full (full ) //满信号
);
initial begin
$monitor("empty=%b , full=%b", empty,full);//检测空满信号
end
initial begin
rst_n=0;
data_in='d0;
wr_en=0;
rd_en=0;
#100;
rst_n=1;
#100;
repeat(4)begin//写4次
data_in=data_in+'d1;
wr_en=1;
#20;
wr_en=0;
#1000;
end
#100;
repeat(4)begin//读4次
rd_en=1;
#20;
rd_en=0;
#1000;
end
repeat(350)begin//写350次
data_in=data_in+'d1;
wr_en=1;
#20;
wr_en=0;
#1000;
end
repeat(5)begin//读写5次
data_in=data_in+'d1;
wr_en=1;
rd_en=1;
#20;
wr_en=0;
rd_en=0;
#1000;
end
#100;
repeat(5)begin//读5次
rd_en=1;
#20;
rd_en=0;
#1000;
end
repeat(15)begin//写15次
data_in=data_in+64'd1;
wr_en=1;
#20;
wr_en=0;
#1000;
end
end
//产生时钟
always begin
clk=1;
#10;
clk=0;
#10;
end
endmodule
点击链接获取代码文件:http://www.hdlcode.com/index.php?m=home&c=View&a=index&aid=408
879