静态时序分析:SDC约束命令set_driving_cell详解

news2024/12/22 18:35:50

相关阅读

静态时序分析icon-default.png?t=N7T8https://blog.csdn.net/weixin_45791458/category_12567571.html?spm=1001.2014.3001.5482


        在上文中,我们不建议使用set_drive命令而是使用set_driving_cell命令,这是一个描述输入端口驱动能力更精确的方法。因为大多数情况下,只有库单元的设计者熟悉单元门内部的输出电阻情况,因此直接指定驱动单元而不是指定驱动电阻更容易。

        该指令的BNF范式(有关BNF范式,可以参考以往文章)为:

set_driving_cell
    [-lib_cell lib_cell_name] [-library lib]
    [-rise] [-fall] [-min] [-max]
    [-pin pin_name] [-from_pin from_pin_name]
    [-dont_scale] [-no_design_rule]
    [-none][-input_transition_rise rtran][-input_transition_fall ftran]
    [-multiply_by factor] port_list

指定驱动单元名称

        -lib_cell选项用于指定驱动输入端口的单元,当单元的输出端口不只一个时,可以使用-pin选项指定输出引脚。默认情况下,set_driving_cell命令在链接库中搜索单元。

指定端口列表

        指定一个端口列表,包含输入端口或输入输出双向端口,如果有多于一个端口,需要使用引号或大括号包围。

简单使用

        以图1所示的电路图为例,首先在输入端口clk定义一个时钟。

create_clock -period 10 [get_port clk]

图1 一个简单的例子

        接着在输入端口d、c上分别定义两个输入延迟,参考时钟为clk。

set_input_delay 0.5 -clock clk [get_port d]
set_input_delay 0.5 -clock clk [get_port c]

        假设在我们的库中有一个叫做CLKINVX1的反相器,使用下面的命令指定输入端口d的驱动单元为CLKINVX1。

set_driving_cell -lib_cell CLKINVX1 [get_port d]

        使用这个命令时,会产生一个警告,如下所示,后面的小节我们会解释原因。

Warning: Design rule attributes from the driving cell will be set on the port. (UID-401)

        现在可以使用report_port -verbose命令报告输入端口的驱动情况了,如图2所示。

图2 端口驱动单元报告

        最后使用report_timing命令分别报告输入端口d到触发器的时序路径,记得使用-transition_time选项,结果如图2所示。 

图3 输入端口d的建立时间时序报告  

        可以看到,此时输入端口d的转换时间是0.0191175,并且带来了0.0045136的额外输入延迟,这是不包括在输入延迟(input external delay)中的。

延迟和转换时间计算原理

        那么这些数据是如何计算出来的呢,我们可以以图4的电路图为例做个实验。

图4 一个简单的实验 

        根据lib文件中的信息,我们使用set_load命令给输出端口d加上0.001494的负载,这是为了模拟图一中U4单元的输入引脚A的电容。

set_load 0.001494 [get_port d]

        接着使用report_delay_calculation命令,就可以知道U2的单元延迟和转换时间的计算情况了,如图5、图6所示。

 report_delay_calculation -from [get_pin U2/A] -to [get_pin U2/Y]

图5 CLKINVX1的有负载延迟计算情况

图6 CLKINVX1的有负载转换时间计算情况

        对比图6与图3可以发现,转换时间的计算方式确实是直接通过非线性延迟模型(NLDM)计算得出。而且我们可以看到,尽管使用了反相器CLKINVX1作为驱动单元,input_external_delay和输入端口d的边沿都是下降沿,这是因为input_external_delay是从输入端口d的边沿反推回去得到的边沿,也就是说时序报告中没有指明驱动单元的输入极性,但是它可以被指定,后面的小节会说明。

        但是还有一个很奇怪的事情,图3中的延迟值0.0045136却和图5中的延迟计算结果0.0170837不同,这是因为这个延迟的计算方式为loaded driving_cell delay - unloaded driving_cell delay,即带负载延迟减去零负载延迟,因此是0.0170837减去零负载延迟。

        我们可以继续在图4中模拟这种情况,即使用remove_load命令把负载去除,延迟计算结果如图7所示。

图7 CLKINVX1的无负载延迟计算情况

        可以看出, 0.0170837-0.01257确实是0.0145137约等于0.0045136(这是因为四舍五入的问题)。

        PS:其实可以直接使用report_delay_calculation -from [get_port d] -to [get_port d]命令报告驱动单元的延迟和转换时间计算情况。

指定库名

        -library选项指定了在哪些链接库中搜索单元。在不使用-library的情况下,DC首先会在所有链接库中与输入端口的操作条件(operating conditions)匹配的库搜索单元,如果找不到,才会去其它链接库搜索单元;在使用-library指定了某些链接库的情况下,DC首先会在这些链接库中与输入端口的操作条件(operating conditions)匹配的库搜索单元,如果找不到,才会去这些链接库中的其他链接库搜索单元。

        -library选项显示地声明了要在哪些链接库中搜索单元,这对于多链接个库中出现多个同名单元的情况有用(尽管这不常见)。

        下面的命令指定使用了typical库中的CLKINVX1单元。

set_driving_cell -lib_cell CLKINVX1 -library typical [get_port d]

指定上升沿、下降沿

         -rise选项用于指定驱动单元使用于端口的上升沿、-fall选项用于指定驱动单元使用于端口的下降沿(注意:不管是什么驱动单元,驱动单元的时序弧都是正单调性)。如果这两个选项都没有指定,延迟同时作用于时钟的上升沿和下降沿(相当于它们同时指定)。

        下面的命令将输入端口上升沿的驱动单元改为CLKINVX2,下降沿的驱动单元依旧是CLKINVX2,如图8所示。

set_driving_cell -rise -lib_cell CLKINVX2 -library typical [get_port d]

图8 端口驱动单元报告

指定最大、最小条件

        -max选项用于指定延迟值作用于最大条件(建立时间分析),-max选项用于指定延迟值作用于最小条件(保持时间分析)。如果这两个选项都没有指定,延迟同时作用于最大条件和最小条件(相当于它们同时指定)。通常情况下,我们会使用-min选项指定驱动能力最强的单元(最快),使用-min选项指定驱动能力最弱的单元(最慢)。

        下面的命令使用-min选项指定驱动能力强的CLKINVX2驱动输入端口d,使用-max选项指定驱动能力强的CLKINVX1驱动输入端口d,如图9所示。

set_driving_cell -min -lib_cell CLKINVX2 [get_port d]
set_driving_cell -max -lib_cell CLKINVX1 [get_port d]

图9 端口驱动单元报告

指定输出引脚

        -pin选项用于指定驱动单元的输出引脚,这对于拥有多个输出引脚的单元很有用,如果使用多个输出引脚的单元而不指定-pin选项,则DC会使用搜索到的第一个输出引脚。

        比如对于一个触发器单元DFFRX1,其拥有两个输出引脚,分别为Q及QN,下面的命令指定以DFFRX1的输出引脚Q驱动输入端口d,如图10所示。

set_driving_cell -lib_cell DFFRX1 -pin QN [get_port d]

图10 端口驱动单元报告

指定输入引脚

        -from_pin选项用于指定驱动单元的输入引脚,这对拥有多个输入引脚的单元很有用,如果使用多个输出引脚的单元而不指定-from_pin选项,则DC会使用搜索到的第一个输入引脚(前提输入输出引脚间有时序弧)。

        比如对于一个单元CMPR42X1,它拥有五个输入端口、三个输出端口,如图11所示。

图11 CMPR42X1单元框图

        下面的命令指定以CMPR42X1的输入端口A,输出端口S作为输入端口d的驱动源,如图12所示。

set_driving_cell -lib_cell CMPR42X1 -from_pin A -pin S [get_port d]

图12 端口驱动单元报告

指定禁止放缩

        -dont_scale选项用于指定,驱动单元的转换时间和延迟不会因为操作环境而被放缩(scale)。放缩指的是当工作环境与特征化条件不同时,转换时间和延迟的计算在最后会被乘以一个因子,如图5、图6、图7中所示的那样。

        使用下面的命令指定上的输入端口d的驱动单元为CLKINVX1并禁止放缩。

set_driving_cell -lib_cell CLKINVX1 -dont_scale [get_port d]

指定设计规则不转移

        现在我们终于开始解决一开始使用命令时的警告问题了,即

Warning: Design rule attributes from the driving cell will be set on the port. (UID-401)

        这是因为默认情况下,驱动单元的设计规则会被复制到输入端口,例如max_fanout、  max_capacitance、max_transition、min_fanout、min_capacitance、min_transition这些属性。而-no_design_rule选项用于禁止这些行为。

        使用下面的命令指定上的输入端口d的驱动单元为CLKINVX1并保证设计规则不转移,此时命令执行后不会出现警告。

set_driving_cell -lib_cell CLKINVX1 -no_design_rule [get_port d]

删除驱动单元

        -none选项用于删除之前指定的驱动单元相关信息,但是这个选项已经过时,尽管它目前仍然起作用,建议使用remove_driving_cell命令替代。

        下面的命令删除了输入端口d上的驱动单元。

set_driving_cell -none [get_port d]

指定上升、下降转换时间

        -input_transition_rise和-input_transition_fall选项用于指定驱动单元输入端上升、下降沿的转换时间,默认情况下,使用输入转换时间0计算输出转换时间和延迟,如图6、图7所示的那样。

        下面的命令指定了驱动单元CLKINVX1的输入上升、下降沿转换时间分别为0.5、0.4。

set_driving_cell -lib_cell CLKINVX1 -input_transition_rise 0.5 -input_transition_fall 0.4 [get_port d]

        下面使用report_delay_calculation -from [get_port d] -to [get_port d]命令报告端口的延迟计算情况,如图13所示。

图13 端口转换时间计算情况

        可以看到对于输入单元下降沿转换时间的计算,使用了指定的输入端上升沿转换时间;对于输入单元上升沿转换时间的计算,使用了指定的输入端下降沿转换时间。也就是说,这里的计算考虑了时序弧的单调性。

​指定驱动能力因子

        -multiply_by选项用于指定一个驱动能力因子,用于模拟驱动减弱或驱动增强,会影响驱动单元延迟和转换时间的计算。

        下面的命令指定了驱动单元CLKINVX1的驱动能力因子为0.5,这代表着最终的计算结果会乘以0.5,如图14、图15所示。

set_driving_cell -lib_cell CLKINVX1 -multiply_by 0.5 [get_port d]

图14 端口延迟计算情况

图15 端口转换时间计算情况

        在使用这个选项是会出现如下警告,代表着这个选项已经过时,即将删除。 

Warning: Starting from 2019.03 release, the 'set_driving_cell' command will no longer  support the '-multiply_by' option (OBS-002)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1466114.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

黑马头条-day10

文章目录 app端文章搜索1、文章搜索1.1 ElasticSearch环境搭建1.2 索引库创建①需求分析②ES导入数据场景分析③创建索引和映射 1.3 索引数据同步①app文章历史数据导入ES②文章实时数据导入ES 1.4 文章搜索多条件复合查询①关键词搜索②搜索接口定义 2、搜索历史记录2.1 需求说…

免费的代理IP能用吗?

随着大家对代理IP的认知逐步加深,不可避免地,免费代理IP安全性和潜在风险也越来越关注,今天我们就来一探究竟,这到底是怎么一回事。 首先,我们得了解一下代理IP。 代理IP是指作为中介的服务器,它能够代理用…

java.lang.IllegalStateException: Promise already completed.

spark submit 提交作业的时候提示Promise already complete 完整日志如下 File "/data5/hadoop/yarn/local/usercache/processuser/appcache/application_1706192609294_136972/container_e41_1706192609294_136972_02_000001/py4j-0.10.6-src.zip/py4j/protocol.py"…

修改单据转换规则后保存报错提示

文章目录 修改单据转换规则后保存报错提示 修改单据转换规则后保存报错提示

软考系分之多媒体分类、声音、图像

文章目录 1、概要2、 媒体分类3、声音4、图像5、总结 1、概要 本篇重点介绍多媒体技术,包括多媒体分类、声音、图像。 2、 媒体分类 媒体主要分为5类,感觉媒体、表现媒体、表示媒体、传输媒体和存储媒体。感觉媒体,就是直接作用于人感官的媒…

android input命令支持多指触摸成果展示-千里马framework实战开发

hi input命令扩展提示部分 generic_x86_64:/ # input -h Error: Unknown command: -h Usage: input [<source>] <command> [<arg>...]The source…

体验LobeChat搭建私人聊天应用

LobeChat是什么 LobeChat 是开源的高性能聊天机器人框架&#xff0c;支持语音合成、多模态、可扩展的&#xff08;Function Call&#xff09;插件系统。支持一键免费部署私人 ChatGPT/LLM 网页应用程序。 地址&#xff1a;https://github.com/lobehub/lobe-chat 为什么要用Lobe…

如何快速导出vercel project中的环境变量

我在vercel中集成了某些插件或者链接了数据库&#xff0c;要如何快速的导出这些环境变量呢&#xff1f; 具体方法如下&#xff1a; npm i -g vercelvercel linkvercel env pull .env.local首先是安装vercel然后登录vercel 最后拉取环境变量到.env.local

2.22学习总结

1.营救 2.租用游艇 3.砍树 4.买礼物 5.刷题统计 砍树https://www.dotcpp.com/oj/problem3157.html 题目描述 给定一棵由 n 个结点组成的树以及 m 个不重复的无序数对 (a1, b1), (a2, b2), . . . , (am, bm)&#xff0c;其中 ai 互不相同&#xff0c;bi 互不相同&#xff0c;ai…

Ansible 简介及部署 基础模块学习 ansible部署rsync 及时监控远程同步

Ansible介绍&#xff1a; Ansible 是一个配置管理系统&#xff0c;当下最流行的批量自动化运维工具之一&#xff0c;它是一款开源的自动化工具&#xff0c;基于Python开发的配置管理和应用部署的工具。 Ansible 是基于模块工作的&#xff0c;它只是提供了一种运行框架&#xff…

Spring之AOP源码解析(上)

Aop相关注解 EnableTransactionManagementEnableAspectJAutoProxyEnableAsync... 从注解切入来看看这些注解都干了什么 Import注解作用简述 注入的类一般继承ImportSelector或者ImportBeanDefinitionRegistrar接口 继承ImportSelector接口&#xff1a;selectImports方法返回…

后端经典面试题合集

目录 1. Java基础1-1. JDK 和 JRE 和 JVM 分别是什么&#xff0c;有什么区别&#xff1f;1-2. 什么是字节码&#xff1f;采用字节码的最大好处是什么&#xff1f; 1. Java基础 1-1. JDK 和 JRE 和 JVM 分别是什么&#xff0c;有什么区别&#xff1f; JDK 是Java开发工具包&am…

lora网关智慧工厂三色灯安灯状态采集钡铼技术S281

LoRa网关结合钡铼技术S281模块在智慧工厂三色灯安灯状态采集方面具有广泛的应用前景。智慧工厂的安全生产管理对于企业生产经营至关重要&#xff0c;而三色灯安灯是工厂安全生产管理的重要指示灯&#xff0c;通过LoRa无线通信技术和钡铼技术S281模块&#xff0c;可以实现对三色…

网络安全-nc(Netcat)工具详解

经常在反弹shell的时候使用nc命令&#xff0c;但是从来没有了解过&#xff0c;今天翻书看到了&#xff0c;准备记录一下。 nc全称Netcat&#xff0c;是TCP/IP连接的瑞士军刀。哈哈我最喜欢瑞士军刀了。 有一个比较偏的知识点&#xff0c;nc还可以探测目标的端口是否开放&…

【springBoot】springAOP

AOP的概述 AOP是面向切面编程。切面就是指某一类特定的问题&#xff0c;所以AOP也可以理解为面向特定方法编程。AOP是一种思想&#xff0c;拦截器&#xff0c;统一数据返回和统一异常处理是AOP思想的一种实现。简单来说&#xff1a;AOP是一种思想&#xff0c;对某一类事务的集…

B端系统:工作台页面,如何从平庸走向出众

Hi&#xff0c;大家好&#xff0c;我是贝格前端工场&#xff0c;从事8年前端开发的老司机。大家看过很多平庸的工作台页面&#xff0c;但是仔细分析过平庸的表现吗&#xff0c;仔细思考过如何实现出众的效果吗&#xff1f;这篇文章为你解读。 一、工作台页面是什么&#xff0c;…

深信服技术认证“SCCA-C”划重点:深信服超融合HCI

为帮助大家更加系统化地学习云计算知识&#xff0c;高效通过云计算工程师认证&#xff0c;深信服特推出“SCCA-C认证备考秘笈”&#xff0c;共十期内容。“考试重点”内容框架&#xff0c;帮助大家快速get重点知识 划重点来啦 *点击图片放大展示 深信服云计算认证&#xff08;S…

【STC8A8K64D4开发板】第2-13讲:SPI总线的应用

第2-13讲&#xff1a;SPI总线的应用 学习目的了解SPI总线的结构、特点以及4种通信模式。掌握通过SPI读、写和擦除SPI Flash W25Q128的方法以及代码编写。掌握通过SPI读、写铁电存储器FM25CL64B的方法以及代码编写。 SPI总线原理 SPI是串行外设接口(Serial Peripheral Interfa…

AI 视频 | Stable Video 开放公测了,免部署,免费使用!谁说 4 秒的 AI 视频不香?!

谁说 4 秒的视频不香&#xff1f;2.21 日&#xff0c;Stable Video 开放公测了&#xff0c;不需要自己部署了&#xff0c;直接在网页上就可以生成视频了。 下面这些视频&#xff0c;都是通过 Stable Video Diffusion 生成的&#xff0c;可以先来感受一下&#xff1a; Stable V…

JavaScript的内存管理与垃圾回收

前言 JavaScript提供了高效的内存管理机制&#xff0c;它的垃圾回收功能是自动的。在我们创建新对象、函数、原始类型和变量时&#xff0c;所有这些编程元素都会占用内存。那么JavaScript是如何管理这些元素并在它们不再使用时清理它们的呢&#xff1f; 在本节中&#xff0c;…