ImageVerifierCode 换一换
格式:DOC , 页数:16 ,大小:745KB ,
资源ID:6122540      下载积分:10 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/6122540.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(FPGA的LVDS介绍和xilinx原语的使用方法中文说明.doc)为本站上传会员【xrp****65】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

FPGA的LVDS介绍和xilinx原语的使用方法中文说明.doc

1、FPGA的LVDS介绍和xilinx原语的使用方法中文说明 低压差分传送技术是基于低压差分信号(Low Volt-agc Differential signaling)的传送技术,从一个电路板系统内的高速信号传送到不同电路系统之间的快速数据传送都可以应用低压差分传送技术来实现,其应用正变得越来越重要。低压差分信号相对于单端的传送具有较高的噪声抑制功能,其较低的电压摆幅允许差分对线具有较高的数据传输速率,消耗较小的功率以及产生更低的电磁辐射。 LVDS:Low Voltage Differential Signaling,低电压差分信号。 LVDS传输支持速率一般在155Mbps(大

2、约为77MHZ)以上。 LVDS是一种低摆幅的差分信号技术,它使得信号能在差分PCB线对或平衡电缆上以几百Mbps的速率传输,其低压幅和低电流驱动输出实现了低噪声和低功耗。 差分信号抗噪特性 从差分信号传输线路上可以看出,若是理想状况,线路没有干扰时, 在发送侧,可以形象理解为: IN= IN+ — IN- 在接收侧,可以理解为: IN+ — IN- =OUT 所以: OUT = IN 在实际线路传输中,线路存在干扰,并且同时出现在差分线对上, 在发送侧,仍然是: IN = IN+ — IN- 线路传输干扰同时存在于差分对上,假设干扰为q,则接收

3、则: (IN+ + q) — (IN- + q) = IN+ — IN- = OUT 所以: OUT = IN 噪声被抑止掉。 上述可以形象理解差分方式抑止噪声的能力。 From: 美国国家半导体的《LVDS用户手册》P9 FPGA中的差分管脚 为了适用于高速通讯的场合,现在的FPGA都提供了数目众多的LVDS接口。如Spartan-3E系列FPGA提供了下列差分标准: ? LVDS ? Bus LVDS ? mini-LVDS ? RSDS ? Differential HSTL (1.8V, Types I and III) ? Diff

4、erential 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 From:Spartan-3E FPGA Family:Complete Data Sheet p18 Spartan-3E系列F

5、PGA器件差分I/O接口输入工作的特性参数:   From:Spartan-3E FPGA Family:Complete Data Sheet p126 Spartan-3E系列FPGA器件差分I/O接口输出工作的特性参数:   From:Spartan-3E FPGA Family:Complete Data Sheet p127 Xilinx公司差分原语的使用 (原语,其英文名字为Primitive,是Xilinx针对其器件特征开发的一系列常用模块的名字,用户可以将其看成Xilinx公司为用户提供的库函数,类似于C++中的“cou

6、t”等关键字,是芯片中的基本元件,代表FPGA中实际拥有的硬件逻辑单元,如LUT,D触发器,RAM等,相当于软件中的机器语言。在实现过程中的翻译步骤时,要将所有的设计单元都转译为目标器件中的基本元件,否则就是不可实现的。原语在设计中可以直接例化使用,是最直接的代码输入方式,其和HDL语言的关系,类似于汇编语言和C语言的关系。) 关于Xilinx原语的详细介绍,可以参考下面文章 1)FPGA开发实用教程 第4节 Xilinx公司原语的使用方法 2)ISE的Help—sofeware Manuals 差分I/O端口组件 1)           IBUFDS

7、  IBUFDS原语用于将差分输入信号转化成标准单端信号,且可加入可选延迟。在IBUFDS原语中,输入信号为I、IB,一个为主,一个为从,二者相位相反。 IBUFDS的逻辑真值表所列,其中“-*”表示输出维持上一次的输出值,保持不变。 表IBUFDS原语的输入、输出真值表 IBUFDS原语的例化代码模板如下所示: // IBUFDS: 差分输入缓冲器(Differential Input Buffer) // 适用芯片:Virtex-II/II-Pro/4, Spartan-3/3E // Xilinx HDL库向导版本,ISE 9.1 IBUFDS

8、 #( .DIFF_TERM("FALSE"), // 差分终端,只有Virtex-4系列芯片才有,可设置为True/Flase .IOSTANDARD("DEFAULT") // 指定输入端口的电平标准,如果不确定,可设为DEFAULT ) IBUFDS_inst ( .O(O), // 时钟缓冲输出 .I(I), // 差分时钟的正端输入,需要和顶层模块的端口直接连接 .IB(IB) // 差分时钟的负端输入,需要和顶层模块的端口直接连接 ); // 结束IBUFDS模块的例化过程 Verilog Instantiation Templ

9、ate IBUFDS instance_name (.O (user_O),                        .I (user_I),                        .IB (user_IB)); 在综合结果分析时,IBUFDS的RTL结构如图所示。 图IBUFDS原语的RTL结构图 2)        OBUFDS OBUFDS将标准单端信号转换成差分信号,输出端口需要直接对应到顶层模块的输出信号,和IBUFDS为一对互逆操作。OBUFDS原语的真值表如表所列。 表OBUFDS原

10、语的真值表 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)

11、// 缓冲器输入 ); // 结束OBUFDS模块的例化过程 Verilog Instantiation Template OBUFDS instance_name (.O (user_O),                        .OB (user_OB),                         .I (user_I)); 在综合结果分析时,OBUFDS原语的RTL结构如图所示。 图OBUFDS的RTL结构图 3) IOBUFDS IOBUFDS原语真值表     I

12、OBUFDS的RTL结构图     Verilog Instantiation Template // IOBUFDS: Differential Bi-directional Buffer // Virtex-II/II-Pro/4/5, Spartan-3/3E/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" (S

13、partan- 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) .I

14、OB(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 差分时钟组件 1)IBUFGDS 与全局时钟资源相关的原语常用的与全局时钟资源相关的Xilinx器件原语包括:IBUFG、IBUFGDS、BUFG、BUFGP、BUFGCE、 BUFGMUX、BUFGDLL和DCM等,如图1所示。 IBUFGDS是IBUFG的差分形式,

15、当信号从一对差分全局时钟管脚输入时,必须使用IBUFGDS作为全局时钟输入缓冲。IBUFG支持BLVDS、LDT、LVDSEXT、LVDS、LVPECL和ULVDS等多种格式的IO标准。    IBUFGDS原语真值表   IBUFGDS的RTL结构图     Verilog Instantiation Template IBUFGDS instance_name (.O (user_O),                         .I (user_I),                      

16、    .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 nege

17、dge 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。添加div2的module在sch上。通过搜索,把时钟缓冲差分组件IB

18、UFGDS也放在div2_diff.sch上。 设置好clk的差分管脚,(按照Verilog命名规范)正的命名为clk_p,负的命名为clk_n。   在添加波形测试文件时要注意,Clock Information选择Multiple Clocks(因为时钟变为两个clk_p、clk_n)     下一步,把clk_p和clk_n都选上:   可以看到仿真的clk_p和clk_n都变为差分输入的了。   还要对div2_diff.sch进行管脚约束。div2_diff.ucf约束文

19、件如下: 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_n和clk_p都要设置在差分管脚对上, clk_n——C9——IO_L14P clk_p——D9——IO_L14N 并且逻辑电平标准设置为LVD

20、S_25。Spartan-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已经变为差分时钟了。   看div2_diff.sch的HDL文件(View HDL Functional Model)。可

21、以看到其实sch调用了IBUFGDS原语。   在差分设计中,经常会因为配置错误而使得综合出错,最常见的错误分析如下: ① 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

22、 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

23、clk_p IBUF clk_n 这个错误出错是因为差分管脚clk_p和clk_n没有约束到芯片的差分对管脚上。需要修改.ucf文件。至于芯片哪个管脚是差分对,可以参考相应芯片的Datasheet。XC3S500E-FG320(Spartan-3E fpga)有92个I/O差分管脚和12个输入差分管脚。 ② ERROR:Pack:946 - The I/O component "clk_p" has an illegal IOSTANDARD value. Components of type DIFFMI do not support

24、 IOSTANDARD LVCMOS33. Please correct the IOSTANDARD property value. 这个错误出错是因为差分管脚设置的逻辑电平标准不对,设置成LVCMOS33,应该设置为芯片支持的LVDS逻辑电平标准。 参考资料: 1)基于LVDS技术与FPGA的高速通讯应用研究,韩党群,唐征兵,张庆玲 2)LVDS原理与应用简介 3) 美国国家半导体的《LVDS用户手册》 Xilinx FPGA 如何使用LVDS 无论使用HDL flow还是schematic flow,只需要例化

25、IBUFDS,OBUFDS之类的差分缓冲器,就可以使用LVDS了。 例化之后,要定位Pin位置,使用PACE,在IO Standard中选择LVDS33或者LVDS25,还能选择有DCI的版本。定端口时,注意看Datasheet中Pin名字分P/N,这P也要对应buffer中的P,N也要对应N。而且注意同一个bank只能有一个电压标准。 如果用FPGA Editor观察布局布线后的情况,就会发现,FPGA Editor中没有IBUFDS这个Component,这个Buffer是藏在IOB里的,点击到Pin的图块中,可以看到里面有一个Buffer,就起到了IBUFDS这个作用。

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服