首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

FIFO写满时,产生的数据放在哪儿啊?

FIFO写满时,产生的数据放在哪儿啊?

数据产生模块:实时产生数据

如果FIFO写满时,数据产生模块产生的数据怎么办?应该放哪啊?需要写个RAM吗?

FIFO中的数据是循环存储的吗?即是不是某个地址的数据被读出后,这个地址就变空了,可以继续向里写数据那?

具体的说,当FIFO中某个地址的数据被读出后,那么这个地址是不是可以再次被写入??
急啊!大侠救命啊!

[此贴子已经被作者于2007-11-22 10:43:19编辑过]

fifo的主要目的一般来讲有两个: 数据速率的适配; 时钟的适配.
fifo的容量有有限的, 而且一般来讲都比较小, 容量大的那是缓存/队列, 虽然缓存/队列也可以做成"先进先出"的形式, 但主要目的已经是缓存数据了.
fifo会输出full标志给写端口, empty标志给读端口, 前面的数据产生模块在full信号置位后就应该停止数据发送, 否则fifo会溢出, 数据会丢失, 如果不做这样的处理, 那你认为fifo的容量应该做几GB或TB才能绝对不溢出呢?
外面的模块不需要关心fifo内部的读写地址, 只需要根据full/empty进行正常的写/读操作就行, fifo内部要维护读写地址, 是循环往复的, 数据读出后, 这个地址单位就会被释放, 就可以再写一个新的数据进去了, 但还没有释放的地址单位不能被覆盖. 但fifo有多种设计, 有的fifo的读地址还能回退, 比如MAC half-duplex的重传.
我不是高手
另外,我觉得你可以使用双时钟,可以控制数据量,保证不被溢出
我不是高手

楼上说得很对,我补充一下。

一般对于fifo的满的值都设为fifo深度的一半,这样在超过这个值后,你要足够的时间判断是否满了。

不至于数据丢失。当然75%也可以。

这个版主不太冷 =========================== 我的中电网博客:http://blog.chinaecnet.com/u/20/index.htm

非常感谢!谢谢两位大虾!

学习。纯顶

高手高手,学习ING
返回列表