找回密码
 注册
关于网站域名变更的通知
查看: 233|回复: 1
打印 上一主题 下一主题

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

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2020-2-24 17:54 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
本文设计思想采用明德扬至简设计法。在使用FPGA设计系统时,常需要利用FIFO进行数据缓存保证数据不丢失,因此计算FIFO深度是至关重要的。FIFO的深度主要取决于“最恶劣”的情况,以下对于两种最常见的场合进行分析。
; o8 o  e$ f! M4 l; J( s* B5 m; G
一.已知读写两侧带宽及最恶劣情况,求FIFO深度8 N" g) u2 Y* t: S# ?5 a0 N
如:对于异步FIFO,写时钟100MHZ,读时钟80MHZ。读写位宽均为16bit。已知每100个写周期最多写入960bit数据,读侧每时钟读取一个数据。问:FIFO深度至少为多少?' w0 Z9 q- ^7 f  \* Q
分析:典型的“背靠背”情况,此时最恶劣的情况是第一次100个写周期内后60个周期连续写入60个数据和第二次100个写周期内前60个周期连续写入60个数据。故上述最恶劣情况下的连续写入120个数据后FIFO内缓存数据最多。计算此时写入数据-该阶段读出数据即为FIFO的最小深度# T4 l& r; l4 U( x
计算:t = 120*Tw
& E1 ?4 W% f8 F3 U   Nwr = 120+ Q3 y0 l- X  y: |
Nrd = t/Trd = 120*Twr/Trd = 120*frd/fwr = 120*80/100 = 96
6 B; M9 P/ g! O1 u, dx = Nwr - Nrd = 120 - 96 = 24.
3 K4 e" K% g/ i: Z; o0 o( t  由于FIFO深度只能取2的整数次幂,因此最小深度为2^5 = 32.
( f% S7 C7 |  w$ c2 |% i( L二.为保证数据连续输出,求读取前FIFO内至少缓存数据量如:异步FIFO,写入时钟80MHZ,读取时钟100MHZ。数据位宽1byte。写侧连续写入均为8192B长度的数据包。问:为保证输出连续不间断,存够多少数据后才能开始发送?6 o5 b2 l5 d% A1 b1 a2 g: ?
分析:此场景为写入一定数据后开始读取FIFO,那么最恶劣的时刻当然是刚开始读取的时间点。想要保证输出连续,则必须满足:读取8192B数据期间写入的数据+已缓存数据 ≥8192B
: A! B- w. h6 U3 s1 V, P计算:t = 8192*Trd0 c$ {2 L6 L% U* k4 _
Nrd = 8192
, K6 ], v. P; R! ]Nwr = t/Twr = 8192*Trd/Twr = 8192*fwr/frd = 8192*80/100 = 6553.6B
) u, O( c7 x" f- E5 d发送水线x满足 Nwr +x = 8192 --> x = 8192 - Nwr = 1638.4B/ N, U1 M2 M% f. s! n" D
  FIFO深度为2^11 = 2048.' l" [. B% `/ N, n0 D+ Y, u( e# B

该用户从未签到

2#
发表于 2020-2-25 18:19 | 只看该作者
FIFO深度计算
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-8-20 08:22 , Processed in 0.109375 second(s), 23 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表