首页 > 其他分享 >后端基础——详解setup与hold

后端基础——详解setup与hold

时间:2023-03-15 21:23:28浏览次数:46  
标签:clock setup flop 详解 time timing hold

一,基础

  在数字集成电路中,通常用建立时间(setup time)、保持时间(hold time)、传输延迟时间(propagation delay time)、最高时钟频率(maximum clock frequency)等几个参数具体描述触发器的动态特性。

 

   以一个边沿D触发器为例

  • 建立时间(setup time)tsu
    建立时间是指输入信号应当先于时钟信号CLK动作到达的时间。为了保证触发器可靠地翻转,在C和C'状态改变以前FF1中Q1的状态必须稳定地建立起来,使Q1=D。由于加到D端的输入信号需要经过传输门TG1和反相器G1、G2才能到达Q1端,延迟时间为3*td;而在CLK的上升沿到达后,只需经过反相器G5的传输延迟时间C'的状态即开始改变,延迟时间为1*td,因此D端的输入信号必须先于CLK的上升沿至少2*td的时间到达,故tsu=2*td.
  • 保持时间(hold time)th
    保持时间是指时钟信号CLK动作到达后,输入信号仍然需要保持不变的时间。由图可见,在C和C'改变状态使TG1变为截止、TG2变为导通之前,D端的输入信号应当保持不变。为此,至少在CLK上升沿到达后2*td的时间内输入信号应当保持不变,即保持时间应当为th=2*td.换句话说:当信号从0变为1的过程中,在一段很短的时间内,所有传输门都可能导通,若此时D端信号发生变化而CLK的transition比较慢,则会发生新值覆盖旧值而导致信号错误的现象。因此,D段信号需要在传输门完成开/关过程中保持稳定,此即为hold的物理意义,也是timing report中library hold time代表的含义。

二,setup和hold应该维持在什么范围

结论:setup通常情况下应当保持为正,hold可以允许为负,但setup+hold应当为正数

Tskew1+Tcq+Tlogic+Tsetup>=Tskew2+Thold

Thold为负,则Tskew2有较大的变化空间。

来看一个解释:

 

 另一个解释:

 

 

Setup Time: and Hold Time: If the data or signal changes just before and after the active edge of the clock respectively then we say that setup time/ hold time has been violated.

Causes for Setup Time: Setup violations can happen as a result of slow conditions (slow process, high temperature) leading to signals arriving too late in the clock period.

Strategy to Fix Setup Time: Reduce Delay.

*As a RTL Design Engineer*:

  1. If the RTL code is a FSM , change the states of a FSM to one hot encode or grey code. If only one bit is changing at a time, it is a good chance that it would be faster and less delay.
  2. Prefer to use case statement over if else. Case statements and if else statements would have the same functionality but synthesis captures them differently. If there are multiple branch conditions, case statements (which is a mux) would be faster than synthesized if else (which would be priority encoder).
  3. Achieve Parallelism in RTL Serial Codes elongate the critical path and that is BAD. If we can split large serial operation in to multiple parallel operations then it is simple to meet timing of small individual units.

*As a Physical Design Engineer*:

  1. Make use of macros Each industry I believe would be having specific macros available. These are usually best optimized cells.
  2. Try to make use of libraries derived from NAND logic. Since , NAND and NOR are universal gates and NAND being faster than NOR they could be utilized to reduce delay. For example: if NAND is followed by a latch, simply use latch-NAND driver.
  3. Increase Wire Thickness (reduces resistance) and increase the spacing between wires (decreases coupling capacitance).
  4. Use Cells with lower Threshold Voltages: Cells with lower threshold voltage have lesser transition times which makes the propagation of logic faster.
  5. Restructuring/Re-timing would be the best way to optimize the logic. Based upon the placement of data path logic cells, you can decide either to combine simple logic gates into a complex gate, or split a multi-stage cell into simpler logic gates.
  6. A cell with better drive strength can charge the load capacitance quickly, resulting in lesser propagation delay. So make sure you cell has better drive strength. (Traditionally , I believe larger cells should be having more driving strength).
  7. For a critical path with a capture flop and a launch flop , try to ensure that the clock at the capture flop comes late or the clock at the launch flop comes early. This will give some extra timing and will be able to relax any violations we would be facing.

Alternative Explanation (for point 7th) : Positive skew helps improve the setup slack. So, to fix setup violation, we may either choose to increase the clock latency of capturing flip-flop, or decrease the clock latency of launching flip-flop.

I am happy to provide diagrammatic explanations as well, if you are interested in explanation with diagrams do comment it.

Causes for Hold Time Violations: Hold violations can happen as a result of fast conditions (fast process, low temperature) leading to signals arriving too early in the clock period.

Strategy to Fix Hold Time:

*As a Physical Design Engineer*

  1. Insert buffers. The timing path where hold violation is occurring, if the delay is increased due to these buffers, then it shall ultimately lead to positive slack thereby improving the chances of hold time being met.
  2. Use data-path cells with higher threshold voltages: If you have multiple varieties of cells with variable threshold voltages, then the cells with higher threshold voltage will have higher transition times. This reduces the chances of the hold time being violated.
  3. Lock up Latches: If we some how try to separate the launching edge and capturing edge by a phase then it will relax the timing path and improves the chances of hold time being met. [Image shown at the last]
  4. A positive skew degrades hold timing and a negative skew aids hold timing. So, if a data-path is violating, we can either decrease the latency of capturing flip-flop or increase the clock latency of launching flip-flop.

Alternative explanation for last point: For a capture and launch flop, if the clock at the launch flop is made to arrive late or the clock at the capture flop is made to arrive early then the chances of hold time being violated is reduced.

 

标签:clock,setup,flop,详解,time,timing,hold
From: https://www.cnblogs.com/hwzhao/p/17220083.html

相关文章

  • stm32F0中断系列详解
    1、中断的概念 概念:程序执行过程中CPU会遇到一些特殊情况,是正在执行的程序被“中断”,cpu中止原来正在执行的程序,转到处理异常情况或特殊事件的程序去执行,结束后再返......
  • js 高频面试题详解
    一:js中的变量提升例1a=2;vara;console.log(a);答:2解析:它会将当前作用域的所有变量的声明提升到程序的顶部,上述代码等价为:vara;a=2console.log(a);//......
  • 百度2024届暑期实习后端算法题详解
    目录一Coding1题目描述解题思路详细代码二Coding2题目描述解题思路详细代码三Coding3题目描述解题思路详细代码这是百度2024届暑期实习后端岗位的第一轮笔试,总共有十五......
  • (转)go context详解
    原文:https://www.cnblogs.com/niuben/p/15110611.html前言平时在Go工程的开发中,几乎所有服务端的默认实现(例如:HTTPServer),都在处理请求时开启了新的 goroutine 进行......
  • LoadRunner——分析图详解(十四)
    《分析图详解》一、RunningVusers图X轴表示运行所用的时间,Y轴表示vuser数,显示在整个运行过程中随着时间的推移,虚拟用户数量是如何变化的,具体描述为:用户是如何增长的......
  • [LeetCode] 1334. Find the City With the Smallest Number of Neighbors at a Thresh
    Thereare n citiesnumberedfrom 0 to n-1.Giventhearray edges where edges[i]=[fromi,toi,weighti] representsabidirectionalandweightededge......
  • 【C】操作符详解
    1.操作符分类:算术操作符移位操作符位操作符赋值操作符单目操作符关系操作符逻辑操作符条件操作符逗号表达式下标引用、函数调用和结构成员2.算术操作符+-*......
  • (转)go语言执行系统命令 - 标准库os/exec详解
    原文:https://blog.csdn.net/weixin_49393427/article/details/116693536exec包对os.StartProcess的包装,方便重新映射标准输入输出,连接io到管道等。exec包不调用系统shell,......
  • 详解React的Transition工作原理原理
    Transition使用姿势Transition是react18引入的新概念,用来区分紧急和非紧急的更新。紧急的更新,指的是一些直接的用户交互,如输入、点击等;非紧急的更新,指的是UI界面......
  • linux 网络管理之tcpdump命令详解
    一、tcpdump的作用tcpdump是linux环境的网络数据采集分析工具,也就是所谓的抓包工具,与tcpdump只有命令行格式不同,Windows有个图形可视化工具Wireshark所谓的抓包工具就......