STA学习记录4-输入输出路径约束

1 输入路径约束

由于STA不能检查不受约束路径上的时序约束,因此需要约束所有路径来进行时序分析

当然,如果存在一些输入控制信号,我们并不关心其信号时序,可能并不需要进行时序检查

如下图是一个待分析设计(DUA),UFF0是外部设计,其输出是UFF0的输入,并且UFF0在设计内部,二者的数据通过输入port INP1连接

图片

UFF0和UFF1都是由时钟CLKA驱动的,了解过建立时间和保持时间的应该知道,在第一个时钟上升沿UFF0发送数据,UFF1在下一个时钟上升沿接收数据,因此CLKA的周期应该是数据从UFF0到UFF1的时间

接下来根据上面的图分析时间

对于外部设计,从UFF0到端口INP1时间的是UFF0需要的时间Tclk2q(CK端 -> Q端的时间)+ C1所需的时间Tc1

那么输入端口INP1上的延迟定义指定的是外部延迟的总和(Tclk2q + Tc1)

假设Tclk2q是0.9ns,Tc1是0.6ns,那么输入延迟约束为:

set Tclk2q 0.9
set Tc1 0.6

set_input_delay -clock CLKA -max [expr Tclk2q + Tc1] [get_ports INP1]

根据这个约束可以知道,输入端口INP1的外部延迟是1.5ns (Tclk2q + Tc1),如果时钟CLKA的周期是2ns,那么端口INP1只剩下500ps(2ns - 1.5ns)的时间可以在设计内部传播

也就是说,UFF1要想在下一个时钟上升沿捕获UFF0发送的稳定的数据,Tc2 + UFF1 setup时间必须小于500ps

了解过setup time和hold time计算的应该留意过,电路中延迟都会给出最大时间和最小时间,用下图的例子加上最大时间和最小时间和分析

在这里插入图片描述

最大延迟对应的是最长路径的时间,最小时间对应的是最短路径的时间,通常我们把最大路径称为worst path,最短路径称为best path,在分析setup时,通常是分析worst path

对于这个例子,输入约束为:

created_clock -period 15 -waveform {5 12} [get_ports CLKP]

set_input_delay -clock CLKP -max 6.7 [get_ports INPA]

set_input_delay -clock CLKP -min 3.0 [get_ports INPA]
  • -max指定的是最大延迟
  • -min指定的是最小延迟

如果没有指定,则认为最大延迟和最小延迟一致,比如下面这个约束

set_input_delay -clock clk_core 0.5 [get_ports bist_mode]

set_input_delay -clock clk_core 0.5 [get_pots sad_state]

由于没有 -max 和 -min,因此最大延迟和最小延迟均为0.5ns

2 输出路径约束

与输入路径约束中第一个例子相似,同样是UFF0发送数据,UFF1捕获数据,只不过此时UFF0是内部设计,UFF1是外部设计,如下图所示

在这里插入图片描述

此时端口OUTB到UFF1的传播时间(Tc2 + UFF1的setup time)是输出路径的约束

假设Tc2的时间是3.9ns,UFF1的setup time是1.1ns,那么输出约束可定义为:

set Tc2 3.9
set Tsetup 1.1

set_output_delay -clock CLKQ -max [expr Tc2 + Tsetup] [get_ports OUTB]

再来看下个例子


在这里插入图片描述

最大延迟路径为7.4ns(Tc2的最大值 + Tsetup),最小延迟路径为 -0.2ns(Tc2的最小值 - Thold),因此约束为:

creat_clock -period 20 -waveform {0 15} [get_ports CLKQ]

set_output_delay -clock CLKQ -max 7.4 [get_ports OUTC]

set_output_delay -clock CLKQ -min -0.2 [get_ports OUTC]

下看一个同时具有输入约束和输出约束的例子


image

在这个例子中,DUA具有两个输入端口DATAIN和MCLK,以及一个输出端口DATAOUT

从图中可以看到,时钟周期是100ns

对于DATAIN的波形,红的方框框住的是当前的数据,而蓝色方框框住的是前一次的数据,因此,data2保持稳定的时间最大是25ns,最小是5ns

对于DATAOUT的波形,数据保持稳定的时间最小是 -5ns,最大是20ns,那么约束可定义如下:

creat_clock -period 100 waveform {5 55} [get_ports MCLK]

set_input_delay 25 -clock MCLK -max [get_ports MCLK]
set_input_delay 5 -clock MCLK -min [get_ports MCLK]

set_output_delay 20 -clock MCLK -max [get_ports MCLK]
set_input_delay -5 -clock MCLK -max [get_ports MCLK]

参考

Static Timing Analysis for Nanometer Designs: A Practical Approach

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容