• 易迪拓培训,专注于微波、射频、天线设计工程师的培养
首页 > 无线通信 > 技术文章 > 在FPGA中实现源同步LVDS接收正确字对齐

在FPGA中实现源同步LVDS接收正确字对齐

录入:edatop.com     点击:

由于FPGA具有非常高的灵活性,比如支持不同LVDS输入数据和输入时钟之间的倍频关系,以及不同的解串行化因子,所以Stratix III LVDS硬核模块的输出字顺序通常是不确定的,每次上电或者复位后字顺序都有可能发生变化,使用时需要根据特殊码型进行字对齐处理。

当输入到FPGA的数据和时钟之间的倍数关系等于解串器的解串行化因子时,FPGA与单独的LVDS解串器一样,有确定的字顺序输出,可以在没有训练码型的情况下继续正常应用。图6是解串行化因子为7时的时序图。假设随路时钟的上升沿对应数据的最高比特,在FPGA内部,PLL会从随路时钟产生一个进行过相位调整的7倍频率采样时钟。此时钟对输入数据进行采样后送入解串器,通过控制解串器的装载时钟相位,得到确定的并行数据输出字顺序。装载时钟的相位相对随路时钟相位的固定差异是通过接收PLL的相位控制来实现的,因此必须在输入时钟稳定后再释放PLL的复位控制,或者等输入时钟稳定后再复位PLL一次,否则输出的字顺序在每次上电时都可能不固定。

图6:LVDS接收及解串行化时序图。

在具体应用时,还需通过仿真来确定具体应用下的字输出顺序,然后在逻辑设计里面进行调整,使最终的并行输出符合满足需求。下面以与TI的SN65LVDS95 LVDS发送器对接为例来介绍具体的设计方法和步骤。当把Stratix III的LVDS与别的LVDS器件对接时,也可以此为参考。

图7:LVDS95输出时序。

在图7,LVDS95输出的时钟和数据是对齐到输出时钟的上升沿上的,数据的最高比特(MSB)出现在时钟上升沿之在后的第三个比特。这里的目的是使Stratix III 的LVDS接收器输出正确的字顺序,也即图7中的D6出现在并行输出数据的最高比特上。

图8:综合设置页面。

假设并行侧的时钟频率是60MHz,这样串行LVDS的速率是480Mbps。为方便描述,这里只针对1路LVDS数据进行设计。

首先根据LVDS95的时序进行Stratix III中的LVDS模块(ALTLVDS)的调用。

图9:频率和锁相环设置页面。

在图8的综合设置页面中,我们没有选上"Implement Serializer/Deserializer circuitry in logic cells",这样就用到了LVDS SERDES硬核。同样也没有选上"Enable Dynamic Phase Alignment mode"选项,这表示不使用DPA功能。

图10:接收器设置页面。

在图9中,根据LVDS95的输出时序,在"What is the phase alignment of 'rx_in' with respect to the rising edge of 'rx_inclock'? "里选择了0度。在图10的设置中,通常情况下需要选上"Register outputs"选项。但因为后续设计逻辑包含了这些寄存器,所以这里选择该选项。此外,在这里没有使能"rx_channel_data_align"端口来进行字重新对齐。

作者:Altera公司 来源:维库开发网

上一篇:如何利用C和汇编语言混合编程实现DSP软件设计
下一篇:适于底层协议栈开发的数据采集与仿真系统

手机天线设计培训教程详情>>

手机天线设计培训教程 国内最全面、系统、专业的手机天线设计培训课程,没有之一;是您学习手机天线设计的最佳选择...【More..

射频和天线工程师培训课程详情>>

  网站地图