当前位置:网站首页>第三章 标准单元库(下)
第三章 标准单元库(下)
2022-08-04 05:30:00 【KuoGavin】
文章目录
3.5 状态相关时序模型(state-dependent models)
许多组合逻辑时序模块中,其输入和输出之间的时序弧依赖于模块中其他引脚的状态。输入和输出引脚之间的这些时序弧可以是正单边类型时序弧、负单边类型时序弧也可以既是正单边类型又是负单边类型时序弧。异或门( x o r xor xor)以及同或门( x n o r xnor xnor)单元就是一个例子,其输入到输出的时序弧可以是正单边类型的也可以是负单边类型的。 在这种情况下,其时序行为可能会有所不同,具体取决于该模块其他输入的状态。通常,取决于引脚状态的多个时序模型被称为状态相关的时序模型(state-dependent models)。
XOR, XNOR和时序逻辑元件
考虑一个双输入引脚的异或元件。输入引脚 A 1 A1 A1到输出引脚 Z Z Z当另一个输入引脚 A 2 A2 A2是逻辑 0 0 0状态时是正单边类型的,当是逻辑 1 1 1时则是负单边类型的。这两个时序模型是使用状态相关的时序模型指定的。 A 2 A2 A2为逻辑 0 0 0时从 A 1 A1 A1到 Z Z Z的时序模型如下所示:
pin (Z) {
direction : output;
max_capacitance : 0.0842;
function : "(A1^A2)";
timing() {
related_pin : "A1";
when : "!A2";
sdf_cond : "A2 == 1'b0";
timing_sense : positive_unate;
cell_rise(delay_template_3x3) {
index_1 ("0.0272, 0.0576, 0.1184"); /* Input slew */
index_2 ("0.0102, 0.0208, 0.0419"); /* Output load */
values( \
"0.0581, 0.0898, 0.2791", \
"0.0913, 0.1545, 0.2806", \
"0.0461, 0.0626, 0.2838");
}
. . .
}
状态相关条件使用 w h e n when when条件进行指定。尽管元件模型摘要只展示了cell_rise
时延,但其他时序模型(cell_fall
,rise_transition
和fall_transition
表)同样是使用 w h e n when when条件指定的。当 w h e n when when条件所指定的改变时,如 A 2 A2 A2是逻辑 1 1 1的时候,会有一个单独的时序模型如下:
timing() {
related_pin : "A1";
when : "A2";
sdf_cond : "A2 == 1'b1";
timing_sense : negative_unate;
cell_fall(delay_template_3x3) {
index_1 ("0.0272, 0.0576, 0.1184");
index_2 ("0.0102, 0.0208, 0.0419");
values( \
"0.0784, 0.1019, 0.2269", \
"0.0943, 0.1177, 0.2428", \
"0.0997, 0.1796, 0.2620");
}
. . .
}
sdf_cond
用来指定生成SDF文件时要使用的时序弧的条件,详情参见后边3.9节中的实例。
状态相关的时序模型可用于各种类型的时序弧,许多时序逻辑单元会使用状态相关的时序模型指定建立时间或保持时间的时序约束。以下是使用状态相关的时序模型进行保持时间约束的扫描触发器(scan flip-flop)的一个示例。其中,分为 S E SE SE引脚有效或是无效这两类时序模型。
pin (D) {
. . .
timing() {
related_pin : "CK";
timing_type : hold_rising;
when : "!SE";
fall_constraint(hold_template_3x3) {
index_1("0.08573, 0.2057, 0.3926");
index_2("0.08573, 0.2057, 0.3926");
values("-0.05018, -0.02966, -0.00919",\
"-0.0703, -0.05008, -0.0091",\
"-0.1407, -0.1206, -0.1096");
}
. . .
}
}
上述时序模型是在当SE
引脚为 0 0 0的时候使用,当SE
引脚为 1 1 1的时候即 w h e n when when条件为 1 1 1时的模型是相似的。
可同时使用状态相关时序模型和状态无关时序模型用以指定一些时序关系。其中,时序分析将使用状态相关时序模型如果元件的状态已知且包括在一种状态相关的时序模型中。如果状态相关时序模型并不包括元件的条件,则使用状态无关时序模型的时序。例如,考虑保持时间约束只由一个SE
引脚为逻辑 0 0 0的条件指定,而没有为逻辑 1 1 1的独立时序模型的情况。在该场景下,如果SE
引脚置为 1 1 1,此时便使用状态无关时序模型。如果此时状态无关时序模型并没有指定,就意味着没有任何有效保持时间约束。
可以为时序库中的任何属性进行指定状态相关模型。因此可存在功率、漏电功率、过渡时间、上升和下降延迟、时序约束等状态相关的模型。下面给出了一个状态相关的漏电功率模型:
leakage_power() {
when : "A1 !A2";
value : 259.8;
}
leakage_power() {
when : "A1 A2";
value : 282.7;
}
3.6 黑盒接口时序模型(interface timing model for a black box)
该部分描述的是黑盒(任意模块或块)的 I O IO IO接口的时序弧。一个时序模型捕获黑盒的 I O IO IO接口的时序。黑盒接口模型可以同时具有组合逻辑时序弧和时序逻辑时序弧。一般而言,这些时序弧也可以是状态相关的。
如上图所示,时序弧可以归为如下几类:
- 输入到输出的组合逻辑时序弧(input to output combinational arc):对应于从输入到输出的直接组合逻辑路径,比如输入引脚 F I N FIN FIN到输出引脚 F O U T FOUT FOUT;
- 输入时序时序弧(input sequential arc):对应于连接到触发器D引脚( D − p i n D-pin D−pin)的输入端口的建立时间或保持时间。通常,在将模块的输入端口连接到触发器的D引脚之前,可以存在一些组合逻辑。这样的一个例子是在输入端口 D I N DIN DIN上相对于时钟端口 A C L K ACLK ACLK的建立时间检查;
- 异步输入时序弧(asynchronous input arc):与触发器的异步输入引脚的恢复时间或移除时间约束类似。例子是输入引脚 A R S T ARST ARST连接至触发器 U F F 0 UFF0 UFF0的异步置零引脚 C L CL CL;
- 输出时序时序弧(output sequential arc):与触发器时钟引脚到 Q Q Q引脚的输出传播时延时序类似。一般而言,在模块输出和触发器输出之间可存在组合逻辑。例子就是从时钟引脚 B C L K BCLK BCLK到触发器 U F F 1 UFF1 UFF1的输出端口 D O U T DOUT DOUT之间。
除了以上的时序弧,对于黑盒的外部时钟引脚可做脉冲宽度(pulse width)检查。同时可能定义黑盒的内部节点并定义这些节点间的衍生时钟(generated clocks),指定这些节点间的时序弧。总而言之,一个黑盒模型可具有如下时序弧:
- 纯组合逻辑路径的输入到输出时序弧(Input to output timing arcs);
- 从同步输入端口到相关时钟端口的建立时间和保持时间时序弧(Setup and hold timing arcs);
- 从异步输入端口到相关时钟端口的恢复时间和撤销时间时序弧(Recovery and removal timing arcs);
- 从时钟端口到输出端口的输出传播延迟(Output propagation delay);
如上所述的接口时序模型并非旨在捕获黑盒的内部时序,而只是捕获其接口上的时序。
3.7 高级时序建模(advanced timing modeling)
非线性延迟模型(NLDM)这类的时序模型是基于输出负载电容和输入过渡时间来表示通过时序弧的延迟的。实际上,单元输出的负载不仅包括电容还应当包括互连电阻(interconnect resistance)。由于NLDM方法假设输出负载为纯电容,因此互连电阻成为了一个问题。即使互连电阻不为零,但当互连电阻的影响较小时,仍使用了这些NLDM模型。在互连电阻存在的情况下,延迟的计算方法通过在单元的输出端获得等效的有效电容(effective capacitance)来改进NLDM模型。延迟计算工具中使用的“有效”电容法获得的等效电容可保证单元输出延迟与具有RC互连的单元输出延迟相同。有效电容法将在5.2节里的延迟计算部分再详细介绍。
随着特征尺寸的缩小,由于波形变得高度非线性,互连电阻的影响会导致较大的误差,各种建模方法为单元的输出驱动能力提供了更高的精度。通常,这些方法通过用等效电流源对驱动器(driver)的输出级进行建模来获得更高的精度。例如CCS(Composite Current Source)复合电流源或ECSM(Effective Current Source Model)有效电流源模型:CCS时序模型通过使用随时间变化且依赖电压的电流源,为建模单元输出驱动能力提供了更高的精度。通过为不同情况下的接收引脚电容(receiver pin capacitance)和输出充电电流(output charging currents)指定详细时序模型,可以提供时序信息。接下来描述CCS模型的细节。
3.7.1 接收引脚电容(receiver pin capacitance)
接收引脚电容对应于NLDM模型中指定的输入引脚电容。不像NLDM模型的引脚电容,CCS模型允许在过渡波形的不同部分进行分开指定接受引脚电容。由于互连RC和由元件内部输入设备的米勒效应(Miller effect)所引起的等效非线性输入电容,接收引脚电容值会在过渡波形的不同点处发生变化。该电容值因此在最初/起始部分(leading portion)与其尾部部分(tailing portion)波形的建模是不同的。
接收电容可以在引脚级别(pin level)上指定(如NLDM模型),通过该引脚的所有时序弧都使用该电容值;或者,接收电容可以在时序弧(timing arc level)级别上指定,在这种情况下可以为不同的时序弧指定不同的电容模型。接下来将介绍这两种指定接收引脚电容的方法:
- 在引脚级别指定电容(specifying capacitance at the pin level):
当在引脚级别指定,接收引脚电容的指定一维表格如下:
pin (IN) {
. . .
receiver_capacitance1_rise ("Lookup_table_4") {
index_1: ("0.1, 0.2, 0.3, 0.4"); /* Input transition */
values("0.001040, 0.001072, 0.001074, 0.001085");
}
i n d e x _ 1 index\_1 index_1指定了该接收引脚的输入过渡时间索引值。一维表格中的 v a l u e s values values指定了输入引脚上用于上升沿波形的接收电容。
与上面示例中的receiver_capacitance1_rise
表格类似,receiver_capacitance2_rise
表格为波形的后续部分指定了输入引脚上用于上升沿波形的接收电容。而下降电容(用于下降沿输入波形的引脚电容)分别由表格receiver_capacitance1_fall
和receiver_capacitance2_fall
指定。
- 在时序弧级别指定电容(specifying capacitance at the timing arc level):
接收引脚电容值也可以在时序弧级别上,根据输入过渡时间和输出负载以二维表格的形式来指定。以下给出了在时序弧级别指定电容的示例。本示例指定了输入引脚 I N IN IN上波形初始部分的接收引脚上升电容,该电容取决于输入引脚 I N IN IN上的过渡时间和输出引脚 O U T OUT OUT上的负载。
pin (OUT) {
. . .
timing () {
related_pin : "IN" ;
. . .
receiver_capacitance1_rise ("Lookup_table_4x4") {
index_1("0.1, 0.2, 0.3, 0.4"); /* Input transition */
index_2("0.01, 0.2, 0.4, 0.8"); /* Output capacitance */
values("0.001040 , 0.001072 , 0.001074 , 0.001075", \
"0.001148 , 0.001150 , 0.001152 , 0.001153", \
"0.001174 , 0.001172 , 0.001172 , 0.001172", \
"0.001174 , 0.001171 , 0.001177 , 0.001174");
}
. . .
}
. . .
}
上面的示例指定了receiver_capacitance1_rise
的模型,库中也包含有关receiver_capacitance2_rise
、receiver_capacitance1_fall
和receiver_capacitance2_fall
的类似定义。
下表总结了四种不同类型的接收电容类型。如上所述,可以在引脚级别将它们指定为一维表格,或在时序弧级别将它们指定为二维表格。
3.7.2 输出电流(output current)
在CCS模型中,非线性时序表现为输出电流。输出电流信息被指定为一个查找表,该表的查找取决于输入过渡时间和输出负载。
输出电流会根据输入过渡时间和输出负载电容的不同组合被指定,对于每一个组合,都将分别指定一个输出电流波形。本质上,此处的波形指的是随时间变化的输出电流值。以下示例使用output_current_fall
指定了用于下降输出波形的输出电流:
pin (OUT) {
. . .
timing () {
related_pin : "IN" ;
. . .
output_current_fall () {
vector ("LOOKUP_TABLE_1x1x5") {
reference_time : 5.06; /* Time of input crossing threshold */
index_1("0.040"); /* Input transition */
index_2("0.900"); /* Output capacitance */
index_3("5.079e+00, 5.093e+00, 5.152e+00,
5.170e+00, 5.352e+00");/* Time values */
/* Output charging current: */
values("-5.784e-02, -5.980e-02, -5.417e-02,
-4.257e-02, -2.184e-03");
}
. . .
}
. . .
}
. . .
}
reference_time
是指输入波形超过延迟阈值的时间, i n d e x _ 1 index\_1 index_1和 i n d e x _ 2 index\_2 index_2是指输入过渡时间和所使用的输出负载电容,而 i n d e x _ 3 index\_3 index_3是时间。 i n d e x _ 1 index\_1 index_1和 i n d e x _ 2 index\_2 index_2(输入过渡时间和输出负载电容)只能有一个值, i n d e x _ 3 index\_3 index_3是指时间值,表值是指相应的输出电流。因此,对于给定的输入过渡时间和输出负载,输出电流波形是时间的函数。同样,还指定了用于输入过渡时间和输出电容的其他组合的查找表。
类似地可以使用output_current_rise
去指定上升输出波形的输出电流。
3.7.3 串扰噪声分析(models for crosstalk noise analysis)
本节介绍用于串扰噪声(或毛刺)分析的CCS模型,又被称为CCSN(CCS Noise)模型。CCS噪声模型是结构(structural)模型,并表示为单元内的不同 沟道连接块-CCB(Channel Connected Blocks) 。
什么是CCB? CCB是指单元的源极(source)-漏极(drain)的沟道(channel)连接部分。例如,单级(single stage)单元(例如反相器、与非门和或非门单元)仅包含一个CCB,即整个单元仅通过一个沟道连接区域进行连接,而多级单元(例如与门和或门单元)包含多个CCB。
通常仅为由单元输入驱动的第一个CCB和驱动单元输出的最后一个CCB指定CCSN模型,并且会使用稳态电流、输出电压和传播噪声模型来指定这些CCSN模型。
对于单级组合逻辑单元(例如与非门和或非门单元),将为每个时序弧指定CCS噪声模型。 这些单元只有一个CCB,因此模型将会是从单元的输入引脚到输出引脚的。
以下是一个与非门单元的模型示例:
pin (OUT) {
. . .
timing () {
related_pin : "IN1";
. . .
ccsn_first_stage() {
/* First stage CCB */
is_needed : true;
stage_type : both; /*CCB contains pull-up and pull-down*/
is_inverting : true;
miller_cap_rise : 0.8;
miller_cap_fall : 0.5;
(ccsn_dc) {
index_1 ("-0.9, 0, 0.5, 1.35, 1.8"); /* Input voltage */
index_2 ("-0.9, 0, 0.5, 1.35, 1.8"); /* Output voltage*/
values ( \
"1.56, 0.42, . . ."); /* Current at output pin */
}
. . .
output_voltage_rise () {
vector (ccsn_ovrf) {
index_1 ("0.01"); /* Rail-to-rail input transition */
index_2 ("0.001"); /* Output net capacitance */
index_3 ("0.3, 0.5, 0.8"); /* Time */
values ("0.27, 0.63, 0.81");
}
. . .
}
output_voltage_fall () {
vector (ccsn_ovrf) {
index_1 ("0.01"); /* Rail-to-rail input transition */
index_2 ("0.001"); /* Output net capacitance */
index_3 ("0.2, 0.4, 0.6"); /* Time */
values ("0.81, 0.63, 0.27");
}
. . .
}
propagated_noise_low () {
vector (ccsn_pnlh) {
index_1 ("0.5"); /* Input glitch height */
index_2 ("0.6"); /* Input glitch width */
index_3 ("0.05"); /* Output net capacitance */
index_4 ("0.3, 0.4, 0.5, 0.7"); /* Time */
values ("0.19, 0.23, 0.19, 0.11");
}
propagated_noise_high () {
. . .
}
}
}
现在我们描述CCS噪声模型的属性:ccsn_first_stage
字段表示该模型用于与非门单元的第一级CCB。如前所述,与非门单元只有一个CCB。is_needed
字段几乎始终为true,但天线单元(antenna cell)等非功能性单元除外。stage_type
字段中的both表示该级CCB同时具有上拉(pull-up)和下拉(pull-down)结构。miller_cap_rise
和miller_cap_fall
分别代表输出上升和下降过渡时的米勒(Miller)电容值。
直流电流(DC Current)
dc_current
表格表示了输出引脚输出的直流电流在不同输入和输出引脚电压组合下的情况。index_1
和index_2
分别指定了输入和输出电压。二维表格中的values
值代表了CCB输出引脚输出的DC电流。输入电压和输出电流均在库单元中有指定(通常是Volt和mA)。比如与非与门单元的输入引脚 I N 1 IN1 IN1到输出引脚 O U T OUT OUT的CCS噪声模型示例,当输入电压为-0.9V并且输出电压为0V时,输出端的直流电流为 0.42 0.42 0.42mA。
输出电压(output voltage)
output_voltage_rise
和output_voltage_fall
表中分别包含CCB输出上升和下降的时序信息。这些表格是CCB输出节点的多维表格,指定了针对不同输入过渡时间和输出电容的上升和下降输出电压。每个表格的index_1
指定了轨到轨输入过渡时间,index_2
指定了输出电容,index_3
指定了输出电压超过特定阈值点的时间(在这种情况下,为0.9V的 V d d Vdd Vdd电源的30%,70%和90%)。在每个多维表中,电压交叉点(voltage crossing points)是固定的,并且CCB输出节点与电压交叉时的时间值在index_3
中指定。
噪声传播(propagated noise)
propagated_noise_high
模型和propagated_noise_low
模型指定的多维表格提供了通过CCB的噪声传播信息。这些模型表征了串扰毛刺(glitch)(或噪声)从CCB的输入到输出的传播,表征时输入端使用了对称的三角波。噪声传播的多维表被组织为了多个表,这些表指定了CCB输出处的毛刺波形。这些多维表包含:
- 输入毛刺幅值(
index_1
) - 输入毛刺宽度(
index_2
) - CCB输出电容(
index_3
) - 时间(
index_4
)
表格中的数值指定了CCB输出电压(或通过CCB传播的噪声)。
两级单元的噪声模型(noise models for two-stage cells)
与单级单元一样,两级单元(例如与门和或门单元)的CCS噪声模型通常被描述为时序弧的一部分。由于这些单元包含两个单独的CCB,因此需要分别为ccsn_first_stage和ccsn_last_stage指定噪声模型。例如,对于两输入与门单元,CCS噪声模型由第一级和最后一级相互独立的模型组成,如下所示:
pin (OUT) {
. . .
timing () {
related_pin : "IN1";
. . .
ccsn_first_stage() {
/* IN1 to internal node between stages */
. . .
}
ccsn_last_stage() {
/* Internal node to output */
. . .
}
. . .
}
timing () {
related_pin : "IN2";
. . .
ccsn_first_stage() {
/* IN2 to internal node between stages */
. . .
}
ccsn_last_stage() {
/* Internal node to output */
/* Same as from IN1 */
. . .
}
. . .
}
. . .
}
为 I N 2 IN2 IN2引脚指定的ccsn_last_stage
中的模型与为 I N 1 IN1 IN1引脚指定的ccsn_last_stage
中的模型是相同的。
多级单元和时序单元的噪声模型(noise models for multi-stage and sequential cells)
通常将较为复杂的组合逻辑单元或时序逻辑单元的CCS噪声模型描述为引脚规范(pin specification)的一部分,这与前面在单级或二级单元的CCS噪声模型中以引脚对(pin-pair)为基础,指定为时序弧的一部分是不同的。通常由所有输入引脚的ccsn_first_stage
模型和所有输出引脚的ccsn_last_stage
模型描述复杂的多级和时序单元。这些单元的CCS噪声模型不是时序弧的一部分,但通常是为引脚指定的。
如果输入和输出之间的内部路径多达两级CCB,则噪声模型也可以表示为引脚对时序弧的一部分。通常,多级单元中可以将某些CCS噪声模型指定为引脚对时序弧的一部分,而其他一些噪声模型可以通过引脚说明来指定。
下面的示例使用引脚说明以及时序弧的一部分指定了CCS噪声模型:
pin (CDN) {
. . .
}
pin (CP) {
. . .
ccsn_first_stage() {
. . .
}
}
pin (D) {
. . .
ccsn_first_stage() {
. . .
}
}
pin (Q) {
. . .
timing() {
related_pin : "CDN";
. . .
ccsn_first_stage() {
. . .
}
ccsn_last_stage() {
. . .
}
}
}
pin (QN) {
. . .
ccsn_last_stage() {
. . .
}
}
请注意,上述触发器单元的某些CCS模型是通过引脚定义的。使用输入引脚上的引脚说明定义的指定为ccsn_first_stage
,而输出引脚QN上的CCS模型指定为ccsn_last_stage
。另外,两级CCS噪声模型被描述为 C D N CDN CDN到 Q Q Q的时序弧的一部分。因此本示例表明,一个单元可以具有指定为引脚说明一部分和时序弧一部分的CCS模型。
3.7.4 其它噪声模型(other noise models)
除了上述CCS噪声模型之外,某些单元库还提供了其他模型来表征噪声。早在CCS噪声模型出现之前,就已经使用了其中一些模型。如果CCS噪声模型可用,则不需要这些附加模型。为了完整起见,我们在下面介绍一些早期的噪声模型。
直流裕度模型(Models for DC margin):直流裕度是指单元输入引脚允许的最大直流变化(DC variation),它将使单元保持稳定状态,即不会在输出端引起毛刺。例如,低电平输入的直流裕度指的是输入引脚上最大的直流电压值,而不会在输出端引起任何电平跳变。
抗扰度模型(Models for noise immunity):抗扰度模型指定输入引脚可以允许的毛刺幅度(glitch magnitude)。通常以二维表的形式来描述,其中毛刺宽度和输出电容为两个索引量,表中的值对应于输入引脚可以允许的毛刺幅度。这意味着任何小于指定幅度和宽度的毛刺都不会通过单元传播。抗扰度模型还具有不同变形形式,例如:
- noise_immunity_high
- noise_immunity_low
- noise_immunity_above_high
- noise_immunity_below_low
3.8 功耗建模(power dissipation modeling)
单元库包含了与元件功耗相关的信息。包括有功功耗(active power)和待机(standby)/漏电(leakage)功率。顾名思义,有功功率和元件在设计中的行为相关,待机功率是待机模式下的功率,这主要是漏电引起的。
3.8.1 有功功率(active power)
有功功率与单元输入和输出引脚上的行为有关。单元中的有功功率是由于输出负载的充电以及内部的开关引起的,通常分别称这两个为输出开关功率(output switching power)和内部开关功率(internal switching power)。
输出开关功率与单元类型无关,仅取决于输出负载电容、开关频率和供电电源;内部开关功率取决于单元的类型,因此该值会包含在单元库中,接下来将介绍库中的内部开关功率。
内部开关功率在单元库中被称为internal power
,这是当单元的输入或输出处于活动状态时单元内部的功耗。对于组合逻辑单元,输入引脚的电平跳变会导致输出引脚的电平跳变,从而导致内部开关功耗。例如,每当输入引脚电平跳变(上升或下降)时,反相器单元就会消耗功率。 库中描述的内部开关功率如下所示:
pin (Z1) {
. . .
power_down_function : "!VDD + VSS";
related_power_pin : VDD;
related_ground_pin : VSS;
internal_power () {
related_pin : "A";
power (template_2x2) {
index_1 ("0.1, 0.4"); /* Input transition */
index_2 ("0.05, 0.1"); /* Output capacitance */
values ( /* 0.05 0.1 */ \
/* 0.1 */ "0.045, 0.050", \
/* 0.4 */ "0.055, 0.056");
}
}
}
上面的示例展示了单元从输入引脚 A A A到输出引脚 Z 1 Z1 Z1的功耗,模板中的 2 × 2 2\times 2 2×2表是根据引脚 A A A上的输入过渡时间和引脚 Z 1 Z1 Z1上的输出电容来确定的。注意,尽管该表包含了输出电容,但表中的值仅对应于内部开关,不包括输出电容的影响。该值表示每个开关转换(上升或下降)时在单元中耗散的内部能量,单位是从库中的其他单位导出的(通常电压以伏特 V V V为单位,电容以皮法拉 p F pF pF为单位,并且表示为以皮焦耳 p J pJ pJ为单位的能量)。因此,库中的内部开关功率实际上是指每次开关转换时内部所消耗的能量。
除了内部开关功率表之外,上面的示例中还给出了电源引脚、接地引脚的说明,并且指定了可将单元断电的条件。这些构造允许在设计和方案中使用多个电源,在这些情况下可以关闭不同的电源。下面展示了单元的电源引脚说明:
cell (NAND2) {
. . .
pg_pin (VDD) {
pg_type : primary_power;
voltage_name : COREVDD1;
. . .
}
pg_pin (VSS) {
pg_type : primary_ground;
voltage_name : COREGND1;
. . .
}
}
功率描述的语法允许上升和下降(指输出过渡方向)功率使用单独的构造。就像时序弧一样,功率描述也可能取决于状态。例如,可以将异或门( X O R XOR XOR)单元的状态相关功耗指定为取决于各种输入的状态。
对于组合逻辑单元,开关功率是基于输入-输出引脚对指定的。但是,对于诸如具有互补输出 Q Q Q和 Q N QN QN的触发器之类的时序单元来说, C L K − > Q CLK-> Q CLK−>Q转换也会导致 C L K − > Q N CLK-> QN CLK−>QN转换。因此,该库可以将内部开关功率指定为三维表格,如下所示。下例中的三个维度分别是 C L K CLK CLK的输入压摆(input slew)和 Q Q Q与 Q N QN QN的输出电容。
pin (Q) {
. . .
internal_power() {
related_pin : "CLK";
equal_or_opposite_output : "QN";
rise_power(energy_template_3x2x2) {
index_1 ("0.02, 0.2, 1.0"); /* Clock transition */
index_2 ("0.005, 0.2"); /* Output Q capacitance */
index_3 ("0.005, 0.2"); /* Output QN capacitance */
values ( /* 0.005 0.2 */ /* 0.005 0.2 */ \
/* 0.02 */ "0.060, 0.070", "0.061, 0.068", \
/* 0.2 */ "0.061, 0.071", "0.063, 0.069", \
/* 1.0 */ "0.062, 0.080", "0.068, 0.075");
}
fall_power(energy_template_3x2x2) {
index_1 ("0.02, 0.2, 1.0");
index_2 ("0.005, 0.2");
index_3 ("0.005, 0.2");
values ( \
"0.070, 0.080", "0.071, 0.078", \
"0.071, 0.081", "0.073, 0.079", \
"0.066, 0.082", "0.068, 0.085");
}
}
即使输出和内部状态没有转换,也可以消耗开关功率。一个常见的例子是在触发器的时钟引脚上切换(toggle)的时钟。触发器在每次时钟切换时都会消耗功率,通常是由触发器单元内部反相器的开关所带来的。即使触发器输出未切换,也会消耗由于时钟引脚切换引起的功率。因此,对于时序逻辑单元,输入引脚功率(input pin power)是指单元内部的功耗,即输出不切换时的功耗。以下例子中描述了输入引脚功率:
cell (DFF) {
. . .
pin (CLK) {
. . .
rise_power () {
power (template_3x1) {
index_1 ("0.1, 0.25, 0.4"); /* Input transition */
values ( /* 0.1 0.25 0.4 */ \
"0.045, 0.050, 0.090");
}
}
fall_power () {
power (template_3x1) {
index_1 ("0.1, 0.25, 0.4");
values ( \
"0.045, 0.050, 0.090");
}
}
}
. . .
}
述例子展示了 C L K CLK CLK引脚切换时的功率说明,它表示即使输出未切换,时钟切换也会导致功耗。
时钟引脚的功率是否被重复计算了?
注意,触发器还包含由于 C L K − > Q CLK-> Q CLK−>Q转换引起的功耗。因此重要的是, C L K − > Q CLK-> Q CLK−>Q功率描述表格中的值是不包括与 C L K CLK CLK内部功率有关的影响的, C L K CLK CLK内部功率与输出 Q Q Q不切换时的状况相对应。
以上内容涉及到了应用工具对功率表使用的一致性,能够确保在功率计算期间与时钟输入有关的内部功率不会被重复计算。
3.8.2 漏电功率(leakage power)
大多数标准单元的设计都仅在输出或状态发生变化时才消耗功率。单元通了电但没有任何行为时,所有功耗都归因于泄漏电流(leakage current)。泄漏可能是由于MOS器件的亚阈值电流引起的,也可能是由于通过栅极氧化物的隧穿电流引起的。在以前的CMOS工艺技术中,漏电功率可以忽略不计,并且在设计过程中并不是主要考虑因素。但是,随着技术的发展,漏电功率变得越来越大,与有功功率相比,漏电功率已经无法忽略不计了。
如上所述,漏电功率主要有两个来源:MOS器件中的亚阈值电流和栅氧化物隧穿。通过使用高阈值电压单元,可以降低亚阈值电流;然而,由于高阈值电压单元的速度较低而存在一个折中(trade-off):高阈值电压单元的漏电较小,但速度较慢。同样,低阈值电压单元的漏电较大,但速度较高。无论是使用高阈值电压还是低阈值电压的单元,栅极氧化物隧穿带来的影响都差不多。因此,控制漏电功率的可能方法是使用高阈值电压的单元。类似于在高阈值电压和标准阈值电压单元之间进行选择,设计中使用的单元强度(strength)也是一种漏电和速度之间的折中。强度较高的单元具有较高的漏电功率,但速度较高。与功率管理有关的折中将在10.6节中详细介绍。
MOS器件的亚阈值泄漏电流与温度具有很强的非线性特性,在大多数工艺技术中,随着器件温度从25°C升高到125°C,亚阈值泄漏电流可能会增加10倍至20倍。栅极氧化物隧穿带来的影响基本不随温度或器件阈值电压而改变,在100nm及以上工艺技术中可以忽略的栅极氧化物隧穿已成为65nm或更精细技术在较低温度下漏电的主要原因。例如,对于65nm或更精细的工艺技术,栅极氧化物隧穿漏电量可能等于室温下的亚阈值漏电量。而在高温下,亚阈值漏电仍然是导致漏电功率的主要因素。
库中的每个单元都被指定了漏电功率。例如,反相器单元的漏电功率可能描述如下:
cell_leakage_power : 1.366;
这是单元中耗散的漏电功率,漏电功率单位在库的头文件中指定,通常以纳瓦为单位。通常,漏电功率还取决于单元的状态,可以使用when
条件指定状态相关值。
例如,一个反相器单元 I N V 1 INV1 INV1可以具有如下描述:
cell_leakage_power : 0.70;
leakage_power() {
when : "!I";
value : 1.17;
}
leakage_power() {
when : "I";
value : 0.23;
}
其中 I I I是反相器单元的输入引脚。需要注意的是,上例中的描述还包括了一个默认值(在when条件之外),该默认值通常是在when条件内指定值的平均值。
3.9 单元库中的其它属性(other attributes in cell library)
除时序信息外,库中的单元描述还指定了单元面积、功能和时序弧的SDF条件。这些将在本节中进行简要描述,有关更多详细信息,请参阅Liberty手册。
单元面积
面积描述中指定了一个单元或一组单元的面积:
area:2.35
上面指定了单元的面积为2.35个面积单位,这可以代表单元实际使用的硅面积,也可以是面积的相对测量值。
单元功能
功能描述中指定了一个引脚或一组引脚的功能:
pin (Z) {
function: "IN1 & IN2";
. . .
}
上面指定了一个两输入与门单元输出引脚 Z Z Z的逻辑功能。
SDF条件
SDF条件属性支持标准延迟格式SDF(Standard Delay Format)文件的生成以及在反标(backannotation)期间的条件匹配。就像when
条件指定用于时序分析的状态相关模型的条件一样,SDF标注(annotation)时状态相关时序的相应条件由sdf_cond
来表示。以下是一个示例:
timing() {
related_pin : "A1";
when : "!A2";
sdf_cond : "A2 == 1'b0";
timing_sense : positive_unate;
cell_rise(delay_template_7x7) {
. . .
}
}
3.10 特征和工作条件(characterization and operating conditions)
单元库中还会指定创建该库的特征(characterization)和工作条件。例如,库文件的头部可能包含以下内容:
nom_process : 1;
nom_temperature : 0;
nom_voltage : 1.1;
voltage_map(COREVDD1, 1.1);
voltage_map(COREGND1, 0.0);
operating_conditions("BCCOM"){
process : 1;
temperature : 0;
voltage : 1.1;
tree_type : "balanced_tree";
}
工作条件(nom_process、nom_temperature和nom_voltage)指定了对库进行表征的工艺、温度和电压, 也指定了使用该库中单元的条件。如果特征和工作条件不同,则需要对延迟计算过程中获得的时序值进行降额(derate)处理, 这可以通过使用库中指定的降额系数( k k k-系数)来实现。
在除用于表征之外的条件下使用降额获得时序值会导致时序计算不准确。只有当无法在预期的条件下表征库时,才能使用降额过程。
什么是工艺变量(process variable)?
与作为物理量的温度和电压不同,工艺是不可量化的变量。就数字特征和验证而言,它可能是缓慢(slow)、典型(typical)或快速(fast)的工艺之一。因此,工艺值为1.0(或任何其它值)是什么意思?答案在下面。
库的表征是一个耗时的过程,针对各种工艺角(process corner)对库进行表征可能需要数周的时间,工艺变量的设置使得以特定工艺角为特征的库可以用于不同工艺角的时序计算。工艺的 k k k-系数可用于完成从特征库工艺到目标工艺的延迟降额。如上所述,降额系数的使用在时序计算期间引入了不准确性,跨工艺条件进行降额尤其不准确,因此很少采用。总而言之,指定不同工艺变量值(例如1.0或任何其它值)的唯一功能就是在少数情况下允许跨工艺条件进行降额处理。
3.10.1 使用K-系数降额(derating using K-factors)
如上所述,当工作条件不同于表征条件时,降额系数(或称k-系数)可用于计算延迟, k k k-系数是近似系数。库中 k k k-系数的示例如下所示:
/* k-factors */
k_process_cell_fall : 1;
k_process_cell_leakage_power : 0;
k_process_cell_rise : 1;
k_process_fall_transition : 1;
k_process_hold_fall : 1;
k_process_hold_rise : 1;
k_process_internal_power : 0;
k_process_min_pulse_width_high : 1;
k_process_min_pulse_width_low : 1;
k_process_pin_cap : 0;
k_process_recovery_fall : 1;
k_process_recovery_rise : 1;
k_process_rise_transition : 1;
k_process_setup_fall : 1;
k_process_setup_rise : 1;
k_process_wire_cap : 0;
k_process_wire_res : 0;
k_temp_cell_fall : 0.0012;
k_temp_cell_rise : 0.0012;
k_temp_fall_transition : 0;
k_temp_hold_fall : 0.0012;
k_temp_hold_rise : 0.0012;
k_temp_min_pulse_width_high : 0.0012;
k_temp_min_pulse_width_low : 0.0012;
k_temp_min_period : 0.0012;
k_temp_rise_propagation : 0.0012;
k_temp_fall_propagation : 0.0012;
k_temp_recovery_fall : 0.0012;
k_temp_recovery_rise : 0.0012;
k_temp_rise_transition : 0;
k_temp_setup_fall : 0.0012;
k_temp_setup_rise : 0.0012;
k_volt_cell_fall : -0.42;
k_volt_cell_rise : -0.42;
k_volt_fall_transition : 0;
k_volt_hold_fall : -0.42;
k_volt_hold_rise : -0.42;
k_volt_min_pulse_width_high : -0.42;
k_volt_min_pulse_width_low : -0.42;
k_volt_min_period : -0.42;
k_volt_rise_propagation : -0.42;
k_volt_fall_propagation : -0.42;
k_volt_recovery_fall : -0.42;
k_volt_recovery_rise : -0.42;
k_volt_rise_transition : 0;
k_volt_setup_fall : -0.42;
k_volt_setup_rise : -0.42;
当延迟计算过程中工作条件的工艺、电压或温度与库中的标称条件不同时,可使用这些系数来进行计算。注意,k_volt
系数为负,这意味着延迟随着电压的增加而减小,而k_temp
因子为正,这意味着延迟通常随温度的升高而增加(除非单元具有2.10节中所描述的温度反转现象)。 k k k-系数的用法如下:
R e s u l t w i t h d e r a t i n g = O r i g i n a l _ v a l u e × ( 1 + k _ p r o c e s s × Δ P r o c e s s + k _ v o l t × Δ V o l t + k _ t e m p × Δ T e m p ) Result\, with\, derating = Original\_value \times \\ (1+k\_process\times \Delta Process\\ +k\_volt\times \Delta Volt \quad \quad \, \, \\ +k\_temp \times \Delta Temp) \quad Resultwithderating=Original_value×(1+k_process×ΔProcess+k_volt×ΔVolt+k_temp×ΔTemp)
3.10.2 库中各单位(library units)
单元描述中数值的单位都是在库中指定的,可使用Liberty命令集在库文件中声明单位。电压、时间、电容和电阻的单位声明如下例所示:
library("my_cell_library") {
voltage_unit : "1V";
time_unit : "1ns";
capacitive_load_unit (1.000000, pf);
current_unit : 1mA;
pulling_resistance_unit : "1kohm";
. . .
}
在本书中,我们假设库中时间单位为纳秒(ns),电压单位为伏特(V),每转换一次的内部功率单位为皮焦耳(pJ),漏电功率单位为纳瓦(nW),电容单位为皮法(pF),电阻单位为Kohms,面积单位为平方微米,但明确有特殊说明的情况除外。
边栏推荐
- 【论文阅读】Anchor-Free Person Search
- PCL窗口操作
- 双向LSTM
- AWS使用EC2降低DeepRacer的训练成本:DeepRacer-for-cloud的实践操作
- MNIST手写数字识别 —— 从二分类到十分类
- YOLOV4流程图(方便理解)
- Golang环境变量设置(二)--GOMODULE&GOPROXY
- 剪映专业版字幕导出随笔
- MNIST handwritten digit recognition, sorted by from two to ten
- How to get started with MOOSE platform - an example of how to run the official tutorial
猜你喜欢
强化学习中,Q-Learning与Sarsa的差别有多大?
Use of double pointers
fuser 使用—— YOLOV5内存溢出——kill nvidai-smi 无pid 的 GPU 进程
Deep Learning Theory - Initialization, Parameter Adjustment
【论文阅读】Anchor-Free Person Search
[Deep Learning Diary] Day 1: Hello world, Hello CNN MNIST
MNIST Handwritten Digit Recognition - Building a Perceptron from Zero for Two-Classification
浅谈游戏音效测试点
PyTorch
多层LSTM
随机推荐
剪映专业版字幕导出随笔
[Deep Learning 21 Days Learning Challenge] Memo: What does our neural network model look like? - detailed explanation of model.summary()
TensorFlow2 study notes: 8. tf.keras implements linear regression, Income dataset: years of education and income dataset
机器学习——分类问题对于文字标签的处理(特征工程)
审稿意见回复
"A minute" Copy siege lion log 】 【 run MindSpore LeNet model
MNIST Handwritten Digit Recognition - Lenet-5's First Commercial Grade Convolutional Neural Network
迅雷关闭自动更新
Transformer
The use of the attribute of the use of the animation and ButterKnife
【Copy攻城狮日志】飞浆学院强化学习7日打卡营-学习笔记
0, deep learning 21 days learning challenge 】 【 set up learning environment
AWS使用EC2降低DeepRacer的训练成本:DeepRacer-for-cloud的实践操作
makefile基础学习
基于BiGRU和GAN的数据生成方法
图像resize
Amazon Cloud Technology Build On-Amazon Neptune's Knowledge Graph-Based Recommendation Model Building Experience
Golang environment variable settings (2)--GOMODULE & GOPROXY
【论文阅读】Multi-View Spectral Clustering with Optimal Neighborhood Laplacian Matrix
Pytorch问题总结