FPGA亚稳态状态检测边沿

亚稳态的原理

亚稳态原理
如上图所示,当时钟上升沿来的时候,数据恰好改变,这个时候输出的结果就无法确定是0/1,寄存器会经过一段时间的抖动然后输出一个结果(无法确定是正确还是错误)

亚稳态检测边沿的解决办法

通过三个寄存器,数据的抖动会消失,从而得到稳定的数据输出(数据同样不确定是否正确)

亚稳态检测边沿的原理:

当寄存器抖动之后输出为0时,如下图所示,通过两个寄存器,就可以消除抖动,并且,在几个时间周期之后一定能检测到边沿
输出为0
下图为数据抖动之后输出为1的情况:
输出数据为1
上面只用到了两个寄存器,如果时钟频率特别快,当下一个时钟沿到来的时候,寄存器0的Q0还在抖动,那么这个抖动就会传到第二个寄存器(通过两个寄存器,抖动基本为0),所以为了确保最后抖动被消除,一般用三个寄存器。

VHDL 代码:
vhdl代码实现

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值