原创 (Xilinx)FPGA中LVDS差分高速传输的实现

2009-2-24 18:20 20441 14 29 分类: FPGA/CPLD

XilinxFPGALVDS差分高速传输的实现<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />


低压差分传送技术是基于低压差分信号(Low Volt-agc Differential signaling)的传送技术,从一个电路板系统内的高速信号传送到不同电路系统之间的快速数据传送都可以应用低压差分传送技术来实现,其应用正变得越来越重要。低压差分信号相对于单端的传送具有较高的噪声抑制功能,其较低的电压摆幅允许差分对线具有较高的数据传输速率,消耗较小的功率以及产生更低的电磁辐射。


 


LVDSLow Voltage Differential Signaling,低电压差分信号。


LVDS传输支持速率一般在155Mbps(大约为77MHZ)以上。


LVDS是一种低摆幅的差分信号技术,它使得信号能在差分PCB线对或平衡电缆上以几百Mbps的速率传输,其低压幅和低电流驱动输出实现了低噪声和低功耗。


 


差分信号抗噪特性


从差分信号传输线路上可以看出,若是理想状况,线路没有干扰时,


在发送侧,可以形象理解为:


IN= IN+ IN-


在接收侧,可以理解为:


IN+ IN- =OUT


所以:


OUT = IN


在实际线路传输中,线路存在干扰,并且同时出现在差分线对上,


在发送侧,仍然是:


IN = IN+ IN-


线路传输干扰同时存在于差分对上,假设干扰为q,则接收则:


(IN+ + q) (IN- + q) = IN+ IN- = OUT


所以:


OUT = IN


 


噪声被抑止掉。 上述可以形象理解差分方式抑止噪声的能力。


 


欲了解更多LVDS,可以参考《LVDS原理与应用简介》pdf


 


<?xml:namespace prefix = v ns = "urn:schemas-microsoft-com:vml" />


点击看大图


From: 美国国家半导体的《LVDS用户手册》P9


 


FPGA中的差分管脚


     为了适用于高速通讯的场合,现在的FPGA都提供了数目众多的LVDS接口。如Spartan-3E系列FPGA提供了下列差分标准:


? LVDS


? Bus LVDS


? mini-LVDS


? RSDS


? Differential HSTL (1.8V, Types I and III)


? Differential SSTL (2.5V and 1.8V, Type I)


? 2.5V LVPECL inputs


  


所拥有的差分I/O管脚数目如下



 


点击看大图


From:Spartan-3E FPGA Family:Complete Data Sheet   p5


 


I/O管脚的命名方式:



 


点击看大图


From:Spartan-3E FPGA Family:Complete Data Sheet    p164


 



9e2bb4e6-d0a2-4ed2-a5e5-a31982d27926.JPG


From:Spartan-3E FPGA Family:Complete Data Sheet    p18


 


Spartan-3E系列FPGA器件差分I/O接口输入工作的特性参数:




 


733ab97f-1a32-4ae8-9852-5d2645efd63d.JPG


点击看大图


From:Spartan-3E FPGA Family:Complete Data Sheet    p126


 


Spartan-3E系列FPGA器件差分I/O接口输出工作的特性参数:




 


ea71ce57-3222-47a7-9ab5-4fd6100850cc.JPG


点击看大图


From:Spartan-3E FPGA Family:Complete Data Sheet    p127


 


Xilinx公司差分原语的使用


(原语,其英文名字为Primitive,是Xilinx针对其器件特征开发的一系列常用模块的名字,用户可以将其看成Xilinx公司为用户提供的库函数,类似于C++中的“cout”等关键字,是芯片中的基本元件,代表FPGA中实际拥有的硬件逻辑单元,如LUTD触发器,RAM等,相当于软件中的机器语言。在实现过程中的翻译步骤时,要将所有的设计单元都转译为目标器件中的基本元件,否则就是不可实现的。原语在设计中可以直接例化使用,是最直接的代码输入方式,其和HDL语言的关系,类似于汇编语言和C语言的关系。)


 


关于Xilinx原语的详细介绍,可以参考下面文章


1FPGA开发实用教程  4 Xilinx公司原语的使用方法


http://www.eefocus.com/article/08-03/37457s.html  


2ISEHelpsofeware Manuals


 



点击看大图 


 


差分I/O端口组件


1)           IBUFDS 


IBUFDS原语用于将差分输入信号转化成标准单端信号,且可加入可选延迟。在IBUFDS原语中,输入信号为IIB,一个为主,一个为从,二者相位相反。

IBUFDS
的逻辑真值表所列,其中“-*”表示输出维持上一次的输出值,保持不变。


IBUFDS原语的输入、输出真值表

点击看大图


IBUFDS原语的例化代码模板如下所示:

// IBUFDS:
差分输入缓冲器(Differential Input Buffer

//
适用芯片:
Virtex-II/II-Pro/4, Spartan-3/3E
// Xilinx HDL
库向导版本,
ISE 9.1
IBUFDS #(
.DIFF_TERM("FALSE"),

//
差分终端,只有Virtex-4系列芯片才有,可设置为True/Flase
.IOSTANDARD("DEFAULT")
//
指定输入端口的电平标准,如果不确定,可设为
DEFAULT
) IBUFDS_inst (
.O(O), //
时钟缓冲输出

.I(I), //
差分时钟的正端输入,需要和顶层模块的端口直接连接

.IB(IB) //
差分时钟的负端输入,需要和顶层模块的端口直接连接

);
//
结束IBUFDS模块的例化过程



http://www.xilinx.com/itp/xilinx6/books/data/docs/lib/lib0229_197.html


Verilog Instantiation Template


IBUFDS instance_name (.O (user_O),


                                  .I (user_I),


                                  .IB (user_IB));



在综合结果分析时,IBUFDSRTL结构如图所示。


313d8cad-8c45-490d-bdf3-9fc9714061a9.JPG
IBUFDS原语的RTL结构图


 

2)        OBUFDS


OBUFDS将标准单端信号转换成差分信号,输出端口需要直接对应到顶层模块的输出信号,和IBUFDS为一对互逆操作。OBUFDS原语的真值表如表所列。


OBUFDS原语的真值表

2183eb4b-e29d-4134-b13d-250a039a65b3.JPG


OBUFDS原语的例化代码模板如下所示:

// OBUFDS:
差分输出缓冲器(Differential Output Buffer

//
适用芯片:
Virtex-II/II-Pro/4, Spartan-3/3E
// Xilinx HDL
库向导版本,
ISE 9.1
OBUFDS #(
.IOSTANDARD("DEFAULT")

//
指名输出端口的电平标准
) OBUFDS_inst (
.O(O), //
差分正端输出,直接连接到顶层模块端口

.OB(OB), //
差分负端输出,直接连接到顶层模块端口

.I(I) //
缓冲器输入

);
//
结束OBUFDS模块的例化过程


http://www.xilinx.com/itp/xilinx5/data/docs/lib/lib0317_301.html


Verilog Instantiation Template


OBUFDS instance_name (.O (user_O),


                                  .OB (user_OB),


                                  .I (user_I));


 

在综合结果分析时,OBUFDS原语的RTL结构如图所示。


2861709a-cfca-4fa2-af00-272d5f2c5d38.JPG
OBUFDSRTL结构图


 


3) IOBUFDS


IOBUFDS原语真值表



 

点击看大图 


 


IOBUFDSRTL结构图


e6a14dbf-7e1e-40e4-8f59-b67d0fb52088.JPG


 


 


Verilog Instantiation Template


// IOBUFDS: Differential Bi-directional Buffer


// Virtex-II/II-Pro/4/5, Spartan-3/3E/<?xml:namespace prefix = st1 ns = "urn:schemas-microsoft-com:office:smarttags" />3A


// Xilinx HDL Libraries Guide, version 9.1i


IOBUFDS #(


.IBUF_DELAY_VALUE("0"),


// Specify the amount of added input delay for the buffer, "0"-"16" (Spartan-


3E only)


.IFD_DELAY_VALUE("AUTO"),


// Specify the amount of added delay for input register, "AUTO", "0"-"8"


(Spartan-3E only)


.IOSTANDARD("DEFAULT") // Specify the I/O standard


) IOBUFDS_inst (


.O(O), // Buffer output


.IO(IO), // Diff_p inout (connect directly to top-level port)


.IOB(IOB), // Diff_n inout (connect directly to top-level port)


.I(I), // Buffer input


.T(T) // 3-state enable input


);


// End of IOBUFDS_inst instantiation


 


差分时钟组件


1IBUFGDS


与全局时钟资源相关的原语常用的与全局时钟资源相关的Xilinx器件原语包括:IBUFGIBUFGDSBUFGBUFGPBUFGCE BUFGMUXBUFGDLLDCM等,如图1所示。


IBUFGDSIBUFG的差分形式,当信号从一对差分全局时钟管脚输入时,必须使用IBUFGDS作为全局时钟输入缓冲。IBUFG支持BLVDSLDTLVDSEXTLVDSLVPECLULVDS等多种格式的IO标准。


http://www.xilinx.com/itp/xilinx6/books/data/docs/lib/lib0231_199.html


 


   IBUFGDS原语真值表


 


1851460a-2259-4006-acb5-105272443804.JPG


 


IBUFGDSRTL结构图


 


6113926c-bb0f-4fe0-a13c-33eb602f22a8.JPG


 


Verilog Instantiation Template


IBUFGDS instance_name (.O (user_O),


                                   .I (user_I),


                                   .IB (user_IB));


 


LVDS差分的在FPGA中的应用


     在高速传输的过程中,经常会受到干扰而误码,因此有时候时钟输入采用差分输入的办法来提高抗干扰的能力。下面已一个二分频为例子:


 


二分频Verilog代码如下:


`timescale 1ns / 1ps


 


module div2(clk, div2_clk, rst_n);


    input clk;


    input rst_n;


        


        output div2_clk;


        reg div2_clk;


 


    always@(posedge clk or negedge rst_n)


       begin 


                     if(!rst_n)


                          div2_clk<=0;


                     else div2_clk<=~div2_clk;


               end


               


endmodule


 


布线布局的仿真(Post-Route Simulation)波形如下:


 



点击看大图 


    


        现在对时钟clk信号进行差分处理,对div2 module进行例化(Create Schematic Symbol


        新建一个div2_diff.sch。添加div2modulesch上。通过搜索,把时钟缓冲差分组件IBUFGDS也放在div2_diff.sch上。


 



86b0d06b-b3fa-4f0d-9656-0bb230e7bba4.JPG


 


    设置好clk的差分管脚,(按照Verilog命名规范)正的命名为clk_p,负的命名为clk_n



 

点击看大图


 


   


       在添加波形测试文件时要注意,Clock Information选择Multiple Clocks(因为时钟变为两个clk_pclk_n



 

点击看大图 


 


下一步,把clk_pclk_n都选上:


 


点击看大图



 


可以看到仿真的clk_pclk_n都变为差分输入的了。



 

点击看大图


 


还要对div2_diff.sch进行管脚约束。div2_diff.ucf约束文件如下:


NET "clk_p"  LOC = "C9" | IOSTANDARD = LVDS_25 ;


NET "clk_n"  LOC = "D9" | IOSTANDARD = LVDS_25 ;


NET "div2_clk"  LOC = "A10" | IOSTANDARD = LVCMOS33 ;


NET "rst_n"  LOC = "H13" | IOSTANDARD = LVCMOS33 ;


 


要注意:


clk_nclk_p都要设置在差分管脚对上,


clk_n——C9——IO_L14P


clk_p——D9——IO_L14N


并且逻辑电平标准设置为LVDS_25Spartan-3E支持下面的差分逻辑电平标准。


? LVDS


? Bus LVDS


? mini-LVDS


? RSDS


? Differential HSTL (1.8V, Types I and III)


? Differential SSTL (2.5V and 1.8V, Type I)


? 2.5V LVPECL inputs


 


     综合、翻译、映射和布线布局后,运行布线布局仿真,可以看到时钟clk已经变为差分时钟了。



 

点击看大图


 


本文工程文件下载 https://static.assets-stash.eet-china.com/album/old-resources/2009/2/24/a4512f43-eb90-4ef6-b038-a058b0869625.rar


 


    div2_diff.schHDL文件(View HDL Functional Model)。可以看到其实sch调用了IBUFGDS原语。



 

2b12eb62-a9c3-428a-8388-6f04243ba583.JPG


 


在差分设计中,经常会因为配置错误而使得综合出错,最常见的错误分析如下:



ERROR:Place:332 - This design contains an LVDS IO pair. The pair of IOs must be placed in a specific relative structure.


   The two IOs can not be placed in this specific structure.


   The reason for this issue:


   All of the logic associated with this structure is locked and the relative placement of the logic violates the


   structure. The problem was found between the relative placement of IBUF clk_p at site PAD27 and IBUF clk_n at site


   IPAD28.  The following components are part of this structure:


      IBUF   clk_p


      IBUF   clk_n


 


        这个错误出错是因为差分管脚clk_pclk_n没有约束到芯片的差分对管脚上。需要修改.ucf文件。至于芯片哪个管脚是差分对,可以参考相应芯片的DatasheetXC3S500E-FG320(Spartan-3E fpga)92I/O差分管脚和12个输入差分管脚。


 



ERROR:Pack:946 - The I/O component "clk_p" has an illegal IOSTANDARD value.


   Components of type DIFFMI do not support IOSTANDARD LVCMOS33.  Please correct


   the IOSTANDARD property value.


 


这个错误出错是因为差分管脚设置的逻辑电平标准不对,设置成LVCMOS33,应该设置为芯片支持的LVDS逻辑电平标准。


 


 


 


参考资料:


1基于LVDS技术与FPGA的高速通讯应用研究,韩党群,唐征兵,张庆玲


http://www.eccn.com/xsj07/xsj080231.asp 


2LVDS原理与应用简介


http://www.ent.eetchina.com/ART_8800472639_2700004_TA_5d4d019d.HTM 


3) 美国国家半导体的《LVDS用户手册》


http://www.ent.eetchina.com/ART_8800562170_2700004_TA_552cca6f.HTM


 


 


 


Xilinx FPGA 如何使用LVDS


 


http://www.61eda.com/Services/help/Xilinx/200803/1225.html


 


无论使用HDL flow还是schematic flow,只需要例化IBUFDS,OBUFDS之类的差分缓冲器,就可以使用LVDS了。


 


    例化之后,要定位Pin位置,使用PACE,在IO


    Standard中选择LVDS33或者LVDS25,还能选择有DCI的版本。定端口时,注意看DatasheetPin名字分P/N,这P也要对应buffer中的PN也要对应N。而且注意同一个bank只能有一个电压标准。


 


    如果用FPGA Editor观察布局布线后的情况,就会发现,FPGA


    Editor中没有IBUFDS这个Component,这个Buffer是藏在IOB里的,点击到Pin的图块中,可以看到里面有一个Buffer,就起到了IBUFDS这个作用。

文章评论15条评论)

登录后参与讨论

用户1822227 2015-8-23 21:59

楼主写的不错 可以参考一下,同时感谢楼上几位的评论

用户377235 2015-6-12 11:36

good

用户1238067 2011-4-18 16:04

请问是用何种布局布线软件来仿真的?

用户1238067 2011-4-18 15:56

Good!

coyoo 2009-9-25 12:25

以上是我在例化lvds的时候出现的错误,无法一次性贴出来,呵呵,有见过这种错误吗?

coyoo 2009-9-25 12:24

(output signal=dataouta_n<0>), pin SNK of Output PAD symbol "tx_output_reg<0>".

coyoo 2009-9-25 12:24

of OBUFDS symbol "loop0[0].obuf_d"

coyoo 2009-9-25 12:23

have a valid load. It is driving: pin I

coyoo 2009-9-25 12:22

signal=tx_output_reg<0>) does not

coyoo 2009-9-25 12:21

ERROR:LIT:156 - The O pin of OBUF symbol "loop0[0].fd_d/OBUF1" (output
相关推荐阅读
藤井树 2015-10-12 14:43
印制电路板的抗干扰设计 zz
印制电路板的抗干扰设计     作者:中船重工集团第707所 肖麟芬   摘   要:本文以印制电路板的电磁兼容性为核心,分析了电磁干扰的产生机理...
藤井树 2013-10-22 15:32
2010.5.30 黄草梁上包饺子一日登山活动——摘韭菜篇
        上次桃花节的时候也有野韭菜,那时候的我连草和韭菜叶分不清,才回去的韭菜也不敢吃,哈哈,这次可算真正见识了韭菜,黄草梁也叫韭菜梁,因为满山遍野都是野韭菜而闻名,比较圆比较粗的就是野韭...
藤井树 2013-10-22 15:28
2010.5.30 黄草梁上包饺子一日登山活动——包饺子篇
摘韭菜回来,大家已经忙开了 我也装模作样地“工作着” 哈哈,还不让我包,包饺子是技术活,一定要皮薄馅厚才有资格包,像我这样的只能旁观了 摘的韭菜应该足够了,旁边那个袋子是我摘来带回学校的 ...
藤井树 2013-08-09 15:19
datasheet下载网站整理(查IC芯片手册)【原创】
*************************************************************************         作为电子工程师,芯片的dat...
藤井树 2010-06-04 00:21
陈伟宁王辉一家捐助渠道(北京菲亚特—英菲尼迪)
       王辉的最新消息请关注 http://chenweining.org/       目前事故责任认定已经出来了——陈家全责。        发信人: program (程序), 信区: D...
藤井树 2010-06-01 13:43
2010.5.30 黄草梁上包饺子一日登山活动——美景篇
这天不得不说的是天空,蓝蓝的天空,白白的云    绿油油的山脊  我、洪涛哥哥、huangna妹妹还有她同事小艾走在黄草梁上    在蓝天白云下合影       阳光照过来,景色真美 象鼻山,走不...
我要评论
15
14
关闭 站长推荐上一条 /2 下一条