FPGA的FIFO

1,FPGA 使用的 FIFO 一般指的是对数据的存储具有 先进先出特性的一个缓存器,常被用于数据的缓存或者高速异步数据的交互,也即所谓的跨时钟域信号传 递。比如由于高速ADC的采样速度可能较高,所以将采集到的数据暂存FIFO,然后再读出进行数据处理。

2,FIFO 从输入时钟的角度来分,有两种类型:单时钟 FIFO(SCFIFO)和双时钟****FIFO( DCFIFO),其 中双时钟 FIFO 又可从输出数据的位宽的角度分为普通双时钟(DCFIFO)和混合宽度双时钟 FIFO (DCFIFO_MIXED_WIDTHS)。
3,FPGA可以根据用户配置,生成FIFO,产生一个fifo.v 文件,生成的FIFO默认引脚如下图,后面我们就可以依据这些引脚来操作FIFO。

4,在双时钟 FIFO 的符号图中,位于图中上侧部分的以**"**data"和 "wr "开头的信号为与写相关的所有信号,位于中间部分的"q"和以" rd"开头的信号为与读相关的所有 信号,位于底部的aclr为异步清零信号。
5,对于 FIFO 需要了解一些常见参数:
FIFO 的宽度: FIFO 一次读写操作的数据位 N ;
FIFO 的深度: FIFO 可以存储多少个宽度为 N 位的数据。
空标志:对于双时钟 FIFO 又分为读空标志 rdempty 和写空标志 wrempty 。 FIFO 已空或将要空时由 FIFO 的状态电路送出的一个信号,以阻止 FIFO 的读操作继续从 FIFO 中读出数据而造成无效数据的读出。
满标志:对于双时钟 FIFO 又分为读满标志 rdfull 和写满标志 wrfull 。 FIFO 已满或将要写满时由 FIFO 的状态电路送出的一个信号,以阻止 FIFO 的写操作继续向 FIFO 中写数据而造成溢出。
读时钟:读 FIFO 时所遵循的时钟,在每个时钟的上升沿触发。
写时钟:写 FIFO 时所遵循的时钟,在每个时钟的上升沿触发。

//wire define
wire wrreq ; // 写请求信号
wire [7:0] data ; // 写入 FIFO 的数据
wire wrempty ; // 写侧空信号
wire wrfull ; // 写侧满信号
wire wrusedw ; // 写侧 FIFO 中的数据量

wire rdreq ; // 读请求信号
wire [7:0] q ; // 从 FIFO 输出的数据
wire rdempty ; // 读侧空信号
wire rdfull ; // 读侧满信号
wire rdusedw ; // 读侧 FIFO 中的数据量

6,依据原子的fpga开发板, 代码中例化 fifo 模块、写 FIFO 模块 wr_fifo 、读 FIFO 模块 rd_fifo, 各模块的信号连接图如下图所示:

7,

相关推荐
csdn_gddf10238439820 分钟前
XY2-100的Verilog实现
fpga开发
沐欣工作室_lvyiyi4 小时前
基于fpga的数字频率计(论文+源码)
stm32·单片机·深度学习·物联网·fpga开发·毕业设计
9527华安13 小时前
FPGA实现UltraScale GTH光口视频转USB3.0传输,基于FT601+Aurora 8b/10b编解码架构,提供2套工程源码和技术支持
fpga开发·音视频·aurora·8b/10b·usb3.0·ft601·ultrascale gth
fei_sun13 小时前
【FPGA】模型机下载FPGA设计
fpga开发
晓晓暮雨潇潇1 天前
FPGA开发技能(10)热电偶测温ADS1118方案
fpga开发·verilog·热电偶·ads1118·温度测试方案
zidan14122 天前
XILINX硬件设计-(1)LVDS接口总结
fpga开发
啄缘之间2 天前
verilog练习:i2c slave 模块设计
学习·fpga开发·verilog·uvm
nature_forest2 天前
quartus24.1版本子模块因时钟问题无法综合通过,FPGA过OOC问题复盘
fpga开发
hi943 天前
Versal - Petalinux 2024.2(下载与安装+VD100+安装JupyterLab+SD卡分区+SDT流程)
linux·fpga开发·petalinux·versal soc
博览鸿蒙3 天前
想成为FPGA工程师需要学什么?主要工作内容是什么?
fpga开发