|
作者:黄刚(一博科技自媒体高速先生原创文)) f; i& ]( G7 V' N- \( T8 W( i
9 g8 q5 R) v* P* z3 o7 Z' [
PCB设计会存在各种大大小小的误区,有的误区很容易用简单的理论进行解释,有的却显得神秘而难懂。高速先生最近和粉丝们的互动中惊讶的发现,磁珠对电源纹波可能会存在反面影响这个误区原来一直都是谜一样的存在…
: O4 E ~ X! ]. L# {+ S' D
' K! J$ {1 Y( \2 y
) Y2 b# @" D- u % h' z" a& ]: Y3 v) R, M7 C
高速先生曾经问过很多硬件的朋友们,为什么在转换电源时要加磁珠,基本上我们得到的答案都是两个字:隔离!的确,从硬件原理来说,磁珠放在电源转换的前后级,的确能限制快速切换的电流带来的纹波从前级扩散到后级,从而把纹波局限在某个范围,不会扩散到该电源的全部区域,然而真正实践起来的时候,结果可能会让你大跌眼镜。8 w% r0 B" E3 I) q6 p$ B4 H2 V
/ b9 K, h# v- x) p0 }$ J. j* {1 k4 A0 U Y: g
4 ]* {5 F* Y w1 c! n
这个高速先生接触过的一个有意思的案例,客户找到我们来做debug。既然是做debug,顾名思义就是板子的调试出了问题,然后想让高速先生帮忙找到原因咯。' e- k% S. ~# Z8 R6 k3 ^& h
* P6 c$ ]* S8 l4 a+ ]5 k. o3 r; |# s
! m' |* |5 t5 k1 H
$ b9 \, ] D3 O7 ?; @0 U
客户的PCIE信号总会偶尔存在通信失败的问题,客户定位到是PCIE电源的纹波过大的原因造成的。客户也提供了他们对电源的测试波形,如下所示,峰峰值达到160mV。
- o5 R8 t0 a9 |$ s3 @3 j4 k; A$ }
& D) U8 A( @& d e, P8 w( c) L2 f
* Q o. H0 T' Y9 V1 y b' U' N$ W. d- ]- V2 N
然后我们打开客户的原理图和PCB设计,发现是一个从1.8V主电源通过磁珠转换得到的PCIE电源。1.8V是通过DC-DC电源芯片从高电压转换而来的,我们看到前段的滤波设计是做得不错的,在电源输出端放上了大电容(uF级),符合我们常规的设计。# ?/ ~ f0 q- Y" l! F
! N0 |8 n( p8 Z( T6 M
$ k5 y. o3 ^/ v' I
 & J; ^9 }+ M. C# T
那么问题到底出在哪里呢?为什么转换后的电源纹波会变得那么大?我们把测试到的纹波转换到频域来看,发现大多数纹波的频率分量都在450kHz,这个数值让高速先生想起了DC-DC电源的开关频率也在这个范围。果然,一查下该电源芯片的datasheet,发现和电源芯片的开关频率是很接近的,因此高速先生怀疑是开关噪声通过链路带给了这个转换后的电源。然后我们对该电源链路进行一个频域的仿真,从仿真结果可以看到,经过该磁珠之后,该电源在450kHz附近出现了明显的反谐振点。: o |/ Y/ ]/ |. B: J. m0 e9 K
( D/ s, l* C8 R! ~# j6 z8 m9 q1 L7 g
9 g% K" h# R0 k$ y! q4 e
3 n0 R5 V; t. I1 w, N% ]从频域仿真的结果表明,使用该磁珠和后面的电容配合进行滤波和隔离后,由于本身磁珠和电容的效应,的确是能滤掉高频的纹波分量,但是却会在kHz的频段出现反谐振点,如果刚好电源的开关频率产生了这个频段的噪声,实际上噪声会一直传递到电源的接收端,不能被滤掉之类,还会把噪声的幅度提高。
) {+ Q4 e+ X: V* [; n4 { q
& v6 i7 r( A! A( a
$ ^0 x# ^0 ?: b/ S" N, N
: U' ^% M9 S/ |5 ]关于电源滤波这个原理,在文章这里就不展开了,大家可以去观看高速先生队长亲自拍摄的视频,获得更多的知识点哈。$ m: _8 B1 G" q7 c% V' T, y
. k$ S' V8 K, }1 e7 k' O! i
https://www.bilibili.com/video/BV1p54y1U7Cc+ t& H3 W' H) [! v& v
: e# H* ^! W+ G; h. a那我们继续往下讲哈,大家都知道高速先生的风格,喜欢把一个案例讲到极致。还是那句话,很多硬件工程师都不太喜欢用频域去看问题,那我们更形象的对该纹波进行时域的仿真。我们假定在电源芯片的输出端产生了450kHz的噪声,峰峰值50mV,如下所示:& U- J1 H- I4 I
1 h: O/ J, r( i$ ?+ r7 I8 W2 x
- J% ~# D% [; I4 @
& C" R; q1 B3 P% m- J; y @9 x' g
那么大家能猜想到接收端的电源会产生多大的纹波吗? K7 d' \" ]. R% e& d A, g* V# `% q
& }7 G5 b% J2 }1 R( I7 J
! j2 H' i6 S, R" m& V $ N# j: G8 B* O. C" t4 a
会比噪声小一丢丢?会基本上滤掉?还是。。。对!不仅不会滤掉,还会增大!!!; e$ Y9 T& v7 o, `4 P
) h4 K3 c0 C$ j1 j8 w! k
6 y. J; B4 _4 w
' [- k$ E/ G1 V2 ~' n6 b
是的,就是这个效果。) Y1 G- O. Z9 o. M' o4 n& N1 |3 c
+ V2 N; G# ~3 y6 x
/ F/ v! L: G" I1 x+ G5 D. \" f
那么可能还有很多朋友还会问两个问题,一是为什么会这样呢?二是要如何解决呢?要是讲到这里就停下,我猜很多粉丝会有意见,那么高速先生就继续往下讲哈。- v5 Q4 o5 T3 c% k N# o! e4 ^4 W
; C9 O+ G7 s" @) L9 H6 w
$ \ {# v; F2 S3 `# _
: B: T' @# D6 ]! P* q0 x4 j
原因的话,我们知道,磁珠其实和电感是类似的,在高频时表现为高阻抗的物体,因此电感和电容会在某个频点发生反谐振,这是跟电容和电感的具体容值感值是有关系的,本文的例子中,我们在磁珠后面添加的是比较小的电容,因此配合到这一款磁珠的属性,刚好会在几百kHz处产生了谐振点,更不巧的是,刚好电源的开关噪声在这个频段,因此就产生了本文的这个案例了。
- V! }9 X& P& p. T2 P( [3 x% \$ ^4 r4 x F7 }* X
& g8 M8 f* Y0 n- p) f 0 i9 d& t u! E
最后再说一下本案例的解决方法哈,我们知道了产生的原因之后,就把其中一个电容换成更大的10uF的电容。
5 s5 L( _0 c; Q# `1 h# I* F+ c' t$ h( N8 F( ]; `9 D$ u( q
' T, `( Y9 a# s% d' ^5 l+ r
$ W- r5 ]8 i( P+ Z7 d从仿真结果来看就能有很明显的优化,完全消除了这个反谐振点。9 i- V* f, U8 \- Q& p0 l1 ]
7 D# u S* M8 h
3 \* i8 d1 k5 D6 J) h8 Y 3 U: b6 ~; F4 R4 ^& i! {8 L
当然也成功帮助客户解决了问题,PCIE的通信就不再出问题了,这时候再让客户测试下噪声的话,也变得比较小了。; n' Z# Z: i0 b V" N! O
4 C5 Y, R9 L+ ]1 |: U/ N* h
' I& r# g4 g5 J: U
- f% V7 Y r! N. V. s
# Z1 L- J" b& x
$ V3 r; {$ ^2 l+ o6 S( D C# m/ O# Z/ i0 I K: d9 c% ~" q9 j/ s
0 F- D+ L8 K! v1 N# u4 W1 i
* B# t' J/ \$ P4 z% U3 I
5 g9 F% A9 {0 X% B* q& e8 ?4 S$ W; ]8 W* u3 D4 m8 _$ {
: V# ]. Z' Z% s& `5 U Z6 E
/ l9 N& A5 t* l5 j! n$ W" f) M$ ~- ?! A+ L. A
2 c1 \2 z7 _& v8 y- F) j. Z8 ~
: t0 `5 t) I6 R% K. l2 C/ O* f x" C) N9 e5 }7 w. M0 Q9 r
- t$ A4 \1 I @4 j* V% _; q2 P
+ a( U8 R, P# O- |* U `
% x8 M) k( D5 d0 i; W
3 ~) C8 ^7 |. T. u3 q) q8 Y
7 c) v/ X! q$ _3 k4 ~/ m
3 _% ^9 ?) N; P; X/ N! v5 C) W" g" Z, j% J0 X* U/ k
& Q3 V4 c: k6 I4 G) \6 w; C
& K F0 g/ q& }( W7 L$ s0 |
% f2 H8 Z$ N: Y1 Z: }) `
! M- _* T( g% B. n, W! g6 i& p
5 D6 l4 F- E0 l/ Q: U$ {- N. j6 x
5 E1 j. d, m- ^% V; w
% s u7 J' x! f* ^. [! b
- Y( w5 u& {% v |
|