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

FIFO学习记录

1https://blog.csdn.net/HouQi02/article/details/51683635
深入理解FIFO(包含有FIFO深度的解释)
FIFO:
一、先入先出队列(First Input First Output,FIFO)这是一种传统的按序执行方法,先进入的指令先完成并引退,跟着才执行第二条指令。
1.什么是FIFO?
FIFO是英文First In First Out 的缩写,是一种先进先出的数据缓存器,他与普通存储器的区别是没有外部读写地址线,这样使用起来非常简单,但缺点就是只能顺序写入数据,顺序的读出数据,其数据地址由内部读写指针自动加1完成,不能像普通存储器那样可以由地址线决定读取或写入某个指定的地址。
2.什么情况下用FIFO?
FIFO一般用于不同时钟域之间的数据传输,比如FIFO的一端时AD数据采集,另一端时计算机的PCI总线,假设其AD采集的速率为16位 100K SPS,那么每秒的数据量为100K×16bit=1.6Mbps,而PCI总线的速度为33MHz,总线宽度32bit,其最大传输速率为1056Mbps,在两个不同的时钟域间就可以采用FIFO来作为数据缓冲。另外对于不同宽度的数据接口也可以用FIFO,例如单片机位8位数据输出,而DSP可能是16位数据输入,在单片机与DSP连接时就可以使用FIFO来达到数据匹配的目的。
3.FIFO的一些重要参数
FIFO的宽度:也就是英文资料里常看到的THE WIDTH,它只的是FIFO一次读写操作的数据位,就像MCU有8位和16位,ARM 32位等等,FIFO的宽度在单片成品IC中是固定的,也有可选择的,如果用FPGA自己实现一个FIFO,其数据位,也就是宽度是可以自己定义的。
FIFO的深度:THE DEEPTH,它指的是FIFO可以存储多少个N位的数据(如果宽度为N)。如一个8位的FIFO,若深度为8,它可以存储8个8位的数据,深度为12 ,就可以存储12个8位的数据,FIFO的深度可大可小,个人认为FIFO深度的计算并无一个固定的公式。在FIFO实际工作中,其数据的满/空标志可以控制数据的继续写入或读出。在一个具体的应用中也不可能由一些参数算数精确的所需FIFO深度为多少,这在写速度大于读速度的理想状态下是可行的,但在实际中用到的FIFO深度往往要大于计算值。一般来说根据电路的具体情况,在兼顾系统性能和FIFO成本的情况下估算一个大概的宽度和深度就可以了。而对于写速度慢于读速度的应用,FIFO的深度要根据读出的数据结构和读出数据的由那些具体的要求来确定。
满标志:FIFO已满或将要满时由FIFO的状态电路送出的一个信号,以阻止FIFO的写操作继续向FIFO中写数据而造成溢出(overflow)。
空标志:FIFO已空或将要空时由FIFO的状态电路送出的一个信号,以阻止FIFO的读操作继续从FIFO中读出数据而造成无效数据的读出(underflow)。
读时钟:读操作所遵循的时钟,在每个时钟沿来临时读数据。
写时钟:写操作所遵循的时钟,在每个时钟沿来临时写数据。
读指针:指向下一个读出地址。读完后自动加1。
写指针:指向下一个要写入的地址的,写完自动加1。
读写指针其实就是读写的地址,只不过这个地址不能任意选择,而是连续的。
4.FIFO的分类
根均FIFO工作的时钟域,可以将FIFO分为同步FIFO和异步FIFO。同步FIFO是指读时钟和写时钟为同一个时钟。在时钟沿来临时同时发生读写操作。异步FIFO是指读写时钟不一致,读写时钟是互相独立的。
5.FIFO设计的难点
FIFO设计的难点在于怎样判断FIFO的空/满状态。为了保证数据正确的写入或读出,而不发生益处或读空的状态出现,必须保证FIFO在满的情况下,不能进行写操作。在空的状态下不能进行读操作。怎样判断FIFO的满/空就成了FIFO设计的核心问题。由于同步FIFO几乎很少用到,这里只描述异步FIFO的空/满标志产生问题。
在用到触发器的设计中,不可避免的会遇到亚稳态的问题(关于亚稳态这里不作介绍,可查看相关资料)。在涉及到触发器的电路中,亚稳态无法彻底消除,只能想办法将其发生的概率将到最低。其中的一个方法就是使用格雷码。格雷码在相邻的两个码元之间只由一位变换(二进制码在很多情况下是很多码元在同时变化)。这就会避免计数器与时钟同步的时候发生亚稳态现象。但是格雷码有个缺点就是只能定义2n的深度,而不能像二进制码那样随意的定义FIFO的深度,因为格雷码必须循环一个2n,否则就不能保证两个相邻码元之间相差一位的条件,因此也就不是真正的各雷码了。第二就是使用冗余的触发器,假设一个触发器发生亚稳态的概率为P,那么两个及联的触发器发生亚稳态的概率就为P的平方。但这回导致延时的增加。亚稳态的发生会使得FIFO出现错误,读/写时钟采样的地址指针会与真实的值之间不同,这就导致写入或读出的地址错误。由于考虑延时的作用,空/满标志的产生并不一定出现在FIFO真的空/满时才出现。可能FIFO还未空/满时就出现了空/满标志。这并没有什么不好,只要保证FIFO不出现overflow or underflow 就OK了。

2https://zhuanlan.zhihu.com/p/375099980
为什么需要FIFO?
FIFO存储器是系统的缓冲环节,如果没有FIFO存储器,整个系统就不可能正常工作。

FIFO的功能可以概括为

(1)对连续的数据流进行缓存,防止在进机和存储操作时丢失数据;

(2)数据集中起来进行进机和存储,可避免频繁的总线操作,减轻CPU的负担;

(3)允许系统进行DMA操作,提高数据的传输速度。这是至关重要的一点,如果不采用DMA操作,数据传输将达不到传输要求,而且大大增加CPU的负担,无法同时完成数据的存储工作。

http://www.jsqmd.com/news/193401/

相关文章:

  • AI技术加持,8款高效查重工具推荐,让学术写作过程更加顺畅无忧
  • ‌互动学习游戏稳定性测试:幼儿教育场景的专业实践指南
  • 测试工具革命:2026年测试工程师的必备武器库
  • AI助力学术写作,精选8款高效查重工具,确保论文原创性无忧
  • ZooKeeper的使用
  • 【行业专家揭秘】:企业级PHP物联网数据上报平台架构设计全流程
  • 测试管理工具对比:TestRail、Zephyr、Xray 中小团队适配全景图
  • 2025年毛巾定制加工厂排行榜,技术强的毛巾定制加工厂有哪些 - myqiye
  • 2026年低温恒温反应槽国产优势企业选购指南:主流品牌与生产商厂家解析 - 品牌推荐大师
  • 用Allure报告让测试结果“一眼看懂”:定制化模板实战
  • GLM-TTS与MyBatisPlus结合案例:数据库驱动的内容播报
  • GLM-TTS参考音频优化策略:提升音色相似度的关键因素
  • 如何用PHP打造高性能视频流转码系统?90%开发者忽略的关键细节
  • Angular交互核心06, 模板驱动表单 vs 响应式表单:场景与性能深度解析
  • 【ELM回归预测】基于VMD-HHO-ELM的水泥煅烧能耗预测附Matlab代码 未发表
  • 2025年靠谱隧道风筒布生产商推荐:专业厂家年度排名 - 工业品网
  • 语音合成灰盒测试实践:介于黑盒与白盒之间的验证方式
  • 2026年靠谱的帘式膜厂家选购参考汇总 - 品牌鉴赏师
  • 如何用PHP+Redis实现毫秒级分布式锁?99%的人都忽略了这3个关键点
  • Redis分布式锁从入门到精通:PHP工程师必备的8个核心技术要点
  • AI改写与查重结合,8款高效工具推荐,让学术写作变得更简单无忧
  • 2025年烟台知名的乏风取热箱厂家推荐排行,冷却器/新风机组/翅片管/空调机组/乏风取热箱,乏风取热箱公司推荐排行榜单 - 品牌推荐师
  • 借助AI技术,推荐8款高效论文查重工具,让学术写作更轻松无忧
  • 【高危漏洞预警】:PHP开发区块链账户时最容易忽视的4个致命错误
  • 2025年成都提分效果好的文化课补习排名:高考文化课补习与高三文化课集训机构全解析 - 工业品牌热点
  • 8款高效论文查重工具推荐,结合AI技术,让学术写作更省心省力
  • 2025年分类/智能/智慧/四分类/环保垃圾箱及定制方案厂家推荐榜:宿迁市金德广告设备有限公司,市政设施领域的创新力量 - 品牌推荐官
  • 手把手教你用PHP原生扩展实现高效WebSocket推送(附完整代码案例)
  • 【高并发架构核心秘籍】:基于PHP与Redis的分布式锁设计全剖析
  • 西门子博途PLC程序开发,V17、V16、V15.1版本实战