数字电路的亚稳态问题

2024-03-09 02:48

本文主要是介绍数字电路的亚稳态问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数字电路的亚稳态问题

    • 亚稳态的原因:
    • 何时会发生亚稳态:
    • 亚稳态危害:
    • 异步复位的亚稳态
    • 同步复位的亚稳态
    • 亚稳态发生概率
    • 亚稳态振荡时间Tmet
    • 常用的消除亚稳态的三种办法

🔈声明:
🔑未经作者允许,禁止转载
🚩推荐一个IC、FPGA新手入门的好网站:👉快 点 击 进 入 学 习 吧👈



  • 亚稳态问题是数字电路中很重要的问题,因为现实世界是一个异步的世界,所以亚稳态是无法避免的,并且亚稳态应该也是面试常考的考点。
  • 时序电路将触发器和锁存器当作存储元件,但是这两种器件都受制于一个称为亚稳定性的状态。

亚稳态的原因:

如果锁存器的一个输入脉冲太窄,或两个输入同时有效,或两个输入间隔过小,那么锁存器可能进入亚稳态。
而如果数据在使能输入沿的周围不稳定,DFF也会进入亚稳态。(这个不稳定就是在Tsu和Th内信号不稳定,或者是复位

何时会发生亚稳态:

因为存储器件很容易进入亚稳态,所以设计时应该考虑使由于亚稳态导致的系统混乱的信号影响最小。
许多想要以同步方式执行的物理系统都具有异步输入信号,而异步信号时间不可控,所以极易出现亚稳态的情况。

  • 那么何为异步信号?
  • 异步信号就是不能由时钟控制,或者如果它是由不同域中的时钟同步的。

亚稳态危害:

  • 因为亚稳态时不确定是0还是1,所以信号会在0,1之间震荡,就会逻辑混乱。而在复位电路中产生亚稳态会使复位失败。

一般同步信号下不会出现亚稳态,亚稳态一般出现在异步信号和跨时钟域的情况下。
1) 在跨时钟域的情况下,由于两端的时钟相移未知,所以在源寄存器发出的信号可能在任何情况下到目标寄存器,无法确定满足Tsu和Th的要求
2) 异步信号的输入也是同理,不确定信号在什么时候到达。

异步复位的亚稳态

在这里插入图片描述
恢复时间(T recovery):

指的的异步信号发生时离下一个clk之间的最短时间,如果异步信号的有效沿在恢复时间内就没有留给寄存器足够的时间去恢复正常,就会出现亚稳态。

去除时间(T removal):

指的是当前clk过去变无效的时间,如果异步信号发生在去除时间内,就会无法屏蔽这个clk可能这个时钟仍会起作用,没有达到复位的效果,这也是亚稳态。

  • 这些情况都指的是异步信号能够直接改变寄存器的情况。

同步复位的亚稳态

大部分资料表明同步复位电路不会发生亚稳态,其实同步电路也会发生,只是几率小于异步电路。
在这里插入图片描述

例如这个电路,din为1时,如果rst无效沿在Tsu和Th内,依旧会产生亚稳态的情况。

  • 所以说有异步信号的电路都有亚稳态发生的机率。

亚稳态发生概率

  • 亚稳态发生情况都是同步信号不满足set-time,hold-time或者异步信号不满足恢复和移除时间。
  • 概率=(set-time + hold-time)/周期
  • 可以看出随着频率变高,亚稳态的概率会随之变大。所以可以通过减小频率,或者使用更好工艺的FPGA来减小Ts和Th。
    

因为实验表明带异步输入的电路故障修复的平均时间与退出亚稳态条件所用的时间成指数关系,所以依靠同步装置创建一个用于从亚稳态条件恢复到正常的缓冲器,可以大大减少电路故障可能性。

一直看到资料说一级寄存器产生亚稳态后,两级就90%没有亚稳态,三级就99%没有,一直没搞懂为什么,现在仔细梳理一下。

因为第一级产生亚稳态后,通过Tmet(决断时间)后会稳定成一个值,但是也有可能Tmet过长,产生第二级的亚稳态。
在这里插入图片描述

亚稳态振荡时间Tmet

亚稳态震荡时间Tmet关系到后级寄存器的采集稳定问题,Tmet影响因素包括:器件的生产工艺、温度、环境以及寄存器采集到亚稳态离稳定态的时刻等。甚至某些特定条件,如干扰、辐射等都会造成Tmet增长。

常用的消除亚稳态的三种办法

1) 对异步信号进行同步处理
2) 采用FIFO对跨时钟域数据通信进行缓冲处理
3) 对复位电路采用异步复位,同步释放处理

  • 具体的三种方法如何实现,以及为何可以消除亚稳态,到下一篇博客在写。




  Verilog的学习还是要多以练习为主,想要练习Verilog的同学,推荐可以去nowcoder看看,他们现在的题库内容很丰富,属于国内做的很好的了,而且是课程+刷题+面经+求职+讨论区分享一站式求职学习网站,最最最重要的里面的资源全部免费

这篇关于数字电路的亚稳态问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/789320

相关文章

Spring Boot中JSON数值溢出问题从报错到优雅解决办法

《SpringBoot中JSON数值溢出问题从报错到优雅解决办法》:本文主要介绍SpringBoot中JSON数值溢出问题从报错到优雅的解决办法,通过修改字段类型为Long、添加全局异常处理和... 目录一、问题背景:为什么我的接口突然报错了?二、为什么会发生这个错误?1. Java 数据类型的“容量”限制

关于MongoDB图片URL存储异常问题以及解决

《关于MongoDB图片URL存储异常问题以及解决》:本文主要介绍关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录MongoDB图片URL存储异常问题项目场景问题描述原因分析解决方案预防措施js总结MongoDB图

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

usb接口驱动异常问题常用解决方案

《usb接口驱动异常问题常用解决方案》当遇到USB接口驱动异常时,可以通过多种方法来解决,其中主要就包括重装USB控制器、禁用USB选择性暂停设置、更新或安装新的主板驱动等... usb接口驱动异常怎么办,USB接口驱动异常是常见问题,通常由驱动损坏、系统更新冲突、硬件故障或电源管理设置导致。以下是常用解决

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1

SpringBoot内嵌Tomcat临时目录问题及解决

《SpringBoot内嵌Tomcat临时目录问题及解决》:本文主要介绍SpringBoot内嵌Tomcat临时目录问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录SprinjavascriptgBoot内嵌Tomcat临时目录问题1.背景2.方案3.代码中配置t

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、