原创 关于建立时间、保持时间的讨论

2008-1-25 12:03 2357 4 5 分类: 模拟

时钟周期为T,触发器D1的时钟沿到来到触发器Q变化的时间Tco(CLK--Q)最大为T1max,最小为T1min,逻辑组合电路的延迟时间最大为T2max,最小为T2min,问触发器D2的建立时间和保持时间。


最终答案:T3setup<T-T1max-T2max,T3hold<T1min+T2min

maxbird: D2的保持时间就是时钟沿到来之后,D2的数据输入端要保持数据不变的时间,这个时间是由D1和D2之间的组合逻辑时延决定的。例如:假设D1和D2之间的组合逻辑时延为2ns,时钟周期为10ns,这意味着在时钟沿来到后,D1输出的新数据要过2ns才会到达D2的数据输入端,那么在这2ns内,D2的数据输入端保持的还是上一次的旧数据,其值不会立即更新,假设D2的最小保持时间为3ns,这意味时钟沿到来后,D2的数据输入端的值在3ns内不能有变化,回到问题的关键,由于D1在时钟沿到来后的输出结果,经过2ns的组合逻辑延时便到达了D2的输入端,而D2要求在时钟沿到来后的3ns内其输入端的值不能改变,这样D2的保持时间就得不到满足,所以D2的保持时间必须小于等于2ns。 至于说T2min为0时的情况,其实T2min是永远不能为0的,即使是一根导线其时延也是不可能为0的,这就是为什么移位寄存器的两个触发器之间连的只是一根导线,导线后端触发器的保持时间却还是可以满足的原因,其实移位寄存器中触发器的保持时间可以看成是小于等于其间导线的时延。

建立时间:触发器在时钟沿来到前,其数据输入端的数据必须保持不变的时间;保持时间:触发器在时钟沿来到后,其数据输入端的数据必须保持不变的时间。如下图:

46334705.jpg

因为触发器内部数据的形成是需要一定的时间的,如果不满足建立和保持时间,触发器将进入亚稳态,进入亚稳态后触发器的输出将不稳定,在0和1之间变化,这时需要经过一个恢复时间,其输出才能稳定,但稳定后的值并不一定是你的输入值。这就是为什么要用两级触发器来同步异步输入信号。这样做可以防止由于异步输入信号对于本级时钟可能不满足建立保持时间而使本级触发器产生的亚稳态传播到后面逻辑中,导致亚稳态的传播。两级触发器可防止亚稳态传播的原理:假设第一级触发器的输入不满足其建立保持时间,它在第一个脉冲沿到来后输出的数据就为亚稳态,那么在下一个脉冲沿到来之前,其输出的亚稳态数据在一段恢复时间后必须稳定下来,而且稳定的数据必须满足第二级触发器的建立时间,如果都满足了,在下一个脉冲沿到来时,第二级触发器将不会出现亚稳态,因为其输入端的数据满足其建立保持时间。同步器有效的条件:第一级触发器进入亚稳态后的恢复时间 + 第二级触发器的建立时间 < = 时钟周期。 (编者注:maxbird在该部分详细说明了建立时间和保持时间的概念,以及如果不满足二者可能导致的亚稳态的传播。注意这里说的建立时间和保持时间都是针对时钟而言的,在进行时序约束时所指的就是这种,而很多网友以前学习的建立时间保持时间的概念是针对信号而言的,所指的对象不同,分析出来的结论完全相反,一定注意不要混淆。)


lh1688: 不考虑CLOCK SKEW情况下。D2的建立时间要求:Tco1+T1(logic delay)+Tsetup2 < Tc(CLOCK 周期) 。那么 Tsetup2 < Tc(CLOCK 周期) -(Tco1+T1)。这个应该比较容易理解。相对的保持时间实际就是 路径的总延时 (Tco1+T1)。 保持时间 Thold2 < (Tco1+T1)。
PARTNER CONTENT

文章评论1条评论)

登录后参与讨论

用户377235 2012-5-13 12:02

很感谢

用户424265 2012-4-16 17:44

我想问一下,是不是数字越大优先级就越高啊?

用户284630 2010-9-24 09:44

很好!很强大!

用户1323030 2010-7-27 14:01

顶了

用户173137 2009-11-10 14:45

明白了!谢谢。

用户187751 2009-5-27 09:19

写的很好很强大!!!不过有个疑问!! 响应优先级应该至少占一位吧 那么您为什么说“第4组:所有4位用于指定抢占式优先级 ”呢?

用户1078285 2009-5-25 13:23

请问,您上面的例子中EXTI0优先级比EXTI9_5低? 另外EXTI9_5可以中断EXTI0吗?? 谢谢!!

用户569744 2009-4-22 14:19

很好! 看了清楚些,

用户116892 2009-3-8 21:45

谢谢了 整个系统只能选择同一组分组方式 主要是为了弄清楚这个

用户1400086 2009-1-9 15:53

讲得好明白,使我少走很多弯路,谢谢~
相关推荐阅读
用户129638 2008-02-04 11:10
51单片机整数二一十进制转换的快速算法
51单片机整数二一十进制转换的快速算法技术分类: 微处理器与DSP  | 2008-02-04 来源:单片机及嵌入式系统应用 | 作者:西北矿冶研究院 陈国照  89C5l系列单片机历经20多年的发展...
用户129638 2008-01-25 12:01
电容
请注意在开关电源的设计中,输入电容和输出电容常常包括两类电容,分别起不同的作用。一类起减小输入输出纹波的作用,一般容值较大,容值的选取与纹波的要求以及电源的开关频率和设计有关。另一类电容是高频耦和电容...
用户129638 2008-01-25 11:42
在一个大的电容上还并联一个小电容,这是为什么?
因为大电容由于容量大,所以体积一般也比较大,且通常使用多层卷绕的方式制作(动手拆过铝电解电容应该会很有体会,没拆过的也可以拿几种不同的电容拆来看看,不过要注意安全,别弄伤手),这就导致了大电容的分布电...
用户129638 2008-01-24 20:04
三极管实现3V与5V混合系统中逻辑器接口问题
用三极管实现3V与5V混合系统中逻辑器接口问题(原创) 发表于 2007-6-8 14:16:03 3V与5V混合系统中逻辑器接口问题在电路设计当中,往往会遇到电压匹配问题,因为电路中往往不只只有一个...
用户129638 2008-01-24 16:48
如何成为一位杰出的工程师
#1 楼主:如何成为一位杰出的工程师-How to be a Star Engineer 贴子发表于:2006-6-28 1:16:25我的博客www.luosview.com, 我的邮件login2...
EE直播间
更多
我要评论
1
4
关闭 站长推荐上一条 /3 下一条