时间的弧线,逻辑的航道——标准单元延迟(cell delay)的根与源

时序弧

在这篇文章中,我们将讨论影响标准单元延迟的因素。在开始讨论之前,我们需要先了解一下什么是时序弧 (Timing Arcs):

时序弧 (Timing Arcs): 时序弧代表了信号从一个输入流向一个输出的方向。它存在于组合逻辑和时序逻辑中,比如AND们的A pin→Z pin为一个时序库,B pin → Z pin为一个时序弧。他们通常具有不同的延迟

关于这些时序弧的信息来源于foundary提供的时序库 (.lib) 文件中,后面我们会讲到如何查看。

cell delay

单元延迟(cell dalay)被定义为:输入信号到达50%逻辑阈值与输出波形到达50%逻辑阈值之间的时间差。 有时也被称为Gate delay/Propagation delay

这个时间差主要取决于两个因素:

  • 1、输入信号的转换时间 (Input slew / transition):即 A 引脚上的信号跳变速率(上升/下降时间)。

  • 2、输出负载 (Output load / capacitance):即 Z 引脚上的电容负载。

也就是cell delay =F{input transition time,Output load}

这里的输出负载 (Output Load) = Z 节点上所有单元的输入电容之和 (Input Cap) + 连接到节点 Z 的所有连线 (nets) 的总寄生电容 (Intterconnect capcitance)

因此,cell delay与输入转换时间和输出负载成正比 :

  • 输出电容越大,单元需要充/放电该电容的时间就越长。因此,延迟就越大。

  • 输入转换时间越长(信号变化越慢),单元在处理完输入值后改变输出所需的时间就越长。

你会发现,对延迟的解释归根结底就是电容的充/放电 (charging/discharging of the capacitors)!!!!

后端中如何查看?

所有cell的delay值都被提供在了标准单元的 lib(时序库)文件中,正如上面结论可得,他需要预先知晓input transition time和Output load,进而可以从从.lib 文件中提供的表中获取单元延迟值。

假设对于某个cell,它的input transition(slew)为0.0344 ns,ouput load的电容大小为0.0068 pf。那么它对应的延时为0.0618937 ns;

此外,在后端实现中,需要格外注意的是:transition和load不要超表,否则对于不在查找表中的transition和load的组合,工具会利用插值算法来计算cell delay,进而导致不精确,因此,我们在设计中,一定要把过大的max_transition和max_cap的violation修复掉。

相关推荐
车载诊断技术8 小时前
电子电气架构 --- 国外对于EE架构的设计方案(上)
架构·汽车·硬件架构·电子电气架构·整车eea简述
拾光Ծ10 小时前
【Linux】冯诺依曼体系结构和操作系统概述
linux·硬件架构
tsumikistep17 小时前
【前后端】接口文档与导入
前端·后端·python·硬件架构
后端小张1 天前
智眼法盾:基于Rokid AR眼镜的合同条款智能审查系统开发全解析
人工智能·目标检测·计算机视觉·ai·语言模型·ar·硬件架构
MarkHD2 天前
车辆TBOX科普 第37次 信号完整性基础与TBOX硬件原型设计实战指南
硬件架构
贝塔实验室6 天前
Altium Designer 6.0 初学教程-如何生成一个集成库并且实现对库的管理
linux·服务器·前端·fpga开发·硬件架构·基带工程·pcb工艺
贝塔实验室7 天前
Altium Designer 6.0 初学教程-如何从原理图及PCB 中生成网表并且实现网表的加载
fpga开发·硬件架构·硬件工程·学习方法·射频工程·基带工程·pcb工艺
MarkHD10 天前
车辆TBOX科普 第7次 TBOX技术深度解析:硬件架构与核心组件详解
硬件架构
Wins_calculator10 天前
硬件架构的异构化和硬件指令集生态多样化的必然性以及Wintel商业联盟对科技进步的阻碍
硬件架构·指令集·wintel
TTBIGDATA10 天前
【Ambari开启Kerberos】- Atlas启动 - Hive服务检查异常处理
大数据·hive·hadoop·硬件架构·ambari·kerberos·bigtop