数字电路的亚稳态问题

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

相关文章

Redis连接失败:客户端IP不在白名单中的问题分析与解决方案

《Redis连接失败:客户端IP不在白名单中的问题分析与解决方案》在现代分布式系统中,Redis作为一种高性能的内存数据库,被广泛应用于缓存、消息队列、会话存储等场景,然而,在实际使用过程中,我们可能... 目录一、问题背景二、错误分析1. 错误信息解读2. 根本原因三、解决方案1. 将客户端IP添加到Re

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下

解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题

《解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题》本文主要讲述了在使用MyBatis和MyBatis-Plus时遇到的绑定异常... 目录myBATis-plus-boot-starpythonter与mybatis-spring-b

mysql主从及遇到的问题解决

《mysql主从及遇到的问题解决》本文详细介绍了如何使用Docker配置MySQL主从复制,首先创建了两个文件夹并分别配置了`my.cnf`文件,通过执行脚本启动容器并配置好主从关系,文中还提到了一些... 目录mysql主从及遇到问题解决遇到的问题说明总结mysql主从及遇到问题解决1.基于mysql

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11

如何安装HWE内核? Ubuntu安装hwe内核解决硬件太新的问题

《如何安装HWE内核?Ubuntu安装hwe内核解决硬件太新的问题》今天的主角就是hwe内核(hardwareenablementkernel),一般安装的Ubuntu都是初始内核,不能很好地支... 对于追求系统稳定性,又想充分利用最新硬件特性的 Ubuntu 用户来说,HWEXBQgUbdlna(Har

MAVEN3.9.x中301问题及解决方法

《MAVEN3.9.x中301问题及解决方法》本文主要介绍了使用MAVEN3.9.x中301问题及解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录01、背景02、现象03、分析原因04、解决方案及验证05、结语本文主要是针对“构建加速”需求交

Nginx、Tomcat等项目部署问题以及解决流程

《Nginx、Tomcat等项目部署问题以及解决流程》本文总结了项目部署中常见的four类问题及其解决方法:Nginx未按预期显示结果、端口未开启、日志分析的重要性以及开发环境与生产环境运行结果不一致... 目录前言1. Nginx部署后未按预期显示结果1.1 查看Nginx的启动情况1.2 解决启动失败的