FIFO深度计算方法_第1页
FIFO深度计算方法_第2页
FIFO深度计算方法_第3页
FIFO深度计算方法_第4页
FIFO深度计算方法_第5页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、写时钟频率w_clk,读时钟频率r_clkz写时钟周期里,每B个时钟周期会有A个数据写入FIFO读时钟周期里,每Y个时钟周期会有X个数据读出FIFO贝ij, FIFO的最小深度是?计算公式如下:fifo_depth = burstjength burstjength * X/Y * r_clk/w_clk例举说明:如果100个写时钟周期可以写入80个数据,10个读时钟可以读出8个数 据。令wclk=rclk,考虑背靠背(20个elk不发数据+ 80clk发数据+ 80clk发数 据+ 20个elk不发数据的200个elk)代入公式可计算FIFO的深度fifo_depth = 160-160X

2、(80%) =160-128=32如果令 wclk=200mhz,改为 100 个 wcik 里写入 40 个,rclk=100mhz, 10 个rclk里读出8个。那么fifo深度为48计算如下 fifo_depth =80-80X (80%) X(100/200)=80-32=48注:将 fifo_depth=burst_length-burst_length*(X/Y)*(r_clk/w_clk)作个变形,得到 fifo_depth = burstjength - (burstjength /w_clk)*r_clk*(x/y)其中(burstjength /w_clk)表示这个burs

3、t的持续时间,r_clk*(x/y)表示读的实际速度。两者的乘积 自然就是这段时间读出的数据量。显然burstjength表示这段时间写入的数据 量,两者的差为fifo中残留的数据,这个也就是理论上的fifo的最小深度。实际 应用中往往是以半空半满信号来指示fifo的空满状态的,所以实际设计fifo的时 候会至少留下一个数据空间的深度裕量。FIFO深度计算讨论(2010-04-15 15:49:00)转载标签:杂谈写时钟周期w_clk,读时钟周期r_clk,写时钟周期里,每B个时钟周期会有A个数据写入FIFO读时钟周期里,每Y个时钟周期会有X个数据读出FIFO贝ij, FIFO的最小深度是?首

4、先,这道题不一定有解有解的必要条件是在一定时间内(足够长),写入的数据数量一定要等于 读出的数据数量因此有:A/B * w_clk = X/Y * r_clk其次,算出写数据的最大burstJengtho考虑最坏情况比如,如果条件给出,每100个写时钟,写入80个数据,那么在背靠背的 情况下,burstjength = 2*80=160最后,fifo_depth = burstjength burstjength * X/Y * r_clk/w_clkBTW:通常,为了安全起见,都会多留一些depth的余度个人觉得,公式应该是这样:A/(B*w_clk) = X/(Y*r_clk)fifo_d

5、epth = burstjength burstjength * X/Y * w_clk/r_clk举例说明:如果100个写时钟周期可以写入80个数据,10个读时钟可以读出8个数据其中 w_ck=5ns,r_ck=10ns如果按照之前的公式,得出的深度为:fifo_depth = burstjength - burstjength * X/Y * r_ck/w_clk=160-160*8/10*2=- 94,显然是不对的实际上,考虑背靠背(20个elk不发数据+ 80clk发数据+ 80clk发数据+ 20 个elk不发数据的200个elk)这样在中间160个写时钟周期连续写的情况下,只能读出

6、160*5/(10*10)*8=64个数据,所以FIFO的深度应该为160-64=96也就是 fifo_depth = burst_length burstjength * X/Y * w_clk /r_clk=160- 160*8/10*5/10=96大家可以讨论一下,加深对这个问题的认识。原帖由 windzjy 于 2007-1-14 17:18 发表个人觉得,公式应该是这样:A/(B * w_clk) = X/(Y * r_clk)fifo_depth = burstjength burstjength * X/Y * w_clk/r_clk举例说明:如果100个写时钟周期可以写入80个

7、数据,10个读时钟可以读出我以前 看到过这个公式,是用来计算同步fifo的。你所举的那个例子,如果呼入fif。的数据宽度和呼出相同的话,都设为w bito那么呼如fifo的带宽就是200wbps,呼出fifo的带宽是100wbpso考虑链路 利用率都是80% o那么呼入fifo的有效带宽是160wbpso呼出fifo的带宽是3 / 580wbpso现在看到矛盾了,由于输入输出带宽不相等,进来永远比出去多,那 么FIFO总是处于不断积累数据的状态。所以lz所举的这个例子并不合适。应该提高读时钟的速率,使fifo两端的带宽匹配,在这个前提下才能计算 出有解的fifo深度。如果令wclk=rclk

8、(以下内容中的elk表示时钟的频率,不是周期)。可使 得读写带宽匹配。那么这个例子的答案是32原因如下:考虑背靠背的情况,160个wcik连续都写入了 160个数据。而这160个 wcik时间内,由于wclk=rclk,那么读出了 (16/10) x8 = 128个数据。有32个 数据会被留在fifo里。那么fifo的最小深度就是32 o "如果令 wclk=200mhz,改为 100 个 wcik 里写入 40 个,rclk=100mhz, 10 个rclk里读出8个。那么fifo深度为48续上:讲数据带入公式 fifo_depth = burstjength burstjengt

9、h * X/Y * r_clk/w_clk正好也是这个结果。所以我觉得公式是对的。其实 A/B * w_clk = X/Y * r_clk 即(A/B)*W_CLK二(X/Y)*R_CLK所表达的含义就是fifo的输入和输出带宽要匹配,其中A/B表示链路利用 率,w.clkxwidth表示带宽,这里大概是默认输入输出的数据宽度相同,所以以 wcik来代替带宽。X/Y和r_clk的含义也是这样:)o在带宽匹配的前提下数据不会无限积累。fifo_depth = burstjength - burstjength * (X/Y) * (r_clk/w_clk)公式是对的续上:fifo_depth =

10、 burstjength - burstjength * (X/Y) * (r_clk/w_clk)作个变形,得到 fifo_depth = burstjength - (burstjength /w_clk)*r_clk*(x/y)其中(burst_length/w_clk)表示这个burst的持续时间,r_clk*(x/y)表示读的 实际速度。两者的乘积自然就是这段时间读出的数据量。显然burstjength表示这段时 间写入的数据量,两者的差为fifo中残留的数据,这个也就是理论上的fif。的最 小深度。实际应用中往往是以半空半满信号来指示fifo的空满状态的,所以实际设 计fifo的时候会至少留下一个数据空间的深度裕量。仔细看了一下发现自己的问题:1,贴子中写时钟周期w_clk和读时钟周期r_clk并不是指的周期,而是指的 频率2,我举例不当,因该

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论