SDC命令详解:使用set_input_delay命令进行约束

本文详细介绍了如何在Verilog设计中使用`set_input_delay`命令对输入端口的延迟进行约束,包括指定延迟值、端口引脚列表、参考时钟、电平敏感性以及不同类型的路径分析。通过实例演示了如何避免时序覆盖问题并利用`-add_delay`选项进行自动推断。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

相关阅读

SDC命令详解https://blog.csdn.net/weixin_45791458/category_12931432.html?spm=1001.2014.3001.5482


目录

        指定延迟值

        指定端口、引脚列表

        指定参考时钟

        简单使用

        指定时钟下降沿

        指定参考端口、引脚

        包含源、网络延迟

        指定电平敏感

        指定上升、下降沿

        指定最大、最小条件

        指定不覆盖添加延迟


        本章将讨论使用set_input_delay命令对输入端口(引脚)的约束。首先需要说明的是,在进行静态时序分析时,任何一条时序路径都需要有约束,约束指的是时序路径的起点(发射触发器)和终点(捕获触发器)都有时钟信号的控制(对于典型时序路径而言)。但是对于起点是输入端口(引脚)、终点是输出端口(引脚)的时序路径而言,没有显然的发射触发器、捕获触发器,因此需要使用set_input_delay命令进行约束。如果想要移除输入延迟,使用remove_input_delay命令。

        本文针对Design Compiler,但该命令同样存在于PrimeTime、IC Compiler等工具中,它们大致相同,略有差别。set_input_delay命令的BNF范式(有关BNF范式,可以参考以往文章)为:

set_input_delay
    delay_value port_pin_list
    [-reference_pin pin_port_name] [-clock clock_name] [-clock_fall] [-level_sensitive]
    [-network_latency_included] [-source_latency_included]
    [-rise] [-fall]
    [-max] [-min] [-add_delay]
    //注:该命令的port_pin_list参数一定要放在delay_value参数后

指定延迟值

        延迟值指的是输入端口(引脚)的数据相对参考时钟的延迟大小,这个参考时钟触发了一个假象的外部发射触发器,模拟了从发射触发器有效沿到达发射触发器到数据到达输入端口(引脚)的组合逻辑延迟,提供了分析输入端口(引脚)到捕获触发器时序路径的依据。

指定端口、引脚列表

        port_pin_list指定了添加输入延迟的端口和引脚,如果指定的对象是一个叶单元(库单元)的引脚,则该引脚所属的叶单元(库单元)被设置为size only,以便综合时进行驱动能力优化,这还会导致时序路径分割,详见静态时序分析:典型与非典型时序路径的约束详解(一)

        一般情况下,只会对输入端口添加输入延迟,因此在本文中我们只考虑输入端口。

指定参考时钟

        -clock选项指定了参考时钟,它可以是一个虚拟时钟(无源对象),也可以是一个有源对象的时钟。一般都需要指定-clock选项,例外情况可以是作为数据使用的时钟端口和传播时钟端口,在此不进行详述。

简单使用

        在理解了上面三项后,便可以使用简单的set_input_delay命令了,以图1所示的简单D触发器为例。

图1 D触发器的例子

        首先使用create_clock命令以clk端口为源对象创建一个周期为10的时钟。

create_clock -period 10 [get_ports clk]

        我们可以首先看一下端口d到触发器的D引脚的时序报告,如图2所示。

图2 建立时间时序报告

        可以从报告中看到, 由于输入端口d没有被时钟约束,因此无法进行时序路径的建立时间分析,报告的最后也显示了(Path is unconstrained)。

        接着我们使用set_input_delay命令在输入端口d上添加一个输入延迟,参考时钟为clk,此时的时序报告如图3所示。

set_input_delay 0.5 -clock [get_clocks clk] [get_ports d]

 图3 建立时间时序报告

        可以从时序报告中看出,d端口的input external delay此时拥有延迟值0.5。可以使用report_port -verbose命令报告端口延迟,如图4所示。

图4 输入端口延迟报告

指定时钟下降沿

        -clock_fall选项指定了假象的外部发射触发器由下降沿触发。在默认情况下,假象的外部发射触发器由上升沿触发,如图3中的(rise edge)显示的那样。

        下面我们在输入端口c上添加一个输入延迟,参考时钟为clk,指定时钟下降沿,如图5所示,此时的时序报告如图6所示。

set_input_delay 0.6 -clock_fall -clock [get_clocks clk] [get_ports c]

 图5 输入端口延迟报告

图6 建立时间时序报告

        可以从图6中看出,输入端口c此时受到时钟clk的下降沿约束。

指定参考端口、引脚

        -reference_pin选项可以指定延迟的参考引脚(它可以是一个叶单元(库单元)引脚或端口),从图3和图6中可以看出,约束端口的参考时钟的clock network latency为0(这是因为我们还没有给参考时钟设置任何延迟),但如果使用了这个选项则clock network latency会包括参考时钟传播到参考引脚的延迟:如果参考时钟是传播时钟,则是源延迟加时钟传播到参考引脚的网络延迟;如果参考时钟是理想时钟,则是源延迟加指定的网络延迟(这是默认的),下面进行举例说明。

        我们给输入端口d设置一个参考端口clk,参考时钟依然为clk,并给时钟clk添加源延迟,如图7所示,注意其中的输入端口d关联的两个clk对象,其中一个是时钟clk,另一个是端口clk。此时的时序报告如图8所示。

set_input_delay 0.7 -reference_pin [get_ports clk] -clock clk [get_ports d]
set_clock_latency 0.1 -source [get_clocks clk]

 图7 输入端口延迟报告

图8 建立时间时序报告

         可以看到,此时的clock network delay包含了时钟clk的源延迟。最后需要注意的是,-reference_pin选项不能和即将谈到的-network_latency_included和-source_latency_included选项一起使用。

包含源、网络延迟

        默认情况下,在进行端口的时序分析时,参考时钟的延迟会被考虑进来。对于理想时钟,延迟包括了源延迟和网络延迟;对于传播时钟,延迟只包括了源延迟,下面对此举例说明。

        首先使用下面的命令,设置时钟clk的网络延迟为0.05,目前它拥有0.1源延迟和0.05网络延迟。

set_clock_latency 0.05 [get_clocks clk]

         然后我们查看输入端口c的时序报告,如图9所示。

图9 建立时间时序报告

        从时序报告中可以看出,clock network delay包含了时钟clk的源延迟0.1+网络延迟0.05。下面我们使用-network_latency_included选项表示时钟的网络延迟已经被包含在delay_value中了,则STA时就不会重复计算网络延迟,如图10、图11所示。

set_input_delay 0.6 -network_latency_included -clock [get_clocks clk] [get_ports c]

 图10 输入端口延迟报告

图11 建立时间时序报告

        图11中展示的时序报告显示捕发射时钟的clock network latency只包含了时钟clk的源延迟,而没有包含网络延迟。

        注意,-network_latency_included选项只能对理想时钟有效,因为默认情况下,传播时钟的clock network latency本就只包含源延迟(除非使用-reference_pin,但-reference_pin不能与这两个选项一起使用)。

        -source_latency_included选项与-network_latency_included选项的用法相似,不同的是,其对理想时钟和传播时钟都有用(很好理解,因为在任何情况下,源延迟是两类时钟共有的)。


指定电平敏感

        -level_sensitive选项指定使用假象的外部发射锁存器,这允许针对锁存器时序进行特殊的分析。如果不指定该选项,则默认使用假象的外部发射触发器。

指定上升、下降沿

        -rise选项用于指定延迟值作用于端口的上升沿、-fall选项用于指定延迟值作用于端口的下降沿。如果这两个选项都没有指定,延迟同时作用于时钟的上升沿和下降沿(相当于它们同时指定)。

        下面的命令改变输入端口c的上升沿输入延迟为0.8,如图12所示。此时的时序报告如图13所示。

set_input_delay 0.8 -clock_fall -rise -clock [get_clocks clk] [get_ports c]

 图12 输入端口延迟报告

 图13 建立时间时序报告

指定最大、最小条件

        -max选项用于指定延迟值作用于最大延迟分析(一般情况下,如果不开启on_chip_variation,这指的是建立时间检查),-min选项用于指定延迟值作用于最小延迟分析(一般情况下,如果不开启on_chip_variation,这指的是保持时间检查)。如果这两个选项都没有指定,延迟同时作用于最大延迟和最小延迟分析(相当于它们同时指定)。

        下面的命令改变输入端口c的最大上升沿输入延迟为0.9,最小上升沿输入延迟为0.5,如图14所示。此时的建立、保持时序报告如图15、图16所示。

set_input_delay 0.9 -max -clock_fall -rise -clock [get_clocks clk] [get_ports c]
set_input_delay 0.5 -min -clock_fall -rise -clock [get_clocks clk] [get_ports c]

 图14 输入端口延迟报告

 图15 建立时间时序报告

 图16 保持时间时序报告

指定不覆盖添加延迟

        -add_delay选项用于以不覆盖和自动推断的形式添加延迟,下面将举例说明。

        假设如图17所示,已经给输入端口c设置了最小条件的输入延迟,现在如果再添加一个参考时钟为clk1的最小条件的上升沿的输入延迟,则会出现图18所示的覆盖情况。

图17 输入端口延迟报告

图18 延迟覆盖情况

        如果继续指定参考时钟为clk1的最小条件的下降沿的输入延迟,则参考时钟为clk的输入延迟会被全部覆盖,如图19所示。

图19 延迟覆盖情况

        这不仅仅出现在不同时钟间,就连相同时钟的不同触发沿(是否指定clock_fall选项,也会出现覆盖)。

        如果使用-add_delay选项,则图18、图19的覆盖情况消失,如图20所示。

图20 延迟不覆盖情况

        -add_delay选项还有一个作用是可以自动推断最差的延迟并覆盖。比如对于图21,如果指定参考时钟为clk的最小条件的输入延迟为0.6并指定-add_delay,则会被忽视,因为0.6大于0.5,这是一个更宽松的最小条件,这是不使用-add_delay选项的命令所不具有的功能。

参考资源链接:[Vivado XDC约束技巧之I/O篇:时序约束与实现](https://wenku.csdn.net/doc/6412b791be7fbd1778d4ac24?utm_source=wenku_answer2doc_content) 在使用Vivado进行FPGA设计时,掌握XDC约束使用是至关重要的,尤其是在进行时序分析时。XDC约束通过一系列命令来指导工具如何处理时序问题,确保设计满足特定的时间要求。下面将结合具体的XDC命令和时序分析的要求,给出一个应用示例。 首先,我们需要了解set_input_delayset_output_delay这两个命令set_input_delay用于设置输入端口的时序要求,而set_output_delay用于设置输出端口的时序要求。这两个命令的基本语法如下: set_input_delay -clock [clock_name] -max [max_delay] -min [min_delay] [input_ports] set_output_delay -clock [clock_name] -max [max_delay] -min [min_delay] [output_ports] 在实际应用中,你可能会遇到这样的情况:输入信号需要在特定的时钟边沿前到达FPGA的输入端口,而输出信号则需要在特定的时钟边沿后被驱动。例如,假设有一个外部时钟clk_ext,频率为100MHz,即周期为10ns,我们需要为FPGA的输入端口input_port设置一个最大延时为2ns,最小延时为1ns的约束,以确保信号能在时钟的上升沿前到达: set_input_delay -clock clk_ext -max 2.0 -min 1.0 [get_ports input_port] 对于输出端口,假设有一个输出信号output_port需要在下一个时钟周期的上升沿后至少1.5ns输出: set_output_delay -clock clk_ext -max 1.5 [get_ports output_port] 除了对输入输出端口直接进行时序约束外,还可以使用set_max_delayset_min_delay命令来指定不经过时序元件的组合逻辑路径的时序要求。例如,如果某个组合逻辑路径在实现时被识别为问题路径,我们可以指定其最大延迟为5ns: set_max_delay -from [get_ports input_port] -to [get_ports output_port] 5.0 使用这些命令时,需要确保为所有关键的输入输出端口添加约束,并针对每一个端口具体分析其在实际电路中的时序要求。同时,也需要注意FPGA的板级走线和外部器件可能引入的延时。 在进行时序分析时,Vivado会根据这些约束进行检查,确保设计满足时序要求。如果发现违反约束的路径,Vivado会报告相关的时序违规,并且可以提供修复建议。 为了更深入地掌握XDC约束和时序分析技巧,建议阅读《Vivado XDC约束技巧之I/O篇:时序约束与实现》一书。这本书详细介绍了XDC约束在I/O时序控制方面的高级应用,将帮助你更好地理解XDC约束的细节以及如何有效地应用于你的FPGA设计中,从而提升设计的整体性能和可靠性。 参考资源链接:[Vivado XDC约束技巧之I/O篇:时序约束与实现](https://wenku.csdn.net/doc/6412b791be7fbd1778d4ac24?utm_source=wenku_answer2doc_content)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

日晨难再

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值