0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

谈一谈FIFO的深度

冬至子 来源:IC解惑君 作者:木飞 2023-11-28 16:19 次阅读

前言:

最近加的群里面有些萌新在进行讨论FIFO的深度的时候,觉得 FIFO的深度计算比较难以理解 。所以特出漫谈FIFO系列,会涉及到FIFO的深度计算、同步/异步FIFO的设计等。

引言:

考虑如下的场景,是我们小学或者初中的时候学过的一个问题:

image.png

场景一:

如上图所示,假设入水口的 进水量 2m³/h ,出水口的 出水量1m³/h ,假设水池容量10m³,开始的时候水池没有水,水池多久会满?

答:水池容量 / (进水量 - 出水量) = 10 /(2 - 1) = 10 h

上面我们可以得出,对于进水量比出水量多的情况下,无论水池容量大小是多少, 水池在一些时间之后会溢出

所以这也反映了,我们在IC设计中,对于 FIFO这个蓄水池 ,输入数据的个数一直大于输出数据的个数, FIFO总会溢出产生问题

场景二:

如上图所示,假设入水口的 进水量 2m³/h ,出水口的 出水量1m³/h ,但是本场景和场景二不同的地方是:入水口的进水时间是一天24h中的任意8小时进水。出水口是半天12h中的任意2小时出水。

问水池会溢出吗?可以设计水池的深度让水池不要溢出吗?

(1)对于一天的进水量来说,2 *8 = 16m³ ,对于一天的出水量来说,2 *2 = 4m³ , 进水量 - 出水量 = 12 m³,所以水池会溢出。

(2)因为 输入数据的个数一直大于输出数据的个数 (在当前的时间)。所以无论设计多深的深度,水池都会溢出。

场景三

如上图所示,假设入水口的时钟是按照 分钟来进行间隔 ,对于入水口,每10分钟流入8m³的水,对于出水口来说,每1.2分钟流出1m³的水。

问水池会溢出吗?可以设计水池的深度让水池不要溢出吗?

(1)对于入水口来说,10分钟8立方米 所以12分钟9.6m³,对于出水口12分钟10m³。所以通过 设定水池的深度可以让水池不会溢出 。因为总体而言流出的水流是大于流入的水流。

概念1:back to back

对于入水口来说有一种情况是需要注意的。这种情况如下图:

image.png

在一次 完整的20分钟之内 ,前面两分钟没有进水,最后的两分钟没有进水,进水的时间集中在20分钟内的 连续16分钟内 ,所以这段时间对于水池来说压力最大,因为水池设计的深度如果不考虑这个可能就会溢出,(这也就是所谓的流(水)量密集)

(2)考虑到概念1再回答场景三的第二个问题:水池的深度应该设计为:

**[1] **16m³ / 16 min = 进水量的效率

[2] 1m³ / 1.2min = 出水量的效率

**[3] ** 水池的深度 = (进水量效率 - 出水量效率) * **16 min ** = (16 /6 )m³

在计算水池深度我们可以得出 结论

所谓水池的深度在计算的时候,就是进水量在背靠背这段时间内,进水的所有量,减去背靠背这段时间内出水口的出水量,在这背靠背的时间内,入水的量减去出水的量,就是内部的水池应该承受的水量。

正文:

FIFO计算问题:

(1)假设FIFO的写时钟为100MHZ,读时钟为80Mhz,在FIFO输入侧,每100个写时钟,写入80个数据,在读数据侧,每个时钟读出一个数据,问FIFO设置为多少FIFO不会溢出??

[1] 在输入数据背靠背的情况下,进入( input**)FIFO的数据量:**

image.png

进入FIFO的数据量:160个 消耗的时间:160 个 写时钟

[2] 在输入数据背靠背的时间内,输出( output 端口输出的数据量

(1)因为输入输出端口的时钟频率不同,所以先把输入数据背靠背的时间换算到输出数据端口的时钟个数:(160 *(1/100MHZ) * / * (1/80MHZ)=128读时钟周期

(2)则输出端口在背靠背输入的时间**内输出的数据:128 *1 = 128个读数据

[3] 则FIFO的深度为:

160 (输入) - 128 (这段时间内的输出) = 32 (内部水池FIFO应该存的)

(2)假设FIFO的写时钟为wclk,读时钟为rclk,在FIFO输入侧,每B个写时钟,写入A个数据,在读数据侧,每Y个时钟读出X个数据,问FIFO设置为多少FIFO不会溢出??

[1] 在输入数据背靠背的情况下,进入( input**)FIFO的数据量:**

进入FIFO的数据量:2A , 消耗的时间:2A * (1 / wclk)

**[2] 在输入数据背靠背的时间内,输出( output )端口输出的数据量:

** (1)因为输入输出端口的时钟频率不同,所以先把输入数据背靠背的时间换算到输出数据端口的时钟个数:**

读时钟周期个数 :(2A * (1 / wclk))* / (1 / rclk)
(2)则输出端口在背靠背输入的时间内输出的数据:

读的数据个数: (2A* (1 / wclk) / (1 / rclk) ** * (X / Y)

[3] 则FIFO的深度为:

输入数据背靠背时间内的输入数据 减去输入数据背靠背时间内的输出数据

2A - [(2A * (1 / wclk)) ** / (1 / rclk)] ** * (X / Y)

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • IC设计
    +关注

    关注

    37

    文章

    1290

    浏览量

    103716
  • fifo
    +关注

    关注

    3

    文章

    387

    浏览量

    43513
  • 时钟源
    +关注

    关注

    0

    文章

    93

    浏览量

    15926
收藏 人收藏

    评论

    相关推荐

    求助,FPGA fifo深度不够怎么办?

    图像压缩之后的数据存入fifo,然后经过nrf2401发送。。但是由于图片尺寸比较大,导致fifo深度不够,受限于FPGA芯片尺寸的限制,fifo
    发表于 05-22 14:34

    谈一谈大家新颖的思路

    长期玩电子,脑子都僵化了,大家来谈一谈自己有什么新颖有创意的想法。
    发表于 02-25 16:28

    FIFO深度怎么设计

    大家好,我有个设计问题,我有两个域之间的接口:输入是50MHz的16位并行数据输出为500 MHz的1位串行数据,对于这种情况,我需要设计FIFO。任何人都可以帮助我设计FIFO
    发表于 01-10 10:45

    【教程】“最恶劣”的FIFO深度计算

    FIFO内缓存数据最多。计算此时写入数据-该阶段读出数据即为FIFO的最小深度。   Nwr = 120x = Nwr - Nrd = 120 - 96 = 24.二.为保证数据连续输出,求读取前
    发表于 02-22 20:37

    谈一谈 MPU6050 姿态融合

    谈一谈 MPU6050 姿态融合
    发表于 05-05 09:28

    谈一谈对FOC的些理解

    FOC入门谈一谈我对FOC的些理解注:其中有些图片是网上找的,有些是自己做的,作图水平般,勿喷这是我第
    发表于 09-01 07:10

    谈一谈对穿越频率的理解

    最近正好研究这方面的内容,所以顶个贴,支持把楼主。楼主从穿越频率的定义来开宗明义,小弟也谈一谈对穿越频率的理解:1)对定义的理解;2)对环路校正时穿越频率选取原则理的解;3)还有大家在分析Bode
    发表于 10-29 06:06

    谈一谈对穿越频率的理解

    最近正好研究这方面的内容,所以顶个贴,支持把楼主。楼主从穿越频率的定义来开宗明义,小弟也谈一谈对穿越频率的理解:1)对定义的理解;2)对环路校正时穿越频率选取原则理的解;3)还有大家在分析Bode
    发表于 11-17 07:58

    谈一谈嵌入式开发怎么入门的

    想要从事嵌入式开发,但又不知道怎么入门的,可以看下,下面我结合自身实际来谈一谈。前提基础:简单的电路、模电、数电知识,C语言、从51单片机入手如果有些前提的基础知识,要上手51单片机不算难。首先
    发表于 12-17 08:12

    谈一谈嵌入式操作系统些需要注意的点

    计算机学院的嵌入式系统实验不是特别难,首先,连代码都不需要写,主要是需要操作些新的设备和软件,但是这些软件的安装,设备的使用上有较多的坑,需要注意。接下来,我就来谈一谈些需要注意的点。...
    发表于 12-23 08:27

    谈一谈DALI的具体应用

    今天我们来谈一谈 DALI 的具体应用, 最主要的是 DALI 控制装置中的调光驱动电源的使用场景, 比如 DT6 和 DT8 产品(参考文章 大力哥 DALI - D...
    发表于 12-27 08:32

    LabVIEW FPGA模块实现FIFO深度设定

    为了解决基于LabVIEWFPGA模块的DMAFIFO深度设定不当带来的数据不连续问题,结合LabVIEWFPGA的编程特点和DMA FIFO的工作原理,提出了种设定 FIFO
    发表于 09-26 13:45 7309次阅读
    LabVIEW FPGA模块实现<b class='flag-5'>FIFO</b><b class='flag-5'>深度</b>设定

    基于LabVIEW FPGA模块程序设计特点的FIFO深度设定详解

    为了解决基于LabVIEWFPGA模块的DMAFIFO深度设定不当带来的数据不连续问题,结合LabVIEWFPGA的编程特点和DMA FIFO的工作原理,提出了种设定FIFO
    发表于 01-04 14:25 4666次阅读
    基于LabVIEW FPGA模块程序设计特点的<b class='flag-5'>FIFO</b><b class='flag-5'>深度</b>设定详解

    FIFO最小深度计算的方法

    由于平时我们工作中,FIFO都是直接调用IP核,对于FIFO深度选择并没有很在意,而在笔试面试过程中,经常被问及的问题之就是如何计算FIFO
    的头像 发表于 07-03 17:25 2688次阅读

    谈一谈PCB翘曲度的标准以及如何测量

    谈一谈PCB翘曲度的标准以及如何测量
    的头像 发表于 11-27 17:28 4800次阅读
    <b class='flag-5'>谈一谈</b>PCB翘曲度的标准以及如何测量