打怪升级之FIFO读完了再读会坏掉嘛?

当FIFO的数据被读空后,其默认输出数据为0,并在后续读操作中保持最后一个读出的数据值。在FIFO再次接收到数据后,可以正常读取新的数值。此特性在使用ALTERA公司的IP核时表现明显,且连续读取直至FIFO为空时,FIFO会持续输出最后留存的数值,直到有新数据写入。

FIFO的数据已经读空了,再读会怎么样?

首先声明一下自己所用的IP核来源,源自ALTERA公司开发的IP核。
然后说结论,FIFO默认输出的数据为0,如果写入数据后再读FIFO,在rdreq归零后FIFO的读出数据线会一直保持最后一个读出数据的值(也有人会用clock来做读取的判断条件,clock跟rdreq本质上是一样的,但一般保持clock的周期不变比较容易让人理解)。

实际演示

在这里插入图片描述这是一个FIFO输入输出的仿真工程,从中可以看到:
1.红框部分是正常的读入与读出。读入数据是你自己输入进FIFO的,所以其变化特征没意义,注意尽量在FIFO_clk的下降沿变化读入数据以保持上升沿时读入数据作为判定条件的稳定。
2.蓝框部分是进行过读入读出操作后,再读入读出的操作,可以看到没有任何问题,FIFO是可以正常复用的。
3.紫框部分表示连续多次读取FIFO直至将FIFO读空。FIFO读空后,会保持输出最后一个留在FIFO内的之前写入的数值,并不会随着FIFO的读取信号而发生改变。重新写入数据后,也可以正常使用,正常读新的数值。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

考琪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值