一)回顾源同步时序计算
0 h2 c2 ~5 z2 m ~Setup Margin = Min Clock Etch Delay – Max Data Etch Delay – Max Delay Skew – Setup Time
+ Y+ H! F" m7 z5 v# N. Q* SHold Margin = Min Data Etch Delay – Max Clock Etch Delay + Min Delay Skew + Data Rate – Hold Time
% d( z# N# h. V2 b& |
下面解释以上公式中各参数的意义:
' j& f! i) q% T5 u, P, E
Etch Delay:与常说的飞行时间(Flight Time)意义相同,其值并不是从仿真直接得到,而是通过仿真结果的后处理得来。
" @7 Q5 \7 h* e+ g9 B请看下面图示:
6 p/ {- K4 ^$ \& M; N% Y6 F% U图一为实际电路,激励源从输出端,经过互连到达接收端,传输延时如图示Rmin,Rmax,Fmin,Fmax。
$ V% P. ?1 G, s. S0 `! a' h& I7 h3 M; A
图二为对应输出端的测试负载电路,测试负载延时如图示Rising,Falling。通过这两组值就可以计算得到Etch Delay 的最大和最小值。
3 H% l# q+ c5 \) J' {) |) ]
; G2 x0 E' z3 ?: u# L! ~图 1 Raw Etch Delay
" ]+ s/ u: m; v6 |
# p+ } \% ?2 K# H# }/ g图 2 Test Load Measurement
& K6 a2 t" h9 W; E7 o8 G0 CDelay Skew*:Delay Skew描述的是信号在缓冲输出前时钟和相对应数据的相对位置,如图三所示。SKEW_MIN和SKEW_MAX分别确定了无效数据无效窗口的起点和终点。它们的值可正可负,负值表明数据边沿超前于对应的时钟边沿,反之亦然。
4 u$ c+ K9 h2 z& {: j
* S5 k3 r( `7 ~( k% ~图 3 Delay Skew
3 F% p- B# F7 q+ F; H3 @Setup/Hold Time:即接受器件正确锁存数据的最小建立和保持时间。
2 \$ s8 q4 s) W9 U( s从以上叙述可以清晰看出,时序计算公式中的参数可以分为三类:第一类是Delay Skew,由输出端所用器件决定,从数据手册中可以得到;第二类为Etch Delay,由互连电路决定,需要通过仿真和计算得到;第三类为Setup/Hold Time,由接收端所用器件决定,同样可以从其数据手册中得到。
: r) C1 l" G' }2 i, q
二)使用时钟PLL的系统时序分析
: u$ s( V& z+ a首先,来看一个简单的是使用时钟PLL的系统接口。如图四所示,数据信号通过传输线直接连接,时钟从输出端(Source)出来后输入时钟PLL,然后PLL输出至接收端(Target),PLL自身有反馈回路。
" G; B, b! z; f2 i4 ~ T
; r. Q. @! d' M图 4 Clock PLL Interface Diagram
) i( d x9 f. j& _" L% j9 o
从传输网络的角度看,此接口由四条网络组成,分别是数据(data),PLL时钟输入(clkin),PLL时钟输出(clkout)和时钟反馈(clock_fb)。
/ C. u3 j: r+ A+ ^8 l
对应于第一部分的计算公式,可以很容易确定第一类和第三类参数,也就是图示的Delay_Skew,即输出端参数,和SETHLD,即输入端参数。下面来确定第二类,即互连延时。
% d+ {* [ W6 }" g- o定义:
* ^1 b0 [: h3 P( R+ C' ]6 G* GIC(Clock Input to the PLL)为源端时钟输入到时钟PLL的Etch Delay,
5 N' H) N8 k( C+ p1 Z) XOC(Clock Output from the PLL)为时钟从PLL输出到接受器件的Etch Delay,
( m9 O) v: H$ m3 r9 \FB为PLL的反馈回路的延时,
4 R& B3 ]6 M$ n- ?; y' ^& Z4 v5 p7 W
NX为PLL的输入到输出的延时,
7 ^9 h4 Z* Q. u6 a( r. J9 t7 V8 H
则:
" o5 g1 K# L- t( R) `
总的时钟延时
+ g7 V! G2 l/ Q8 B# N8 d1 s
Min Clock Etch Delay = Min IC + Min NX + Min OC – Max FB
% N4 C, y o1 Y, J
Max Clock Etch Delay = Max IC + Max NX + Max OC – Min FB
* K3 H4 n9 K* p
将得到的总的时钟和数据信号延时代入到时序计算公式,就可以计算出使用时钟PLL的系统时序裕量。
3 ?3 J7 w6 X, b$ D$ V8 G, Z9 ?" N
三)使用Quantum-SI仿真计算使用时钟PLL的系统时序
0 ^( I, J% [. w5 I1 ?3 A
Quantum-SI支持时钟PLL系统时序分析,它领先的信号完整性(SI)和时序分析功能可以快速解决此类问题。
: X( G1 r6 Q1 k0 W% R
Quantum-SI以电路接口为中心,可以在一个接口上建立多个传输网络,而Quantum-SI可以分析这不同传输网络之间的时序关系。如图五,图六所示
9 O% P# P- j8 K) a
/ [+ ]; M1 |* X7 u' q& e
图 5 Transfer Net
, t5 B. N& k: q4 j
# |+ r' f, ]: }# ^ k
图 6 Setup/Hold Margin by variation
1 _0 T0 o- d/ E z+ ^+ W0 @* I) s& \% M
图六是在图五的传输网络建立后,Quantum-SI自动仿真分析得到。
& u0 G, o7 }3 g! s4 W+ J5 C2 C可以知道,对于系统的时序分析,需要清楚器件内部的时序关系,测试负载的概念与应用,互连传输延时等。而使用时钟PLL的系统,需要清楚时钟信号的传输路径。
: L9 h# ~" \& j( J. i' ^
对于复杂高速的系统时序分析,需要考虑不同参数,如电压/温度/工艺等对时序的影响。Quantum-SI在高速信号完整性和时序分析方面提供了一个完整的解决方案。
4 }; ^4 F& c* d8 C3 S