EDA365电子工程师网

标题: 整理:时序分析——公共时钟(内同步,外同步),源同步 [打印本页]

作者: wcn312318697    时间: 2011-10-27 09:28
标题: 整理:时序分析——公共时钟(内同步,外同步),源同步
时钟系统可以分为公共时钟和源同步时钟,公共同步又可以分为内同步和外同步,内同步典型的即为CPU与SDRAM系统的读写。7 w/ R* B/ \- }, J$ k) {. v
! y+ _& {7 [- _' a$ g, P; j2 }

) V% @( k& K  O, Q! }+ @" k
9 |5 ~3 A" J: Z, O5 m1 ?建立时间:要求接收端的数据信号必须先于时钟信号到达。
9 G7 s9 i! p( n1 Z: t: Y* v- J* [: h% g+ I
时钟信号的延时:Tdelay = Tco_clka + Tflt_clka
! U' [. P* M6 k/ d- Z8 k3 ~9 h
7 ?' n6 b4 b3 ^% B, z2 n1 \数据信号的延时:Tdata_delay = Tco_clkb + Tflt_clkb + Tco_data + Tflt_data3 d; Z" m/ V# r8 B0 A
1 s. R8 w" q8 S8 @! _; s
公共时钟中第一个时钟用来将数据锁存到驱动端输出端,第二个时钟周期则将数据锁存到接收端内部。意味着第一个数据到达接收端的时间应该早于第二个时钟到达接收端的时间,才能有足够的建立时间裕量。因此:
  |" n8 r: ~0 ~9 F1 g" ^7 G- L. {4 M0 W
Tclka_delay = Tcycle + Tco_clka + Tflt_clka$ Y6 k$ t6 _( J
" s0 X, [5 H4 O9 w1 n
Tclka_delay_min – Tdata_delay_max – Tsetup – Tmargin > 0 0 d5 X5 q8 j# _* R

" i7 w4 \  h8 z3 {% |1 @& r即:Tcycle +(Tco_clka_min – Tco_clkb_max)+(Tflt_clka_min – Tflt_clkb_max) – Tco_data_max - Tflt_data_max – Tsetup – Tmargin >0, g2 p, Z3 n1 U+ |+ z5 [
. b8 K& }! z! }3 @! F
若是考虑时钟的抖动,偏移等情况则需将这部分时间扣除。
. h  T+ H' K0 ?' n/ u' v" ]% g
/ H" u2 O8 r! Q& u. ?3 m, E  h5 t+ m2 H/ l0 k
保持时间:要求有效数据信号必须在下一个数据信号到达之前锁存到接收端的触发器中,这就要求接收时钟信号clka的延时要小于接收端数据信号的延时。具体的说就是第二个时钟信号必须先于第二个数据信号到达接收端。
/ G) }6 T( f3 R( i4 J) M, k$ R+ N1 J& }( b) k5 c" ]# x
因此:Tdata_delay_min – Tdelay_max – Thold – Th_margin > 0; L  _# a1 N  S7 z8 K4 }9 J
6 Y# d: e, I2 \9 {$ i
即: (Tco_clkb_min – Tco_clka_max)+(Tflt_clkb_min – Tflt_clka_max)+ Tco_data_min + Tflt_data_min – Thold – Th_margin > 0
7 C' T3 c9 ~  t! \* J8 j- B, T% ^# U, B6 f' m5 c" q$ o5 T+ B
若是考虑时钟的抖动,偏移等情况则需将这部分时间扣除。$ h8 I$ M1 X7 n

# x# w1 P  M% }2 v1 f从2个公式可看出,对于人为可控的调整项只有三个:Tflt_clka,Tflt_clkb,Tflt_data.这样就可以通过调整PCB走线来使这三项满足时序的要求。
( s5 a% P& ]; T6 l, a  i  B9 ~, w/ `- g: ?$ u5 A7 k
2.内同步时钟:
3 b- s5 [" ]: b
/ ~; C3 e5 X+ W) t: Z/ M8 M5 p( k5 p    指一种时钟或者选通信号和数据信号同时从驱动芯片产生并同步传输到接收端。它不同于公共时钟同步那样采用独立的时钟源。
1 P6 X7 s, y# F; Q3 R- Q
: T; x- J; I; g% S" J. o
6 [+ B4 P  o' `, {1 s+ f! l从上图可以轻易的看出内同步时钟的工作原理,时钟信号clk的输出采用缓冲器输出,是因为可以同步CPU高速器件和存储器低速器件间的数据读写;数据信号也是从驱动端发出的,参考的时钟是驱动端的时钟信号,则有一个缓冲的延迟Tco_data在里头。这个参数可在数据手册中查得,有最大,最小值。这样我们就可通过控制PCB走线来轻易使Tflt_data和Tflt_clka来满足时序的要求。Tdelay表示驱动端的采样数据对应的时钟信号发出时间比所采样的数据信号发出时间的延后的时间,
+ B/ X  l8 w9 ]* Z: P/ P
; t: s* ?/ V/ a  O' g. X/ ~$ r4 c* j建立时间:数据信号需在采样时钟信号之前到达接收端。
& ?( f4 P8 a! G" v9 z& G2 _
2 _, O: h4 _6 w) O/ i/ g: X/ L; u, mTdelay +(Tflt_clk_min – Tflt_data_max)- Tsetup – Ts_margin > 0- c6 j9 _- r8 }! F5 K% w

3 m  n3 I! `; \$ {在这里,由于数据信号和时钟信号都是由发送端产生,而数据信号的发送也必须以时钟信号为参考。因此,采样当前数据信号的时钟会落后驱动发送该数据信号的时钟一个周期,则Tdelay = Tcycle – Tco_data_max0 E! Z6 a& t( |" k, e+ F4 I1 I" E
9 E5 H5 T8 d; O/ }
则建立时间为:
, ?  L+ F! [. `8 L' d6 Q5 X
: ^7 z8 w3 K& D9 S9 UTcycle – Tco_data_max +( Tflt_clk_min – Tflt_data_max)- Tsetup – Ts_margin > 09 v/ e- I- f  W* _! a0 a0 g

* _/ p6 C" [2 P: H& C( G保持时间:前一个采样时钟必须比后一个数据信号先到达接收端。; A3 a' _( S& A' A* d/ ~: j/ v. H
% k# E5 S: ^, g  x/ n+ F7 K8 A
这里,前一个采样时钟即为后一个数据信号的发送参考时钟,因此,他们从走线上开始有效传输的时间之差即为数据信号的缓冲延时时间,即Tco_data,则满足: Tco_data_min+ (Tflt_data_min – Tflt_clka_max) – Thold – Th_margin > 0 6 ~: \; \& H( j1 Q  t  e

$ q0 K6 Q+ ~, {" _$ t6 \2 A  ^' M* @* {( B! w" x
还有内同步读和源同步的时序分析,由于现在电脑无法上传图片,待续。。
作者: wcn312318697    时间: 2011-10-28 08:31
6 W5 ]! w  a1 A7 C5 Y
2 S! w( S+ [% l0 Q! p
通过时序图可以CPU与SDRAM的内同步系统中得到CPU读SDRAM的过程:
/ ?4 Z& q  g+ p3 [% h6 yCPU首先发送一个时钟信号到SDRAM,触发SDRAM发送数据到CPU端, CPU发出的第2个时钟信号采样前一个信号触发而发送到CPU端的数据信号,从而完成一个读数据的过程。为了满足时序要求,则要求第1个被触发的数据信号必须在CPU发出第2个时钟信号之前到达CPU端,这是建立时间;第1个数据信号在第2个时间信号触发采样后所保持的时间为数据的保持时间,即第2个数据信号到达CPU端之前的部分时间,这段时间包括第2个时钟信号的飞行时间,第2个数据飞行时间以及第一个数据发出时的保持时间。
+ A# r1 w: a: J3 x, C! K9 Y9 k4 `则可以得到CPU读SDRAM的时序要求为:
/ S+ c# m5 U4 v% j建立时间: Tcycle – Tflt_clk – Tflt-data – Tacc – Tsetup – Ts_margin > 0& `6 r4 X7 _3 [$ S6 v* B
保持时间: Tflt_clk + Tflt_data + Toh – Thold – Th_margin > 00 U% B7 W4 P; n

3 o1 E3 z/ ?/ D( t& F$ j
; Q- }% O! K; @# t: l9 _源同步:# ~, _7 z( W4 D+ d" [& S9 u
发送数据的时钟信号也由驱动端发出,而且和驱动端发出的参考时钟信号保持一个固有的相位差。
3 [" S$ j/ `' x: w若定义Tb为在器件内数据信号先于时间采样点的时间,即驱动端数据在时钟有效前多少时间有效,为驱动端的建立时间;Ta为第二个数据信号落后于第一个采样点的时间,即驱动端数据在时钟有效后保持有效的时间,为发送端保持时间。则有:
7 J! f1 l# e4 G+ z* HTb = Tdelay + Tco_clk – Tco_data  Ta = Tcycle – Tdelay– Tco-clk + Tco_data; C9 Q: @! d% o* ~6 Y* K0 d
则有:' }* o+ ^. b2 B; _
建立时间:Tb + (Tflt-clka_min – Tflt_data_max)- Tsetup – Ts_margin > 0* p+ P( h0 H3 {" |/ D6 c5 T0 q
保持时间:Ta +(Tflt_data_min – Tflt_clka_max)– Thold – Th_margin > 01 t" i2 Y! X" d" Z/ \1 q5 j

' Z8 {' q+ S# Z1 |内同步不同于源同步时钟系统的地方在于:内同步系统中数据通过寄存器输出,时钟通过缓冲器输出;而源同步系统中数据与时钟信号都是通过寄存器输出,并且保持同等相位差,一般保持时钟正好在数据中间。
+ W" F2 W+ K4 M# X; ^

外同步.jpg (24.02 KB, 下载次数: 3)

外同步.jpg

外同步.jpg (24.02 KB, 下载次数: 4)

外同步.jpg

内同步写时序.jpg (24.15 KB, 下载次数: 3)

内同步写时序.jpg

外同步.jpg (24.02 KB, 下载次数: 3)

外同步.jpg

内同步写时序.jpg (24.15 KB, 下载次数: 7)

内同步写时序.jpg

作者: wcn312318697    时间: 2011-11-16 17:24
本帖最后由 wcn312318697 于 2011-11-18 09:13 编辑
( e- D; a, X  r  H$ M, H- Q* f  K: ?/ r* Y' y2 p
今天再整理时序的时候发现上面对于源同步时序的推导有误,由于定义了Tvb和Tva则建立和保持时间应满足:
( @& A8 ]- U6 F; g源同步写时序:
; E* X  C/ |: [建立时间:Tvb + (Tflt_data_min–Tflt_clk_max)-Tsetup–Ts_margin> 0" g5 X) A' q3 G3 n5 ^
保持时间:Tva +(Tflt_clk_min–Tflt_data_max)–Thold–Th_margin> 0
* o) M# Y  Y5 s  w源同步读时序:5 L5 n3 N( n: O5 m: m
建立时间:Tvb + Tflt_clk_min + Tflt_data_min – Tsetup – Ts_margin > 0( Q, B, c/ e. {- V' n, K# m1 w% g
保持时间:Tva – Tflt_clk_max – Tflt_data_max – Thold – Th_margin > 0% [  \% P; ^) a+ g
若有其他错误,欢迎大家指正啊!!5 \4 v* _: Z5 X- E, G5 J& g

" d6 [. t# `; j+ |  u1 @7 M' ^补充内容 (2011-12-13 15:11):
4 R. N2 W, i+ x- t0 Q% M1 R哎。。俺又错了。。竟然都没人来指正。。。。。
, J; x8 F; n6 T) ]: f原来对于源同步的了解不够,现在再改一次。。3 c, Y  r9 Y& {9 D2 t
源同步的读与写应该是一样的过程,都是采样信号与数据信号进行同相,同向的传输,
% A: G2 f3 G" a* L& L0 ]& r# q) @4 s. T) }; x4 O/ p
补充内容 (2011-12-13 15:12):
3 w3 K+ [- A. b$ B) Q, q4 m9 P那么:
; g5 U+ e& `1 `, M1 G1 K4 W建立时间:Tvb + (Tflt_probe_min–Tflt_data_max)-Tsetup–Ts_margin> 06 v1 D! `: ]/ P& _
保持时间:Tva +(Tflt_data_min–Tflt_probe_max)–Thold–Th_margin> 0
4 U7 p( M5 B' i/ |probe:即为数据的采样信号
- g% j! b; u& v% Z! K$ |5 n- ?5 a
作者: babadashagua    时间: 2011-11-16 23:18
谢谢分享
作者: redeveryday    时间: 2012-6-6 16:04

作者: qiangqssong    时间: 2012-6-6 16:20
谢谢分享,学习下!!
作者: yejialu    时间: 2012-6-6 16:27
不错, 再研究深一点呀
作者: guokeqin    时间: 2012-9-26 20:09
新手学习中...
作者: willyeing    时间: 2012-10-10 17:23
看晕了,我自己写过,现在都已经忘了。反正你就画个时序图,自己写公式就可以,要细心些不难的。
作者: James‘    时间: 2012-10-11 14:45
怎么感觉PCB设计越来越难了呢?
作者: dck    时间: 2014-3-16 17:30
好文章,重新顶起来




欢迎光临 EDA365电子工程师网 (http://bbs.elecnest.cn/) Powered by Discuz! X3.2