当前位置: 首页 > article >正文

FPGA的FIFO

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

2,FIFO 从输入时钟的角度来分,有两种类型:单时钟 FIFOSCFIFO)和双时钟 FIFODCFIFO),其 中双时钟 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,


http://www.kler.cn/a/463073.html

相关文章:

  • Niushop商城商业插件_cps联盟_包装转换_视频购物_同城配送_上门预约等插件的安装方法
  • NCCL源码解读3.1:double binary tree双二叉树构建算法,相比ring环算法的优势
  • Docker入门常用命令总结
  • 【C语言】_指针运算
  • Yocto项目 - 详解PACKAGECONFIG机制
  • Android 第三方框架:网络框架:OkHttp:源码分析:缓存
  • 数据挖掘——认识数据
  • SQL-Server链接服务器访问Oracle数据
  • 【蓝桥杯】:蓝桥杯之路径之谜
  • 机器人C++开源库The Robotics Library (RL)使用手册(四)
  • 关于ElasticSearch
  • 搭建医疗产品行业知识中台的手册
  • 深度学习在文本情感分析中的应用
  • 基于Redis的分布式锁
  • easybox
  • 【YashanDB知识库】hive初始化崖山报错YAS-04209
  • 万里数据库GreatSQL监控解析
  • 永嘉县瓯北六小:庆元旦,献爱心,让新永嘉人在童装节中找到归属感!
  • Golang学习历程【第五篇 复合数据类型:数组切片】
  • ShardingSphere-Proxy分表场景测试案例
  • CPT203 Software Engineering 软件工程 Pt.4 软件设计(中英双语)
  • Spring 核心技术解析【纯干货版】- II:Spring 基础模块 Spring-Beans 模块精讲
  • pyside6总结
  • 网络编程原理:回显服务器与客户端通信交互功能
  • Day20:逻辑运算
  • 30.Marshal.AllocHGlobal C#例子