[X]关闭

XILINX FPGA LVDS 差分时钟原语、IObuf 原语 调用

文档创建者:uisrc
浏览次数:13220
最后更新:2022-04-08
悬赏1积分未解决

差分I/O端口组件


1)           IBUFDS


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

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));


2)        OBUFDS


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

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));


3) IOBUFDS



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" (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



差分时钟组件


1)IBUFGDS


与全局时钟资源相关的原语常用的与全局时钟资源相关的Xilinx器件原语包括:IBUFG、IBUFGDS、BUFG、BUFGP、BUFGCE、 BUFGMUX、BUFGDLL和DCM等,如图1所示。


IBUFGDS是IBUFG的差分形式,当信号从一对差分全局时钟管脚输入时,必须使用IBUFGDS作为全局时钟输入缓冲。IBUFG支持BLVDS、LDT、LVDSEXT、LVDS、LVPECL和ULVDS等多种格式的IO标准。


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




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


发表评论已发布 2

兰兰的天

发表于 2021-1-5 09:19:23 | 显示全部楼层

格雷诺那在短暂的一生中生活方面没有十一运夺金什么欲望,他唯一的追求是掌握生产香水的技术,使自己成为香水之王。他依靠自己的特异嗅觉,勤奋工作,终于如愿以偿。但在资本主义社会里,他的特异功能只能为资本家所利用。他并未发财致富,而超级大乐透敛财致富的却是资本家。小说《香水》通过榕雷诺耶为格里马、巴尔迪尼、阿尔努菲寡妇卖命,反映了资本主义剥削的天津时时彩极端残酷性。格雷诺那一生寂寞、孤独,没有一个真正的朋友,只知拼命劳动以求生存,这恰恰暴露了资本主义社会中人与人之间的冷漠关系和竞争关系

回复

使用道具 举报

hkkarfgw

发表于 2022-4-8 09:39:30 | 显示全部楼层

good
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则