找回密码
 注册
关于网站域名变更的通知
查看: 608|回复: 2
打印 上一主题 下一主题

(Xilinx)在FPGA中LVDS差分高速传输是怎样实现的(中)

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2019-8-8 09:30 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x

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

8 b$ j" y4 Z/ t' R/ M' C2 B' E% _

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

Xilinx公司差分原语的使用

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

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

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

2)ISE的Help—sofeware Manuals

: u+ w+ Z) v' h% w

差分I/O端口组件

1)           IBUFDS

IBUFDS原语用于将差分输入信号转化成标准单端信号,且可加入可选延迟。在IBUFDS原语中,输入信号为I、IB,一个为主,一个为从,二者相位相反。 5 H, k0 a( ]) t7 x4 U6 j8 a- Y
IBUFDS的逻辑真值表所列,其中“-*”表示输出维持上一次的输出值,保持不变。

表IBUFDS原语的输入、输出真值表 : A" I1 I0 w( ~: M- H

IBUFDS原语的例化代码模板如下所示:
/ q- g: V( X0 d. |" ~& M- j
% t3 U& k  W/ Q, J9 Q" r// IBUFDS: 差分输入缓冲器(Differential Input Buffer)
9 q# a4 H! |* w' K// 适用芯片:Virtex-II/II-Pro/4, Spartan-3/3E 9 C  n7 j; D0 k0 U
// Xilinx HDL库向导版本,ISE 9.1 / U5 _, C" a* `; ^4 ?) |& z- d% Q
IBUFDS #( 1 F! P; y8 ^0 C3 N! c
.DIFF_TERM("FALSE"),
( U0 O3 ~; r( \8 c: J( f// 差分终端,只有Virtex-4系列芯片才有,可设置为True/Flase
+ t. x& g" a, \* F; {.IOSTANDARD("DEFAULT") % ]/ m- b  H7 c" z! e
// 指定输入端口的电平标准,如果不确定,可设为DEFAULT
! j/ m$ r/ w  i: u' W) IBUFDS_inst ( 9 Y: h- D) z/ v: |
.O(O), // 时钟缓冲输出
4 O. y5 {' H4 @.I(I), // 差分时钟的正端输入,需要和顶层模块的端口直接连接
0 Q- k5 T. I% [, o.IB(IB) // 差分时钟的负端输入,需要和顶层模块的端口直接连接 , ]3 n" ?2 p( c# Q% _
); ) o3 j3 w9 S  n. \
// 结束IBUFDS模块的例化过程
- A! F) U! y! [( h9 Z1 c
+ F) _, Q% e: x" X  }' W: ^( G' F

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


! s" M+ g) j" X; K  a

Verilog Instantiation Template

IBUFDS instance_name (.O (user_O),

                                  .I (user_I),

                                  .IB (user_IB));

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

+ t) C! T% H  j4 o9 a+ N
图IBUFDS原语的RTL结构图

2)        OBUFDS

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

表OBUFDS原语的真值表 $ E% q' o8 d7 y: l, q

OBUFDS原语的例化代码模板如下所示:
' [" {. ?6 u" O: E* a) H( B! c6 e, {+ ~0 a0 W" Y  S: K  I
// OBUFDS: 差分输出缓冲器(Differential Output Buffer) " w2 ]( X+ t" ~1 @! X6 i! S- v- t$ l
// 适用芯片:Virtex-II/II-Pro/4, Spartan-3/3E
9 z" d+ \6 m7 {8 ~// Xilinx HDL库向导版本,ISE 9.1
/ P: Y2 w% h' n0 J3 K. i' i7 bOBUFDS #(
: q% W" L$ n$ i9 k/ q" }- L% A.IOSTANDARD("DEFAULT") 1 y0 M" e' G1 S! _0 s/ V# {
// 指名输出端口的电平标准
+ k' q+ c& e! p& @4 F, ]+ ^9 j) OBUFDS_inst ( 9 {: E  ]4 t: l& w% E* L1 q" I
.O(O), // 差分正端输出,直接连接到顶层模块端口 0 V1 I( J- h% s4 }( o( d
.OB(OB), // 差分负端输出,直接连接到顶层模块端口 - ^9 X  ~% ~- _! H5 D0 v  v0 J1 M
.I(I) // 缓冲器输入 " X7 T7 R3 B; {' z- E
); : B; P3 e# g3 v, [; C
// 结束OBUFDS模块的例化过程

0 J+ g) ]3 I0 @6 U' C1 N+ Y

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

/ o$ h& s# T2 O7 Z

Verilog Instantiation Template

OBUFDS instance_name (.O (user_O),

                                  .OB (user_OB),

                                  .I (user_I));

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

- v5 h  m2 {$ @' n
图OBUFDS的RTL结构图

3) IOBUFDS

IOBUFDS原语真值表

IOBUFDS的RTL结构图

, H1 F, t, B* U2 t% S  k


6 Y; F7 r( G! n6 G  O4 H# S+ e) U


7 h! S, s: _& d/ }& J1 N' W4 b' y
2 O9 D% ], p% R2 ]

该用户从未签到

3#
发表于 2022-4-12 15:03 | 只看该作者
在FPGA中LVDS差分高速传输是怎样实现的
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-7-27 17:03 , Processed in 0.125000 second(s), 27 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表