|

- UID
- 39122
- 帖子
- 259
- 精华
- 2
- 积分
- 8356
- 资产
- 8356 信元
- 发贴收入
- 1510 信元
- 推广收入
- 0 信元
- 附件收入
- 13820 信元
- 下载支出
- 7010 信元
- 阅读权限
- 50
- 在线时间
- 414 小时
- 注册时间
- 2006-7-16
- 最后登录
- 2010-8-25
|
2#
发表于 2007-1-14 17:18
| 只看该作者
个人觉得,公式应该是这样:
A/(B * w_clk) = X/(Y * r_clk)
fifo_depth = burst_length - burst_length * X/Y * w_clk /r_clk
举例说明:
如果100个写时钟周期可以写入80个数据,10个读时钟可以读出8个数据
其中w_ck=5ns,r_ck=10ns
如果按照之前的公式,得出的深度为:fifo_depth = burst_length - burst_length * X/Y * r_ck/w_clk=160-160*8/10*2=-94,显然是不对的
实际上,考虑背靠背(20个clk不发数据+80clk发数据+80clk发数据+20个clk不发数据的200个clk)
这样在中间160个写时钟周期连续写的情况下,只能读出160*5/(10*10)*8=64个数据,所以FIFO的深度应该为160-64=96
也就是fifo_depth = burst_length - burst_length * X/Y * w_clk /r_clk=160-160*8/10*5/10=96
大家可以讨论一下,加深对这个问题的认识。 |
|