陈 莹,高双成
(西安电子科技大学电子工程学院,陕西西安 710071)
介绍了基于FPGA的LVDS模块的应用,实现了将数据通过FPGA(Altera StratixII EP2S90)的LVDS发送模块的传输,以640 Mbit·s-1数据率送至 DAC电路[1]。
LVDS,即 Low-Voltage Differential Signaling低压差分信号,是由美国国家半导体公司于1994年提出的一种信号传输模式,在满足高数据传输率的同时降低了功耗,运用LVDS技术可使数据速率从几百Mbit·s-1到 2 Gbit·s-1。
LVDS传输方式的原理是用一对线传输一个信号,一条传输正信号,另一条传输相反电平并且在接收端相减,可以将走线上的共模噪声消除。因为两根信号的极性相反,所以对外辐射的电磁场可以相互抵消,耦合越紧密,互相抵消的磁力线越多,泄露到外界的电磁能量就越少[2]。
LVDS接口也称RS-644总线接口,运用LVDS传输技术,采用极低的电压摆幅高速差动传输数据,具有低功耗、低误码率、低串扰和低辐射等特点,可使用铜质PCB连线传输或平衡电缆。LVDS在对信号完整性、低抖动及共模特性要求较高的系统中的应用越来越广泛。目前LVDS技术规范有两个标准:一个是TIA/EIA的ANSI/TIA/EIA-644标准;另一个是IEEE 1596.3 标准[3]。
采用Stratix II系列的EP2S90F1020C3FPGA,其支持高速LVDS接口,在Quartus II软件中可以调用其宏功能模块Altlvds_tx,即LVDS接口发送模块。此模块将以并行方式输入的TTL电平数据信号转换成串行的LVDS信号输出。
图1 Altlvds综合设置界面
将LVDS模块设置为发送模式,即将左端输入的并行tx_in信号转化为串行的tx_out信号输出,并且设置通道数和串行化因子,在这里,通道数即为输出数据的位数,而串行化因子表示将输入数据分几次输出。例如输入为96位的并行数据,设置为24 channels×4,表示输出串行的24位数据,分4次输出,若输入数据时钟为160 MHz,则输出的数据率为 4 倍,即 640 Mbit·s-1,并且可以输出640 MHz的数据时钟。在综合设置页面中,没有选中“Implement Serializer/Deserializer Circuitry In Logic Cells”,就表示用到了 LVDS Serdes硬核[4]。图 2所示数据率为640 Mbit·s-1,输出时钟为640 MHz。
图2 频率设置界面
需要注意的是,Altlvds发送模块在对数据进行并转串输出时,会对输入数据的顺序进行重新排列,例如:输入8位并行数据,设置2 channels×4,则输入数据分为2组即2个通道,每组4 bit,如图3所示。
图3 Altlvds_tx模块输出数据排列
从图3可以看出,8位输入数据分为2个通道,每个通道4 bit,输出数据时,第一个输出的2 bit数为第一个通道的最高位和第二个通道的最高位分别作输出的高位和低位,第二个输出的数为第一个通道的次高位和第二个通道的次高位组合,以此类推。
当设置的串行化因子为2时,Altlvds_tx模块会自动变成DDR工作模式。
Altlvds模块内部有一个PLL,可以得到所需要的输出数据时钟,在图1中可以看到选项Use External PLL,当选择此项时,表示使用外部时钟,则需要在FPGA中重新做一个PLL,并将输出时钟和LVDS模块进行相应的连接。
当使用内部 PLL时,如图 2所示,What is the phase alignment of‘tx_in’with respect to the rising edge of‘tx_inclock’?(in degrees)即可以调节tx_in输入数据和tx_inclock输入时钟的相位偏移,而Register‘tx_in’input port using选项表示输入数据是用输入时钟tx_inclock控制还是用核时钟tx_coreclock控制,默认的是核时钟,而当使用tx_inclock时钟缓存输入数据时,可能会提示建立时间的问题,而对高速时钟来说,使用核时钟缓存时,会用最优的相位位置来缓存数据[5]。
图4 发送器设置界面
如图4所示,发送器设置界面中What is the phase alignment of‘tx_outclock’with respect to‘tx_out’?选项可以设置输出数据和输出时钟的相位关系。当选择‘tx_coreclock’输出时可选择核时钟的时钟源What is the clock resource used for‘tx_coreclock’?可选择Global Clock全局时钟或Regional Clock区域时钟,默认的是 Auto Selection.,由编译时自动选择[5]。
当使用外部时钟时,即在图1中选择Use External PLL,此时新建一个PLL来提供时钟源,这时LVDS模块只能设置输出数据与时钟的相位关系,其余选项不可设置。
DAC系统原理框图如图5所示。
图5 基于FPGA的LVDS接口模块应用系统框图
系统中DSP使用TigerSHARC处理器TS101,FPGA采用Altera公司的StratixⅡ系列EP2S90F1020C3,DAC芯片采用ADI公司的AD9735。
AD9735为12 bit数模转换器,可以提供高达1 200 MS·s-1的采样速率,且设有一个 SPI端口,可以对D/A内部参数进行设置,并回读状态寄存器。
系统中由DSP将处理好的数据发送至FPGA,在FPGA内部先由双口RAM进行缓存,然后将读出的数据送至LVDS_TX模块,输出LVDS数据和数据时钟到AD9735。实验中数据率为 640 Mbit·s-1,并且提供640 MHz的系统时钟给AD9735。由于接口时钟速率提高,传统系统同步方式的数据接口电路难以实现,则采用源同步的方式更加可行,要求时钟伴随数据输出,AD9735的数据输入接口就是按照源同步的模式设计,它要求保证时钟与数据的边沿对齐,即需要输入数据随路时钟与数据采用同样的机理产生[6]。所以通过LVDS_TX模块产生所需的数据和640 MHz时钟送至AD9735。
在FPGA中使用全局时钟100 MHz通过PLL产生160 MHz时钟来控制双口RAM的写地址计数器时钟,并作为LVDS_TX模块外部时钟PLL的输入时钟。如图6所示,DSP送来的24位波形数据,低12位为I路数据,高12位为Q路数据送至双口RAM,由DSP的60 MHz时钟写入,用LVDS模块的外部PLL产生的核时钟做读数时钟,一次读出96位,即4个点的数据。其中Rearrange模块功能为实现数据位重新排列,为后面的LVDS_TX模块数据做准备(如图3所示),使最终输出数据能够保证正确的数据顺序。
图6 双口RAM模块
LVDS_TX模块的设置如图7所示,这里使用外部时钟控制,即在LVDS模块外重新定制一个 PLL,此PLL要设置在LVDS模式下,PLL类型会自动选择为Fast PLL。这时 PLL会有 3个输出 c0,sclkout0,enable0。输入时钟inclk0设为160 MHz,LVDS数据率置为 640 Mbit·s-1,则输出 c0 为核时钟,频率为160 MHz,输出sclkout0为串行化输出时钟640 MHz,输出enable0为LVDS输入使能信号。
图7 LVDS_TX模块
在外部PLL设置中可以对输出的核时钟和高速串行化输出时钟的相位进行调节,因为FPGA的高速时钟由于内部布线等原因可能会产生一些相位偏斜,导致数据和时钟不能准确对齐,这时就需要对时钟的相位进行调节来对齐数据和时钟。本实验中设置c0的相偏为-45°,则sclkout0会默认产生-180°相偏,因为LVDS设置的是4倍抽取关系,即45×4=180,使用外部时钟时还可以根据需要分别调节两个时钟的相位。时钟相位关系如图8所示。
图8 时钟相位关系
用PLL输出的核时钟即c0将rearrange模块输出的数据进行同步后送至LVDS_TX模块,时钟的连接方法如图7所示。在enable0信号有效时将数据输入至LVDS模块,LVDS_TX模块输出的24位数据输入给2个DA(I、Q),低12位为I路,高12位为Q路,并将输出640 MHz同步时钟送至DA。此时LVDS模块内仍可以调节输出数据和输出时钟的相位,但只剩下2个相位值可以调节,即0°和180°。
实验中由DSP分别发送100 MHz和225 MHz的正余弦波形数据至FPGA,经过双口RAM和LVDS_TX模块发送至AD9735,并从示波器上观察DA的输出波形。
实验中c0相偏为 -45°,sclkout0为 -180°相偏。由DSP首先发送的是100 MHz的I、Q波形数据,AD9735的输出波形在示波器上显示如图9所示,其频谱如图10所示。
在100 MHz时,其杂散抑制可达-41.6 dB。
再发送225 MHz的I、Q波形数据,输出波形及频谱如图11和图12所示。
在225 MHz时,其杂散抑制可达-36.8 dB。
以下时钟相位的偏移对数据的影响,将c0和sclkout0相偏设置为0°。
仍由DSP发送100 MHz的I、Q波形数据,输出如图13所示,可以看出数据质量变差。
如图14所示,DSP发送225 MHz的I、Q波形数据的情况。
从图中看出,在225 MHz时时域波形质量较差,DSP发送的数据已是不能正确读出。可以看出在高速数据传输时,数据和时钟的同步很重要,正确调整时钟数据的相偏才能保证数据的正确传输。
由实验结果可以看出,在正确的时钟相位下,波形数据以640 Mbit·s-1的数据率正确的送至DAC,波形和频谱质量良好,通过LVDS_TX接口模块的应用,简单方便地实现了高速数据接口电路并输出高速LVDS信号,解决了高速时钟与数据的同步问题。
LVDS接口技术的优越性能使其在大型高速数据处理传输系统中的应用越来越广泛。介绍了基于FPGA的LVDS_TX模块在DAC系统中的应用,实现了高速LVDS数据的传输,应用时应要注意:LVDS并串转换时,数据bit位的顺序问题,正确相应的输入数据排列才能得到正确的输出数据,同时,无论是使用LVDS模块内部时钟还是外部时钟,都要注意时钟数据相位的正确调整,以便使数据与时钟准确对齐同步,从而得到正确良好的输出数据波形。
[1]赵耀华,陆铁军,王宗民.基于VLSI的高速LVDS接口设计[J].微电子学与计算机,2009,26(11):78 -81.
[2]范丹,何永强,方晋贤.高速LVDS接口电路设计[J].仪表技术,2010(4):7-8.
[3]司朝良.LVDS接口电路及设计[J].今日电子,2003(1):17-18.
[4]韦俊伟.在FPGA中实现源同步LVDS接收正确字对齐[J/OL].(2009-02-01)[2011-7-17]http://www.ed-china.com.
[5]Altera.LVDS SERDES Transmitter/Receiver(ALTLVDS_RX/TX)MegafunctionUserGuide [M].USA MA:Altera,2010.
[6]何柯.800兆高速任意波形产生硬件平台研究与实现[D].成都:电子科技大学,2007.