latch应用总结-Time Borrowing/Lockup/Gating Check

latch应用总结-Time Borrowing/Lockup/Gating Check同步数字电路中主流还是用寄存器 但是锁存器 Latch 也不容忽视 它既能用作数据存储单元 又能作为时钟控制单元

大家好,欢迎来到IT知识分享网。


前言

同步数字电路中主流还是用寄存器,但是锁存器(Latch)也不容忽视,它既能用作数据存储单元,又能作为时钟控制单元。

一、Latch功能介绍

在这里插入图片描述
D Latch 是一种常用的 Latch。E = 0时输出状态保持不变,锁存输入信号D;E = 1时,输出随输入状态而改变。因此,D Latch 可以用于存储单比特的数据,设计中使用Latch的好处是相比寄存器的面积更小,功耗更低,可以从后级电路进行time borrowing,更容易满足setup time,然而坏处是STA分析不会那么直接,下面我们就看看引入了Latch的setup/hold Timing Path如何分析。

二、Time Borrowing

在数字设计中,经常会碰到如下图所示的Path,两个寄存器(UFF0和UFF1)之间存在一个锁存器(ULAT1),这种情况工具会怎么分析path呢?
在这里插入图片描述
根据Latch的特点,在CLKN为高电平时,ULAT1是transparent,ULAT1/D端的数据能即时地反映在ULAT1/Q端。下图中的情况是,UFF0->ULAT1/D的Path Delay使得ULAT1/D数据在CLKN的上升沿之后才到达,需要从后一级ULAT1->UFF1中进行time borrow,使得原本违例的path满足了要求。
在这里插入图片描述
UFF0->ULAT1/D的Path Delay使得ULAT1/D数据在CLKN的上升沿之后才到达,需要从后一级ULAT1->UFF1中借了1.81ns,使ULAT1/D数据在CLKN上升沿到来之前到达,使得原本违例的path满足了要求。而ULAT1->UFF1的timing path即使借出去1.81ns,也能够满足要求,具体的setup timing report如下:
①UFF0 -> ULAT1 setup timing report(从后一级ULAT1->UFF1中借了1.81ns)
在这里插入图片描述
②ULAT1 -> UFF1 setup timing report(ULAT1->UFF1的timing path借出去1.81ns给前一级)
在这里插入图片描述

三、Lockup Latch in Scan Shift Mode

我们不仅要给功能路径(functional path)close setup/hold timing,还要close scan path setup/hold timing。
在scan shift mode下,scan chain两个flop之间就是直接连接的,而不像functional path中间存在combo logic,再加上scan clock的频率一般也比functional clock的频率要低,所以通常来说setup time是很容易满足的,但是hold time可能会出问题,特别是本来分属于不同的clock domain的两个flop被穿在了一条scan chain下,而clock tree没有做balance的时候,两个flop的clock skew可能会很大,相应的hold time violation也会很大,因为在scan shift mode下,所有的clock是同步的。
由于CLK1和CLK2为不同的时钟域,很难保证他们同步,假如CLK2相比CLK1有一段不确定的延迟Tskew,可大可小,那么很有可能FF1/CLK1->FF1/Q->FF2/SI这段延时Tdata会比Tskew小,造成hold timing违例。因此,可以在两级寄存器之间加入一个低电平敏感的latch,结构如下图所示:
在这里插入图片描述
CLK1低电平的时候,Lockup Latch是transparent,CLK1高电平的时候Lockup Latch一直保持上一拍的数据延长了半个周期,这样即使CLK2有延迟,只要不超过CLK1高电平持续时间,就能保证hold timing没有问题。
在这里插入图片描述
在这里插入图片描述
另外,为什么不能加高电平敏感的latch, 因为加了之后,CLK1高电平的时候,Lockup Latch是transparent,无法保持上一拍的数据,因此setup仍是一个周期check, hold check时由于Tskew较大导致当前data还没有被capture但下一个data已经到达造成hold timing violation。

lockup latch的主要作用,就是来解决scan shift mode下存在比较大的hold time violation的问题。

四、Clock Gating Check

Latch的另一个应用是作为门控时钟单元(Clock Gating Cell),通过避免部分寄存器不必要的时钟翻转,可以极大地节省电路的动态功耗。设计中使用Latch的好处是,相比寄存器的面积更小,功耗更低,可以从后级电路进行time borrowing,更容易满足setup time。

Latch + AND

如下图所示,在AND门前面加入low-active latch。当时钟信号是低电平时,latch处于透明状态,根据输出等于输入;当时钟信号从低电平变为高电平时,latch会读取数据输入端的输入信号,并将其保存在锁存器内部的状态中。由于是低电平有效的latch,因此在时钟高电平期间,即使gating信号存在glitch,也不会影响latch的输出。
在这里插入图片描述
因此,EN信号在整个CLK cycle都可以随意toggle, 因为低电平有效的latch,低电平时latch处于透明状态但最终和CLK低电平AND结果为0,高电平时latch锁存输入端信号直至高电平结束。只需要保证将正确的EN信号锁存到latch里面即保证latch的setup/hold timing满足要求即可。

Latch + OR

如下图所示,与latch + AND门不同的是,latch + OR需要使用high-active latch且gating信号来自下降沿触发的寄存器。
在这里插入图片描述
实际应用中,为了避免出现毛刺,会在Latch后面添加一个与门组成一个ICG(Integrated Clock Gating)。
在这里插入图片描述
由于ICG是用在clock path上,STA工具默认会要求做CLKI到EN端的clock gating check,目的是保证时钟使能的时序满足要求,所以会存在REG2ICG的path。因为ICG的clock会比REG的clock delay要短,所以天然存在一个skew对setup不利。在设计上,需要保证REG2ICG的数据路径不能太复杂,否则物理实现会存在困难。

总结

因此,对于latch的timing path,一般setup half-cycle check, hold 同沿 check,如果在这种情况下仍有timing violation, 一般setup会time borrow,hold直接insert buffer fix timing violations。

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/156453.html

(0)
上一篇 2025-02-13 11:25
下一篇 2025-02-13 11:26

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信