ARTIX-7 GTP 3G-SDI 使用实例

XILINX ARTIX-7 FPGA 可以使用GTP 传送最高3G-SDI的信号。本文记录 GTP调用方法,与SDI IP的互联方法等,最后实现1080p60彩条内部产生后经SDI回环后接收,仅适用于ARTIX-7或更高系列。组建工程部分参考赛灵思 xapp1097 实例。

操作概览:

调用GTP IP取出xxx_gt.v和xxx_common.v备用 →  调用3G-SDI IP  →  下载  xapp1097.zip  →  包装3G-SDI IP  →  实现1080p60彩条内部产生后经SDI回环然后接收,使用VIO调试观察接收端锁定情况。

IP说明:

需要调用两个IP:SMPTE SD/HD/3G-SDI 和 7 Series FPGAs Transceivers Wizard(使用GTP)

需要下载一个文件:xapp1097

 SDI IP    将使用到顶层和以下所有代码(SDI IP须命名为smpte_sdi),使用xapp1097内模块后 SDI IP被包装成名为a7gtp_sdi_rxtx_wrapper.v 的模块。

 GTP IP  使用 xxx_gt.v作为顶层,其内部包含的.v文件也可以从GTP IP示例工程中获得。xxx_common.v可以从GTP IP 示例工程中获得。

 


1.    新建一个vivado工程,我使用2017.4版本。添加GT IP核  7 Series FPGAs Transceivers Wizard

2.    IP核命名为 a7gtp_sdi_wrapper,按照下图设置

 

3.    翻到第二页,协议必须选择hd sdi,根据xapp1097即使用3g-sdi也必须选择hd sdi。一个GTP收发器使用两个PLL,确保两个PLL都使能,因为最后的应用需要TX端动态切换两个PLL,由于板子上只有148.5Mhz video OSC只能连接到一个时钟源,因此,不支持发送1.485/1.001 Gb/s HD-SDI和2.97/1.001 Gb/s 3G-SDI。但是,接收端因为有CDR unit,只有148.5Mhz晶振也可以接收5种SDI信号。(按照下图连接时钟源后TX端切换PLL并不能改变频率)

- 270 Mb/s SD-SDI

- 1.485 Gb/s HD-SDI

- 1.485/1.001 Gb/s HD-SDI (不支持发送该比特率除非有148.35 MHz osc)

- 2.97 Gb/s 3G-SDI

- 2.97/1.001 Gb/s 3G-SDI   (同上)

按照下图设置,此板连148.5Mhz晶振连接在REFCLK0_Q0上。

4.     翻到下一页,DRP/system clock freq 设置为27Mhz,该时钟用作SDI IP 和GTP IP辅助时钟,从外部 OSC接入(SDI专用),事实证明 该时钟可以不是精确的27Mhz,也可由内部PLL产生。其他设置默认

 

5.    下一页,按照下图设置

 

6.    下一页,可以勾选LOOPBACK用于调试,注意LOOPBACK是在FPGA内部进行回环,本文其实没有用到。其他默认

7.    其他页默认配置,点OK,generate

8.    右键打开示例工程,这会在示例工程中产生一个support文件夹,里面一个文件会用到。关闭示例工程

 

9.    找到示例工程下a7gtp_sdi_wrapper_common.v文件拷贝到原工程下(仅为方便)

cp ./a7gtp_sdi_wrapper_ex/a7gtp_sdi_wrapper_ex.srcs/sources_1/imports/example_design/support/a7gtp_sdi_wrapper_common.v 

./sdi.srcs/sources_1/ip/a7gtp_sdi_wrapper

该模块是对2个PLL的封装,一个GTP Quad 中含有2个PLL和4个收发器,一个_common.v 对应一个GTP Quad,可以实例化到多个GTP Quad 

10.    将以下文件加入工程

a7gtp_sdi_wrapper_gt.v                  下面三个可以从example_design内获得

+-------a7gtp_sdi_wrapper_gtrxreset_seq.v            

+-------a7gtp_sdi_wrapper_rxrate_seq.v      

+-------a7gtp_sdi_wrapper_sync_block.v 

a7gtp_sdi_wrapper_common.v

 


11.   创建SMPTE SD/HD/3G-SDI IP,必须命名为 smpte_sdi

 


12.    下载  xapp1097,删除SDI_wrapper内 a7gtp_sdi_rxtx_wrapper_ise.v 然后把以下目录加入工程

./SDI_wrapper

./dru

 

包含如图

13.     再把 /ac701_sdi_demo内的verilog文件加入,不要chipscope内的。

14.    可以发现新增了两个包装文件。这两个文件需要修改(下图2个“新增”),代码参见。在a7_sdi_rxtx.v中有一个ILA和两个VIO,所以需要手动添加这三个的IP,此处不细讲。

最后包含如上(注意还需要有ILA和VIO)


15.    a7gtp_sdi_rxtx_wrapper.v 内的 FXDCLK_FREQ变量设置为DRP/system clock freq。

16.    a7_sdi_rxtx.v 包装了SDI信号源、SDI IP以及 GTP的原语,还有一个逻辑分析仪和VIO,VIO用于选择发送模式。顶层ac701_sdi_demo.v包装了a7_sdi_rxtx.v和GTP PLL0/1。顶层内可以实例化两个a7_sdi_rxtx.v,那么约束过后会使用两个收发器。

17.    引脚约束(单个收发器)

set_property IOSTANDARD LVCMOS33 [get_ports clk_27M]

set_property IOSTANDARD LVCMOS33 [get_ports sdi0_sd_hd]

set_property PACKAGE_PIN F6 [get_ports mgtp_refclk0_p]

set_property PACKAGE_PIN B8 [get_ports mgtp_rx0_p]

set_property PACKAGE_PIN B4 [get_ports mgtp_tx0_p]

set_property PACKAGE_PIN C18 [get_ports clk_27M]

set_property PACKAGE_PIN A14 [get_ports sdi0_sd_hd]

18.    综合产生bit文件下载。输入输出对接同轴电缆。打开调试界面如下。接收锁定(mode_locked,rx_locked)成功

VIO

 

tx模式选择

 

ila rx SDI数据口

以上

操作省略较多 仅参考备忘用途

引用:

xapp1097-smpte-sdi-a7-gtp.pdf

xapp1097.zip

ug482_7Series_GTP_Transceivers.pdf

pg071-v-smpte-sdi.pdf

  • 5
    点赞
  • 68
    收藏
    觉得还不错? 一键收藏
  • 12
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值