EDA365欢迎您!
您需要 登录 才可以下载或查看,没有帐号?注册
x
本帖最后由 alexwang 于 2018-7-2 14:26 编辑 % X" w# P5 I7 m4 n* x. c. \
" z1 p. z3 \2 I7 n
模拟电路工程师的三大法宝!为了提高数字电路工程师关系的串行传输速率.
: `/ ?, e5 D3 H/ I2016-06-22 又见山人 shark4685 0 Y5 |9 Z0 h7 ~
为了提高单根线的传输速率,必须要讲到我们模拟电路工程师的三大法宝,差分信号(differential signaling),时钟-数据恢复(Clock-Data Recovery,简称CDR),和信道均一化(Channel Equalization,Eq)。 7 a" }( {4 c% E9 o* ?
差分信号的好处:不外乎抗干扰能力强,引入的噪声也比较小,虽然必须要两根线,但速度从几百M提高到几G,还是很值得的。- q e, P6 p/ G% q
% d5 C4 d- |( g
CDR的好处:消灭了skew,减少了时钟的功耗和噪声(但多出了CDR电路本身的功耗和噪声),同时避免了电磁干扰。想想在PCB或者电线上传一个15G的时钟,太带感了,幸亏我们不用做这种事。) V- ^ x) J7 `' P
1 n8 N" h# g. I6 u
信道均一化 相当值得一提,这才是SerDes高速发展的决定性因素,所以我决定花点文字讲一下。 g9 d7 Z7 m" d$ ^- I
一般来说,真实世界中的信道都是低通特性的,到处都是小电容,所谓绝缘体中的分子在高频情况下吸收电场能量,再加上金属线中的趋肤效应,所以我们想要的高频信号走不了多远就不像样子了,比如下面某信道的频率特性(绿线)。 ! v8 O, V1 ]0 B3 I8 ~- _' ^
& w, r9 m* s+ ~! Z" M
如图所示,在对应28Gbps的频点上,信号能量被衰减了30db,电压幅度只剩3%了;在对应56Gbps的频点上更惨,65db意味着信号电压摆幅剩下不到千分之一。在这种信道中,发送端一个完美漂亮的数据眼图:
# G j' \0 K" E1 ^
& a l! P' B! N7 v& d: x
到了接收端会变成这样的一堆垃圾: ' n# c' C+ g$ ~$ {4 I
什么都辨认不出来对吧。但是,经过我们聪明的工程师们一番努力,均一化开关打开,信号就变成了这样:
: Y* |; j& o4 i$ _) U+ F4 p7 M% H4 w
$ [- X0 `) V- \9 ^# J; f神奇么?我觉得挺神奇的,我认识的电子工程师们第一次看到这个,没人觉得不神奇。
) L2 K5 t ~' o) Q4 S+ e* o0 n' ~. p8 \0 p5 B+ D
下面一个重要的问题,既然有了三大法宝,他们只能用在串口上吗?
/ z& @: d* Z6 F答案很显然,不是,串口可以用的,我们并口一样可以用。那为什么并口不用呢? $ u: x6 q& b" ]
差分信号这条不用说了,并口的电线本来已经够多了,数目还要再翻一倍?系统工程师会杀人的。 . \' E/ o. n+ n1 f% Z. {9 x2 U& e6 @3 A
CDR 意义也不大,反正你并口速度也不高,一堆数据线中顺便传下时钟,比做接收端做CDR再采样每一位数据省事多了。
$ C" }' \; }; z* p' V) Q信道均一化属于屠龙之技,不用差分信号的话也就传几百M,本来就没啥衰减,用这个干啥?还是考虑下各种噪声串扰的问题吧。9 C) E% n8 M# b; T- x& _1 \
1 P# u9 q; E! t" e. w# r
于是答案就呼之欲出了。串口为啥比并口快?是因为串口的特性和应用场景,决定了它更加适合采用一些可以提高单根信道速率的设计方法,这些方法用在并口上并不合适。
. p$ X0 j0 t; s; n! [5 W L3 |8 E. Z4 O' X5 g, s9 J
从现有的应用看来,需要持续稳定高带宽的应用,往往使用高速串行接口,一根带宽不够再加一根,各种视频网络应用,基本如此。而一些历史遗留速度不高的应用,还有一些需要突发性高带宽的应用,并口仍然存活,比如很特殊的DDR。虽然XDR/GDDR/HMC/HCM这些新标准都在试图引入SerDes, 但DRAM行业的特殊性还是让并口继续存活着。" v* P W# F! H2 M. P
/ \4 _" u- H$ |1 Z* x
这个答案清楚明晰的指出了几乎所有串口的优势,但是忘了提及一点,这些优势其实是三大法宝带来的,并非串口与生俱来。就像小强开车小明走路,小强自然快很多,但并非他天生就快,而是因为小明腿短够不到油门。haha... # H5 W5 i, M. C. q" p8 [8 [
, H- k; e, W! \% b% V) R* q
|