EDA365电子论坛网

标题: 画板碰到问题,请诸位高手指教 [打印本页]

作者: nacassoce    时间: 2008-8-22 21:08
标题: 画板碰到问题,请诸位高手指教
最近在画一块六层的PCBARM(三星2440)+ SDRAM(K4S561632CLK = 100MHz)+ NAND(K9F1208)这是一个设备使用的核心板,现有几个问题请教各位大侠。
6 f, _* ~% @7 Y( J0 k6 B & E% M& R( M2 p
1:关于电源层,采用2电源层(第二层GND,第五层PWR),地层整个是一个,关于PWR2440有两种供电电压:3.3V1.2V(1.3V 400MHz)
3 z7 ^' v: D1 S6 G. E
% u. Z) s6 W' L6 `/ P根据我查的资料,和现有的其他电路图,由于SDRAMNAND都是3.3V供电,所以在整个PCB板上只有CPU下面的地方是1.2VPWR层,其他地方都是3.3VCPU上的3.3V电源是通过导线引出到3.3V的铜区然后过孔连接,这样做是否合理?) c. ]6 R& Z- v( @& V, {3 p9 N: ^

, w. h2 G7 v; b. T' V8 @3 T有的资料上说高速信号线不能跨越电源层的分割区,这一说法我认为是防止电流回路绕过分割从而加大串扰,我的PCB的第二层是一个完整的大地,从CPU上引出的SDRAM的时钟线,数据线,地址线如果都是在第一层和第三层,是不是电流回路就会以第二层的大地为参考而不会去绕电源层的分割,即使是在底层或者第四层,只要CPUSDRAMVSS都与地层相连,是不是回路仍然会从地层走,也就是说可以忽略PWR的分割区?! @; L9 Q. F; c2 W- C

, b; s2 t( T# L& e+ v. L# K0 y/ S两个不同电压的分割区要多宽才合理?) z/ g2 t2 a" p' }
分割的边界离CPU边界距离多少比较合适?
8 j* [4 p% V6 p# v* C3 w要不要跨接电容?
# E: F: Q9 M2 U) Z7 }$ O  ]1 y: e
% v, ?7 F* A. Q. U# t
) p% F! h8 Q6 T& u; J* A
6 u% E4 N! q0 Q
" H& v! ~. w$ N2:关于SDRAM的数据线,地址线,CLK,控制线) z- L+ _7 j* c6 s8 p' a% ^  Y# J

) _( d& F( r' B4 I" J# n' q) N. w6 qSDRAMCLK是否一定要比ADDRDATA,控制线长哪?6 i; s. h% i" {: _. |& X- \
资料上说调整走线的长度是为了满足时序的要求,怎么理解满足时序?是不是将CPU发出的各个信号的延迟调整到时钟到达时都有效,并且数据返回到CPUCPU不会读错数据(不会读到下一个周期的数据)?
$ k3 r6 {4 L( w6 |# k; K# o   w) I# h+ Q) n$ g0 P3 a% d% _6 ~2 t
对于数据线和地址线很多资料上说要分别等长,或者误差小于50mil,可是我计算使用FR-4,介电常数4.5100mil的延迟大约是0.18ns,是否可以认为100mil也可以了?
4 l  }9 u! j. X! ?7 j  Y3 h有的资料上写允许的延迟与时钟上升沿的时间有关,怎样知道由CPUPLL产生的SCLK上升沿的时间,是否只能通过实验测得?
% c2 m/ u! G  z$ d 1 k- ]) |0 S% C# r
时钟线如果要比其他线都长,是否也能蛇形绕线?不能的话应该怎么走?- v( w8 M: h2 L) G

+ @" M! y9 h: E+ h  w
: p' c! c: Q6 `  M( J. _) ]* A# x ! i- p% L, z3 X; q1 }) F
3:关于阻抗匹配:
+ |4 }% r  I1 |2 @$ A! c看到很多设计上SCLK都在靠近CPU端串接一个22或者33Ohm的电阻,这一阻值是怎么估计出来的?是不是K4S561632上也能用2233Ohm, h2 W% @! V3 D9 \% L( b+ U

1 j* M( i( |1 `% u$ ~8 u' H7 E8 i请各位高手指教,不胜感激
作者: forevercgh    时间: 2008-8-23 09:43
1.高频信号回流路径为低阻抗通路(相对于参考面)。电源和地作为参考面的概念来说是没有区别的。跨越分割面走线意味着阻抗不连续,back loop的加大(包围面积磁通量的变大)。电源分割的安规可以理解为两块不同net灌铜区的clearance。我一般使用20mil。这么我没有很明确概念,请他人指教。7 Z$ v7 \) Y* a- v) |5 B
5 B. t5 c1 v. i  c; M
2.首先你要理解什么是同步系统,同步系统的参考信号就是CLK,你要做的是依据实际情况,在确定CLK长度的前提下,进而决定control,address,data的长度。当然对于源同步系统,需要关注的是strobe同data的延时差
$ R8 Z. X( A* F( x) h/ V1 M之所以考虑到沿率,是要确定特征长度,进而决定是否需要将board level routing看作transmission line。沿率一般在数据手册中会有,或者对应的ibis model中会有。
1 Y: Q3 Z5 R% U, q) {
7 d% N3 W9 q5 N: M, d8 l$ A3.源端串接电阻实现阻抗匹配。% ]% A* j' ~3 K$ T
Ro+Rs=Z0- V5 E% f* A& x4 L& K
Ro驱动端输出阻抗
$ O1 N. D: V+ B) d2 y# T4 s+ aRs串接电阻大小(就是你提到的那些22ohm之类的玩意)" M( t+ P; i% L" O' t: R0 n
Z0传输线特征阻抗$ b$ v4 N8 `! }& r! M& n  g. b

8 }4 L' Z0 M+ L7 w" ^" U2 V- @讲的不一定对,请他人扶正补充
作者: liqiangln    时间: 2008-8-23 18:50
第二层GND,第五层PWR: 建议 3层GND,5层PWR: 地平面和电源平面尽量靠近,3层是地,2层和4层做SDRAM等高速信号走线,基本满足;同时电源和地的距离相对近一些。
1 @; b( U% C* k/ B0 S) U6 ^6 `
$ {" S% l# A& u& HCPU上的3.3V电源是通过导线引出到3.3V的铜区然后过孔连接,这样做是否合理?:如果你做了电源分割,这也是没有办法的事情,关键就看你是否愿意用导线引出1.2V或是3.3V,你现在的做法是芯片的整个下面都是1.2V了,这要看1.2V几个pin,是否有必要做这么大的面积,如果是条形的是否能解决。PCB
" [0 V  ?1 h! c* ]
  u: a- _. _  D: W' b5 }- V4 n ! `) x) k' s& r. i
6 X3 D; |8 J( z7 b

$ i8 ~; e8 a; t9 G& l( R! X我的PCB的第二层是一个完整的大地,从CPU上引出的SDRAM的时钟线,数据线,地址线如果都是在第一层和第三层:表层不要走高速线了,你的阻抗不好控制的。
1 B+ K0 h& b3 b8 B! t+ j0 J
, t; I2 e3 u; I( Z6 A关于时序什么的问题:你理解一下在数字电路中数据是怎么 发出 和 采集 回去的吗?
作者: nacassoce    时间: 2008-8-23 20:49
十分感谢二位的解答,真是不胜感激; _$ Y& o' ~+ y& }, [3 c
我会看一下关于同步系统和数字电路方面的资料/ L; W( `9 e& _- U! d6 s
- ~; a1 {$ b2 F" H- |
另外这里还有一点疑惑
; T! l4 Z( Q* ^% U( a表层不要走高速线了,你的阻抗不好控制:如果不走在第一层,所有高速线就要通过至少两个过孔,这样会不会对信号质量有影响?' b/ Q- r  C2 A: K

% K! p, n7 _9 ]: T: `另外CLK是否可以走蛇形线哪?
作者: forevercgh    时间: 2008-8-24 08:39
对于百兆SDRAM来说,两个过孔并不会对最终的信号质量造成过大的影响。
! }9 Z- I+ b% R" y- u8 V
. N; t2 x4 F; s6 e但是必须明确一个概念,信号换层走线就意味着阻抗不连续,这就是为什么高速信号的布线尽可能避免打过孔的原因(貌似微带天线就是要避免过孔影响)。1 C8 j' O; [7 B6 z8 K
7 g' `5 G$ \1 n
随着信号频率的提高,过孔引入效应已经对信号质量造成不可接受的影响时,就要着重考虑过孔的寄生参数(建模,调整参数)。' v# k# W" Q9 x7 @$ o
; A  m: a, S2 ?* i! O" k
蛇形线,貌似没有造成阻抗不连续,但事实是,工艺上对于蛇形线拐角的实现都是一种近似处理,并不能实现严格的宽度一致,那么随之而来的便是阻抗mismatch,拐角处的reflection等等。/ h/ T# g/ @: _/ \1 ]. R

3 |. T, p) p" t7 C" R蛇形线除了用来实现timing的控制,无其他正面作用。/ t/ r2 v% q& M% E5 W: b
! r- I3 k( B  }2 Q5 b6 J3 O
你的clk如果没有特别需要,只要满足timing要求,没必要走蛇形线
作者: nacassoce    时间: 2008-8-24 12:37
- c. ?- g1 |  e# V: _" ~* |7 F
说明:
* x( U( U7 X% W& Z9 E$ ]4 R( V时钟周期:T = 10ns 100MHz
* T& z) ?4 p& e) s+ j+ [
9 J+ T7 q  s2 b1 c( iTclkCLK在传输线上的延迟(线1到线2的时间)
3 b/ x0 e# O, L* p" N# |TsddCPU发出CLKCPU输出DATA(由于地址和数据的延迟相同所以这里统称为DATA)的延迟,S3C2440上标注的是1~4ns (线1到线3的时间)& g# @3 O( ]' E, O- ^0 V1 Y
TdataDATA在传输线上的延迟(线3到线4的时间,线8到线9的时间)
' ]0 B, B( ^" O. ^: J! ]4 PTsetup:时钟触发前所需要的建立时间(线4到线5的时间:SDRAM所需的建立时间(1.5ns),线9到线10的时间:CPU所需的建立时间(2ns))" ~9 K" H# @0 H2 E1 v
! y; [; D2 L1 F+ d
Thold:时钟触发后所需要的数据保持时间(线5到线6的时间:SDRAM所需的保持时间(1ns),线10到线11的时间:CPU所需的保持时间(0ns))& F4 r1 [, M" l1 f: l3 n
' X8 X6 t2 w% z2 i7 G6 V* N, V, e" `
TsacSDRAM收到时钟上升沿到输出数据的时间(线7到线8的时间)(max6ns  x* J5 ~6 f, u/ f$ A+ ]3 F6 D
5 J: V% V7 O8 \9 m

6 f0 P+ [6 f: \% E* v  _8 i时序的要求:
* N% R+ l( e$ }+ Q+ T对于CPUèSDRAM:满足Tsetup > SDRAM所需的建立时间 = 1.5nsThold > SDRAM所需的保持时间 = 1ns5 b7 D$ {: V( R( N+ e
即:T+Tclk-Tdata- Tsdd >Tsetup è 10+Tclk-Tdata-1>1.5è Tdata-Tclk<7.5
# y$ _# k+ B: E' j  n" Y  Z( H2 y* ^$ h' D$ J$ W$ M- }7 G
T – (T+Tclk-Tdata- Tsdd)>Thold
è Tclk-Tdata-1 < 1 è Tclk < Tdata
+ j; k( j: I- H, n

0 z; J% Z6 i0 \& ~, V5 q* k' ?对于SDRAMèCPU:满足Tsetup > CPU所需的建立时间 = 2nsThold >CPU所需的保持时间 = 0ns+ h3 a0 x9 V0 }9 z6 ?7 V0 J
即:T-Tclk-Tsac-Tdata>Tsetup è 10-Tclk-Tsac-Tdata >2è Tdata+Tclk<8 - Tsac
# F9 w# X  ~2 ~# c3 N% p7 n& `" d
对于这一时序,我的理解就是要考虑Tclk < Tdata,其他的很容易满足2 {7 t9 B9 c) V9 E" }$ N
9 `. ^: @7 k! w0 F! o8 n, \
但是这里有个问题,在计算的时候都是假设数据的保持时间 = T,也就是 线4到线6的时间是10ns,如果数据的保持时间不是10ns对于以上的计算就不对了,至少计算CPUèSDRAM时,要满足Thold > SDRAM所需的保持时间 = 1ns的方程就不是这么列了,我在SDRAM上看到它的输出保持至少3ns,但是在2440的数据页上没有找到Output Hold time,所以这里才会假设线4到线6的时间是10ns,不然的话就是Tcpu_hold - Tclk + Tdata > Thold,假设CPU的hold time也是3ns,则Tclk<Tdata + 2;, C0 q4 S) R: `1 V& g2 ~! ?4 O
不知这一问题如何解决?
$ `3 I* x- _; }7 d+ ?  I+ k2 H2 ~Tcpu_hold: CPU时钟第二个上升沿到输出数据无效的延迟(图上是:线1之后的一个CPU时钟上升沿到CPU发出数据无效的时间)
- N1 U( b/ `7 X$ F% ]
2 ]# Q+ c2 h  w$ Q4 c& `" ]以上都是我自己的理解,不知是否正确,请高手指点. @4 M  P" J9 W5 v  Q5 Y

% [, A: |' X, g5 i& T[ 本帖最后由 nacassoce 于 2008-8-24 13:55 编辑 ]
作者: yangcanhui07    时间: 2008-9-2 17:10
我的个人看法:
6 Y# @' j( V* m. L: x1.设置第2,5层为地和电源是对的.不要整到第三层去,关于电源和地层是否应靠近点,在此案子的应用来看,得不偿失,因为第二层变成了微带线,辐射更大.当然,走线尽量走中间层,表层少走线.两三个过孔对2440的影响可忽略$ @2 f4 L1 [0 Z+ S' M, @2 d8 A/ e
2.关于嵌入式系统的SDR SDRAM,这系统不同于其它的同步系统的是,它的读时序和写时序是极不对称的,并且CLK始终是由CPU产生的。主要着重考虑的是"读"建立时间.以一个125M,周期8ns为例简单估算一下。.内存最重要的参数是tAC,假设最大为6.0ns(绝大部分都在5。4~6。0之间)。
7 \! Y& \( `" c1 i& q6 v) w; o
" o/ v: e- E  d& Y& I时序基准都以CPU的CPU上升沿的跳变时刻为0点。时钟从CPU到SDRAM的走线就用了0.5ns,然后第二个周期的tAC又花去了6.0ns,DQ才出现在SDRAM的PIN上,再过0.5ns之后才到CPU的引脚上。换言之,在下一个时钟上升沿到来之前的1ns数据都已经全部在CPU的DQ脚上准备好等待锁存。查看2440的SPEC,最小建立时间是2ns。时序裕量已经为负值了。要是跑100M,时钟周期10ns,还是绰绰有余的。至于HOLD的时间更宽裕得很。
* O  I' B4 l7 z. V0 U8 T0 v
! `( Y, V* v: p& s, V
( m3 D% c& T4 U% r; D1 @实际在处理2440这类SDRAM的走线的时候,只要保证最长的一条DQ在CLK到来之前有足够的时间准备好就行了,等长也没太多必要,但是CLK一定要短。
作者: 风淡云悠    时间: 2008-9-2 17:56
坐上沙发学习,越来越感觉在这里真的学到不少东西。有种相见恨晚的感觉。呵呵
作者: nacassoce    时间: 2008-9-6 11:42
我了解了,十分感谢!
作者: forevercgh    时间: 2008-9-6 14:12
原帖由 yangcanhui07 于 2008-9-2 17:10 发表 % Z# W. e  I1 a2 @
我的个人看法:+ X$ H' W9 S8 t+ y5 m1 o
1.设置第2,5层为地和电源是对的.不要整到第三层去,关于电源和地层是否应靠近点,在此案子的应用来看,得不偿失,因为第二层变成了微带线,辐射更大.当然,走线尽量走中间层,表层少走线.两三个过孔对2440的 ...
) I) L# S! n/ B% S8 P6 [

" z7 p" _8 R" Z% O3 h) }tAC-----DATA ACCESS TIME--------equal tco




欢迎光临 EDA365电子论坛网 (https://bbs.eda365.com/) Powered by Discuz! X3.2