一文搞懂FIFO深度计算

何时需要FIFO?

当模块A需要向模块B发送数据,但是发送数据和接受数据的速度不一样,这个时候就需要一个FIFO来做缓冲。
在这里插入图片描述

FIFO的深度

简单的想,FIFO的深度取决于FIFO内部存储的还未读取的数值的个数,当这个数达到最大的时候,就是FIFO的最小深度。
这里考虑的读写速度的差异,是写得速度比读的速度更快,这样才会有可能出现FIFO溢出的情况,才需要仔细考虑FIFO的深度为多少。但是当读比写快,或者读写一样快的时候又会怎样呢?下面会仔细分析。

写比读快

第一种情况

第一种情况很简单,如下图,已经告诉了连续写数据的长度(Burst Length),那么只需要考虑这段时间内最多会写进多少个数,以及会读走多少个数,二者只差就是FIFO的深度。
在这里插入图片描述

第二种情况

第二种情况和第一种类似,是说如果在连续的两次读和写之间都插入一个周期的延迟,结果会怎样?答案是没有变化,计算过程和第一种情况一样,如果感兴趣,可以下载本文最后的文件。

第三种情况

第三种情况是在读和写之间插入了不同的delay,就算过程其实也比较简单,如下图所示。本质上相当于改变了读写的速度,导致FIFO深度的要求产生变化。
在这里插入图片描述

第四种情况

第四种情况分析的是读写时钟的占空比发生改变的时候,对FIFO的深度有何影响?
答案是没有影响。

读比写快

第五种情况

这种情况很简单,FIFO的深度为1就可以了
在这里插入图片描述

第六种情况

在这里插入图片描述

读写一样快

第七种情况

读写一样快,读写之间没有延迟的话,FIFO的深度为1就够了

第八种情况

在这里插入图片描述

另一类问题

第九种情况,如下图,这种问题比前面的要复杂一点,好在题目已经给了Burst Size, 就会简化很多。
在这里插入图片描述
需要理解这里的160是怎么来的,题目中说了每100个周期会写80个数据进来,那么就会有20个周期没有数,即IDLE状态,关于WRITE状态和IDLE状态的分布,有很多种可能,如下图所示
在这里插入图片描述
我们需要考虑得是最差情况下,即“背靠背”的输入,就是上面的case-4,这种情况下会连续写入160个数据,无疑对于FIFO的深度要求是最高的,计算过程如下:

  • 最差情况下连续写入160个数据,需要160个周期
  • 这160个周期可以读出160*(8/10)=128个数据
  • FIFO的深度为160-128=32

总结

总的来说,对于这样的问题:

写时钟频率wclk,
读时钟频率rclk,
写时钟周期里,每B个时钟周期会有A个数据写入FIFO
读时钟周期里,每Y个时钟周期会有X个数据读出FIFO
则,FIFO的最小深度是?

首先要确定Burst Length,对这种题目,BL一般为2*A,然后深度的计算公式如下
d e p t h = B L − B L ∗ ( X / Y ) ∗ ( r c l k / w c l k ) depth = BL - BL * (X/Y) * (rclk/wclk) depth=BLBL(X/Y)(rclk/wclk)

参考文档

参考文档

  • 8
    点赞
  • 59
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
异步FIFO深度计算通常考虑写数据速率比读数据速率快的情况,以防止数据溢出和丢失。一种计算深度的方法是根据最大的写数据速率和读数据速率来确定。假设最大的写数据速率是Wr,读数据速率是Rd,传输数据的时钟周期为T,那么FIFO深度可以通过以下公式计算得出:深度 = ceil(Wr * T / Rd)。这个公式保证了FIFO能够容纳写入速率最大的数据,同时避免了数据丢失。另外,由于异步FIFO的设计中通常使用格雷码,所以深度需要是2的幂次方。如果计算得到的深度不是2的幂次方,需要选择大于等于该深度的最小的2的幂次方作为FIFO深度。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [异步FIFO深度 计算模型以及详细推导.docx](https://download.csdn.net/download/changhaizhang/11441790)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [异步FIFO最小深度计算](https://blog.csdn.net/qq_40268672/article/details/123275374)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值