论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
ToB企服应用市场:ToB评测及商务社交产业平台
»
论坛
›
软件与程序人生
›
云原生
›
FPGA实现SDI视频缩放转UltraScale GTH光口传输,基于GS2 ...
FPGA实现SDI视频缩放转UltraScale GTH光口传输,基于GS2971+Aurora 8b/10b ...
反转基因福娃
金牌会员
|
2025-2-18 22:00:29
|
显示全部楼层
|
阅读模式
楼主
主题
908
|
帖子
908
|
积分
2724
FPGA实现SDI视频缩放转UltraScale GTH光口传输,基于GS2971+Aurora 8b/10b编解码架构,提供2套工程源码和技术支持
1、前言
FPGA实现SDI视频编解码现状;
一是使用专用编解码芯片,比如典型的接收器GS2971,发送器GS2972,优点是简单,比如GS2971接收器直接将SDI解码为并行的YCrCb422,GS2972发送器直接将并行的YCrCb422编码为SDI视频,缺点是成本较高,可以百度一下GS2971和GS2972的价格;另一种方案是使用FPGA逻辑资源部实现SDI编解码,利用Xilinx系列FPGA的GTP/GTX资源实现解串,利用Xilinx系列FPGA的SMPTE SDI资源实现SDI编解码,优点是合理利用了FPGA资源,GTP/GTX资源不消白不消,缺点是操纵难度大一些,对FPGA开辟者的技术水平要求较高。本计划使用GS2971接收器方案;
FPGA实现SFP光口视频编解码现状;
如今基于Xilinx系列FPGA的SFP光口视频编解码告急有以下几种,Artix7系列的GTP、Kintex7系列的GTX、更高端FPGA器件的GTH、GTY、GTV、GTM等,线速率越来越高,应用场景也越来越高端;编码方式也是多种多样,有8b/10b编解码、64b/66b编解码、HDMI编解码、SDI编解码等等;本计划采用UltraScale系列的UltraScale GTH作为高速接口、8b/10b编解码的方式实现SFP光口视频编解码;
工程概述
本计划使用Xilinx UltraScale系列FPGA为平台,实现UltraScale GTH 8b/10b编解码视频传输;输入源为一个3G-SDI相机大概HDMI转3G-SDI盒子,也可以使用SD-SDI大概HD-SDI相机,因为本计划是三种SDI视频自顺应的,同轴的SDI视频通过同轴线毗连到GS2971转接板,GS2971解码芯片将同轴串行的SDI视频解码为并行的BT1120格式视频,至此,SDI视频解码操纵已经完成,可以进行通例的图像处理操纵了;然后使用纯verilog实现的BT1120转RGB模块实现视频格式转换后输出RGB888视频;然后使用自研的、纯verilog实现的、支持恣意比例缩放的图像缩放模块实现对输入视频的图像缩放操纵;然后缩放视频送入视频组包模块,将视频的每一行打上包头包尾标记以包的形式输出,将视频的每一行打上包头包尾标记以包的形式输出,以便接收方进行有效识别;让后调用Xilinx官方的UltraScale GTH IP核实现视频8b/10b编码和数据串化,将并行数据串化为高速串行差分信号,线速率设置为5Gbps,编码后的视频通过板载的SFP光口的光纤输出;然后用板载的SFP光口的光纤接收视频,然后送入Xilinx官方的UltraScale GTH IP核实现视频8b/10b解码和数据解串,将差分高速串行信号解为并行数据;然后数据送入数据对齐模块,实现错位数据对齐;然后数据送入视频解包模块,实现每一行的视频包头包尾拆解,并生成对应的场同步信号和数据有效信号输出;然后使用本博主常用的FDMA图像缓存架构对采集视频做图像3帧缓存,缓存介质为板载DDR4;然后Native视频时序控制FDMA从DDR4中读取视频并同步输出RGB888视频流;然后使用RGB转HDMI模块或专用芯片实现RGB视频流转HDMI差分视频信号;最后用显示器显示视频即可;针对市场主流需求,本博客计划并提供2套工程源码,具体如下:
现对上述2套工程源码做如下解释,方便读者理解:
工程源码1
开辟板FPGA型号为Xilinx–Kintex UltraScale–xcku060-ffva1156-2-i;输入源为一个3G-SDI相机大概HDMI转3G-SDI盒子,也可以使用SD-SDI大概HD-SDI相机,因为本计划是三种SDI视频自顺应的,同轴的SDI视频通过同轴线毗连到GS2971转接板,GS2971解码芯片将同轴串行的SDI视频解码为并行的BT1120格式视频,至此,SDI视频解码操纵已经完成,可以进行通例的图像处理操纵了;然后使用纯verilog实现的BT1120转RGB模块实现视频格式转换后输出RGB888视频;然后使用自研、纯verilog实现的、支持恣意比例缩放的图像缩放模块,将输入视频由1920x1080缩放为1280x720;然后缩放视频送入送入视频组包模块,将视频的每一行打上包头包尾标记以包的形式输出,以便接收方进行有效识别;让后调用Xilinx官方的UltraScale GTH IP核实现视频8b/10b编码和数据串化,将并行数据串化为高速串行差分信号,线速率设置为5Gbps,编码后的视频通过板载的SFP光口的光纤输出;然后用板载的SFP光口的光纤接收视频,然后送入Xilinx官方的UltraScale GTH IP核实现视频8b/10b解码和数据解串,将差分高速串行信号解为并行数据;然后数据送入数据对齐模块,实现错位数据对齐;然后数据送入视频解包模块,实现每一行的视频包头包尾拆解,并生成对应的场同步信号和数据有效信号输出;然后使用本博主常用的FDMA图像缓存架构对采集视频做图像3帧缓存,缓存介质为板载DDR4;然后Native视频时序控制FDMA从DDR4中读取视频并同步输出RGB888视频流;然后经过纯verilog显示的RGB转HDMI模块输出HDMI差分视频,输出分辨率为1280x720@60Hz;由此形成Sensor+高速接口+光编码+HDMI的高端架构;该工程适用于SFP光口的视频采集卡(光端机)应用;
工程源码2
开辟板FPGA型号为Xilinx–>Zynq UltraScale–xczu4ev-sfvc784-1-i;输入源为一个3G-SDI相机大概HDMI转3G-SDI盒子,也可以使用SD-SDI大概HD-SDI相机,因为本计划是三种SDI视频自顺应的,同轴的SDI视频通过同轴线毗连到GS2971转接板,GS2971解码芯片将同轴串行的SDI视频解码为并行的BT1120格式视频,至此,SDI视频解码操纵已经完成,可以进行通例的图像处理操纵了;然后使用纯verilog实现的BT1120转RGB模块实现视频格式转换后输出RGB888视频;然后使用自研、纯verilog实现的、支持恣意比例缩放的图像缩放模块,将输入视频由1920x1080缩放为1280x720;然后缩放视频送入送入视频组包模块,将视频的每一行打上包头包尾标记以包的形式输出,以便接收方进行有效识别;让后调用Xilinx官方的UltraScale GTH IP核实现视频8b/10b编码和数据串化,将并行数据串化为高速串行差分信号,线速率设置为5Gbps,编码后的视频通过板载的SFP光口的光纤输出;然后用板载的SFP光口的光纤接收视频,然后送入Xilinx官方的UltraScale GTH IP核实现视频8b/10b解码和数据解串,将差分高速串行信号解为并行数据;然后数据送入数据对齐模块,实现错位数据对齐;然后数据送入视频解包模块,实现每一行的视频包头包尾拆解,并生成对应的场同步信号和数据有效信号输出;然后使用本博主常用的FDMA图像缓存架构对采集视频做图像3帧缓存,缓存介质为PS端DDR4;然后Native视频时序控制FDMA从DDR4中读取视频并同步输出RGB888视频流;然后经过ADV7511输出HDMI差分视频,输出分辨率为1280x720@60Hz;由此形成Sensor+高速接口+光编码+HDMI的高端架构;该工程适用于SFP光口的视频采集卡(光端机)应用;
本博客具体描述了FPGA基于Aurora 8b/10b编解码架构实现UltraScale GTH光口视频传输的计划方案,工程代码可综合编译上板调试,可直接项目移植,适用于在校学生、研究生项目开辟,也适用于在职工程师做学习提拔,可应用于医疗、军工等行业的高速接口或图像处理领域;
提供完备的、跑通的工程源码和技术支持;
工程源码和技术支持的获取方式放在了文章末端,请耐心看到最后;
免责声明
本工程及其源码即有自己写的一部分,也有网络公开渠道获取的一部分(包括CSDN、Xilinx官网、Altera官网等等),若大佬们觉得有所冒犯,请私信批评教育;基于此,本工程及其源码仅限于读者或粉丝个人学习和研究,禁止用于贸易用途,若由于读者或粉丝自身原因用于贸易用途所导致的法律问题,与本博客及博主无关,请谨慎使用。。。
2、干系方案推荐
我已有的所有工程源码总目录----方便你快速找到自己喜欢的项目
实在一直有朋侪反馈,说我的博客文章太多了,乱花渐欲迷人,自己看得一头雾水,不方便快速定位找到自己想要的项目,所以本博文置顶,列出我如今已有的所有项目,并给出总目录,每个项目的文章链接,当然,本博文实时更新。。。以下是博客地点:
点击直接前往
我这里已有的 GT 高速接口解决方案
我的主页有FPGA GT 高速接口专栏,该专栏有 GTP 、 GTX 、 GTH 、 GTY 等GT 资源的视频传输例程和PCIE传输例程,其中 GTP基于A7系列FPGA开辟板搭建,GTX基于K7大概ZYNQ系列FPGA开辟板搭建,GTH基于KU大概V7系列FPGA开辟板搭建,GTY基于KU+系列FPGA开辟板搭建;以下是专栏地点:
点击直接前往
本博已有的 SDI 编解码方案
我的博客主页开设有SDI视频专栏,里面满是FPGA编解码SDI的工程源码及博客介绍;既有基于GS2971/GS2972的SDI编解码,也有基于GTP/GTX资源的SDI编解码;既有HD-SDI、3G-SDI,也有6G-SDI、12G-SDI等;专栏地点链接如下:
点击直接前往
我这里已有的FPGA图像缩放方案
我的主页如今有FPGA图像缩放专栏,改专栏收录了我如今手里已有的FPGA图像缩放方案,从实现方式分类有基于HSL实现的图像缩放、基于纯verilog代码实现的图像缩放;从应用上分为单路视频图像缩放、多路视频图像缩放、多路视频图像缩放拼接;从输入视频分类可分为OV5640摄像头视频缩放、SDI视频缩放、MIPI视频缩放等等;以下是专栏地点:
点击直接前往
3、工程具体计划方案
工程计划原理框图
工程计划原理框图如下:
SDI 输入设备
SDI 输入设备可以是SDI相机,代码兼容HD/SD/3G-SDI三种模式;SDI相机相对比力贵,预算有限的朋侪可以考虑用HDMI转SDI盒子模仿SDI相机,这种盒子某宝一百块左右;当使用HDMI转SDI盒子时,输入源可以用条记本电脑,即用条记本电脑通过HDMI线毗连到HDMI转SDI盒子的HDMI输入接口,再用SDI线毗连HDMI转SDI盒子的SDI输出接口到FPGA开辟板,如下:
GS2971芯片
本计划采用GS2971芯片解码SDI,GS2971不需要软件设置,硬件电阻上下拉即可完成设置,本计划设置为输出BT1120格式视频,当然,你在计划电路时也可以设置为输出CEA861格式视频;GS2971硬件架构如下,提供PDF格式原理图:
BT1120转RGB
BT1120转RGB模块的作用是将SMPTE SD/HD/3G SDI IP核解码输出的BT1120视频转换为RGB888视频,它由BT1120转CEA861模块、YUV422转YUV444模块、YUV444转RGB888三个模块组成,该方案参考了Xilinx官方的计划;BT1120转RGB模块代码架构如下:
BT1120转RGB模块顶层接口如下:
纯Verilog图像缩放模块详解
本计划的图像缩放模块使用纯Verilog方案,功能框图如下,由跨时钟FIFO、插值+RAM阵列构成,跨时钟FIFO的目的是解决跨时钟域的问题,比如从低分辨率视频放大到高分辨率视频时,像素时钟必然需要变大,这是就需要异步FIFO了,插值算法和RAM阵列具体负责图像缩放算法层面的实现;
插值算法和RAM阵列以ram和fifo为焦点进行数据缓存和插值实现,计划架构如下:
依据上图,图像缩放模块内部焦点是例化了4个双口RAM,作用是缓存4行图像,以得到4个邻近的像素,以此为底子做线性插值;如果是做图像放大操纵,就以这4个邻近的像素为基准,以线性插值为算法,在原图像中插入更多的像素点来扩大分辨率;如果是做图像缩小操纵,就以这4个邻近的像素为基准,以线性插值为算法,在原图像中删除更多的像素点来缩小分辨率;别的,前面描述的工作是实时的、整幅图像全部扫描式的进行,所以需要对RAM的读写操纵进行精准控制;
图像缩放模块代码架构如下:模块的例化请参考工程源码的顶层代码;
图像缩放模块FIFO的选择可以调用工程对应的vivado工具自带的FIFO IP核,也可以使用纯verilog实现的FIFO,可通过接口参数选择,图像缩放模块顶层接口如下:
FIFO_TYPE选择原则如下:
1:总体原则,选择"xilinx"好处大于选择"verilog";
2:当你的FPGA逻辑资源不敷时,请选"xilinx";
3:当你图像缩放的视频分辨率较大时,请选"xilinx";
4:当你的FPGA没有FIFO IP大概FIFO IP快用完了,请选"verilog";
5:当你向自学一下异步FIFO时,,请选"verilog";
6:不同FPGA型号对应的工程FIFO_TYPE参数不一样,但选择原则一样,具体参考代码;
2种插值算法的整合与选择
本计划将常用的双线性插值和邻域插值算法融合为一个代码中,通过输入参数选择某一种算法;
具体选择参数如下:
input wire i_scaler_type //0-->bilinear;1-->neighbor
复制代码
通过输入i_scaler_type 的值即可选择;
输入0选择双线性插值算法;
输入1选择邻域插值算法;
代码里的设置如下:
纯Verilog图像缩放模块使用(重点阅读)
图像缩放模块使用非常简单,顶层代码里设置了四个参数,举比方下:
上图是将输入视频分辨率从1280x720缩放为1920x1080;
如果你想将输入视频分辨率从1280x720缩放为640x480;
则只需修改为如下:
再比如你想将输入视频分辨率从1280x720缩放为960x540;
则只需修改为如下:
当然,需要修改的不仅仅这一个地方,FDMA的设置也需要相应修改,详情请参考代码,但我想要证明的是,图像缩放模块使用非常简单,你都不需要知道它内部具体怎么实现的,上手就能用;
在本博主这里,想要实现图像缩放,操纵就是这么无脑简单,就该两个参数就能搞定貌似高大上的双线性插值图像缩放,这种计划、这种操纵、这种工程源码,你还喜欢吗?
视频数据组包
由于视频需要在UltraScale GTH 中通过aurora 8b/10b协议收发,所以数据必须进行组包,以顺应aurora 8b/10b协议标准;视频数据组包模块代码位置如下:
起首,我们将16bit的视频存入FIFO中,存满一行时就从FIFO读出送入UltraScale GTH发送;在此之前,需要对一帧视频进行编号,也叫作指令,UltraScale GTH组包时根据固定的指令进行数据发送,UltraScale GTH解包时根据固定的指令恢复视频的场同步信号和视频有效信号;当一帧视频的场同步信号上升沿到来时,发送一帧视频开始指令 0,当一帧视频的场同步信号降落沿到来时,发送一帧视频开始指令 1,视频消隐期间发送无效数据 0 和无效数据 1,当视频有效信号到来时将每一行视频进行编号,先发送一行视频开始指令,在发送当前的视频行号,当一行视频发送完成后再发送一行视频竣事指令,一帧视频发送完成后,先发送一帧视频竣事指令 0,再发送一帧视频竣事指令 1;至此,一帧视频则发送完成,这个模块不太好理解,所以我在代码里进行了具体的中文解释,需要注意的是,为了防止中文解释的乱序显示,请用notepad++编辑器打开代码;指令界说如下:
注意!!!指令可以恣意更改,但最低字节必须为bc;
基于UltraScale GTH高速接口的视频传输架构
本计划使用UltraScale GTH高速接口传输视频,使用8b/10b编解码协议,搭建基于UltraScale GTH高速接口的视频传输架构,包括视频数据组包模块、UltraScale GTH IP核设置调用、接收数据对齐模块、视频数据解包模块等部分,总体代码架构如下:
基于UltraScale GTH高速接口的视频传输架构顶层接口核参数设置如下:
本计划共例化了2路UltraScale GTH,所以2路UltraScale GTH的收发回环方式也做了灵活的参数化设置,如果你只需要1路GT,则可删除另一起,如果你想例化更多路GT,则可根据上述计划方法扩展,十分方便;
UltraScale GTH IP 简介
关于UltraScale GTH 介绍最具体的肯定是Xilinx官方的《ug576-ultrascale-gth-transceivers》,我们以此来解读:《ug576-ultrascale-gth-transceivers》的PDF文档我已放在了资料包里;我用到的开辟板FPGA型号为Kirtex7-UltraScale-xcku060-ffva1156-2-i;带有28路UltraScale GTX资源,其中2路毗连到了板载2个SFP光口,每通道的收发速率为 500 Mb/s 到 16.375 Gb/s 之间。GTH 收发器支持不同的串行传输接口或协议,比如8b/10b编解码、PCIE /2.0/3.0 接口、万兆网 XUAI 接口、OC-48、串行 RapidIO 接口、 SATA(Serial ATA) 接口、数字分量串行接口(SDI)等等;
UltraScale GTH 基本结构
UltraScale GTH 基本结构如下:
Xilinx 以 Quad 来对串行高速收发器进行分组,四个串行高速收发器和一个 COMMOM(QPLL)组成一个 Quad,每一个串行高速收发器称为一个 Channel(通道),下图为UltraScale GTH 收发器在Kintex7 UltraScale FPGA 芯片中的示意图:《ug576-ultrascale-gth-transceivers》第19页;
在 Ultrascale/Ultrascale+架构系列的 FPGA 中,GTH 高速收发器通常使用 Quad 来划分,一个 Quad 由四个GTHE3/4_CHANNEL 原语和一个 GTHE3/4_COMMON 原语组成。每个GTHE3/4_COMMON 中包罗两个 LC-tank pll(QPLL0 和 QPLL1)。只有在应用步伐中使用 QPLL 时,才需要实例化 GTHE3/4_COMMON。每个 GTHE3/4_CHANNEL 由一个 channel PLL(CPLL)、一个 transmitter,和一个 receiver 组成。一个参考时钟可以直接毗连到一个 GTHE3/4_CHANNEL 原语,而不需要实例化 GTHE3/4_COMMON;
Ultrascale GTH 收发器的发送端和接收端功能是相互独立,都是由 Physical Media Attachment(物理媒介适配层 PMA)和Physical Coding Sublayer(物理编码子层 PCS)组成。PMA 内部集成了串并转换(PISO)、预加重、接收均衡、时钟发生器和时钟恢复等;PCS 内部集成了 8b/10b 编解码、弹性缓冲区、通道绑定和时钟修正等,每个 GTHE3/4_CHANNEL源语的逻辑电路见《ug576-ultrascale-gth-transceivers》第20页;
UltraScale GTH 的参考时钟
UltraScale 器件中的 GTH 收发器提供了不同的参考时钟输入选项。参考时钟选择架构支持 QPLL0、QLPLL1 和CPLL。从架构上讲,每个 Quad 包罗四个 GTHE3/4_CHANNEL 原语,一个 GTHE3/4_COMMON 原语,两个专用的外部参考时钟引脚对,以及专用的参考时钟路由。如果使用到了高性能 QPLL,则必须实例化 GTHE3/4_COMMON,如下面 GTHE3/4_COMMON 时钟多路复用器结构的具体视图所示,(《ug576-ultrascale-gth-transceivers》第33页)在一个 Quad 中有 6 个参考时钟引脚对,两个本地参考时钟引脚对:GTREFCLK0或GTREFCLK1,两个参考时钟引脚对来自上面的两个Quads:GTSOUTHREFCLK0或 GTSOUTHREFCLK1,两个参考时钟引脚对来自下面的两个 Quads: GTNORTHREFCLK0 或GTNORTHREFCLK1。
UltraScale GTH 发送和接收处理流程
起首用户逻辑数据经过 8B/10B 编码后,进入一个发送缓存区(Phase Adjust FIFO),该缓冲区告急是 PMA 子层和 PCS 子层两个时钟域的时钟隔离,解决两者时钟速率匹配和相位差别的问题,最后经过高速 Serdes 进行并串转换(PISO),有须要的话,可以进行预加重(TX Pre-emphasis)、后加重。值得一提的是,如果在 PCB 计划时不慎将 TXP 和 TXN 差分引脚交叉毗连,则可以通过极性控制(Polarity)来弥补这个计划错误。接收端和发送端过程相反,相似点较多,这里就不赘述了,需要注意的是 RX 接收端的弹性缓冲区,其具有时钟纠正和通道绑定功能。这里的每一个功能点都可以写一篇论文甚至是一本书,所以这里只需要知道个概念即可,在具体的项目中回具体用到,照旧那句话:对于初次使用大概想快速使用者而言,更多的精力应该关注IP核的调用和使用。
UltraScale GTH 发送接口
《ug576-ultrascale-gth-transceivers》的第104到179页具体介绍了发送处理流程,其中大部分内容对于用户而言可以不去穷究,因为手册讲的基本都是他自己的计划头脑,留给用户可操纵的接口并不多,基于此思绪,我们重点讲讲UltraScale GTH例化时留给用户的发送部分需要用到的接口;用户只需要关心发送接口的时钟和数据即可,以例化2路UltraScale GTH 为例,经本博主优化,用户只需要关心如下UltraScale GTH 发送接口即可快速使用UltraScale GTH ;
UltraScale GTH 接收接口
《ug576-ultrascale-gth-transceivers》的第181到314页具体介绍了发送处理流程,其中大部分内容对于用户而言可以不去穷究,因为手册讲的基本都是他自己的计划头脑,留给用户可操纵的接口并不多,基于此思绪,我们重点讲讲UltraScale GTH 例化时留给用户的发送部分需要用到的接口;用户只需要关心接收接口的时钟和数据即可,以例化2路UltraScale GTH 为例,经本博主优化,用户只需要关心如下UltraScale GTH 接收接口即可快速使用UltraScale GTH ;
UltraScale GTH IP核调用和使用
UltraScale GTH IP核设置调用在工程种位置如下:
UltraScale GTH IP核调用和使用很简单,通过vivado的UI界面即可完成,如下:
UltraScale GTH基本设置如下:板载差分晶振125M,线速率设置为5G,协议类型被指为aurora 8b/10b;如下:
相较于Xilinx 7系列FPGA的GT高速接口,UltraScale系列FPGA在物理约束页也有较大改进,已不需要用户再去检察官方数据手册找到原理图所在的FPGA内部位置,而是直接给出了具体PIN脚,只要在这里选对了位置,GT高速接口的时钟和数据引脚在XDC中已不再需要约束,如下:
别的,有别于Xilinx 7系列FPGA的GT高速接口;UltraScale 系列FPGA的GT高速接口在控制引脚方面更加细节,用户可以选择具体哪些控制引脚被使用,当然,这需要开辟人员对SERDES技术有较高的认知,在此底子上,可使我们的计划更加便捷,对于8B/10编解码协议而言,开辟者可能只需关注并使用极性反转控制,如果需要动态变速,可能还需要使用DRP接口,其余功能性接口实在不必太过关注;如下:
接收数据对齐模块
由于GT资源的aurora 8b/10b数据收发天然有着数据错位的环境,所以需要对接受到的解码数据进行数据对齐处理,数据对齐模块代码位置如下:
我界说的 K 码控制字符格式为:XX_XX_XX_BC,所以用一个rx_ctrl 指示数据是否为 K 码 的 COM 符号;
rx_ctrl = 4’b0000 表示 4 字节的数据没有 COM 码;
rx_ctrl = 4’b0001 表示 4 字节的数据中[ 7: 0] 为 COM 码;
rx_ctrl = 4’b0010 表示 4 字节的数据中[15: 8] 为 COM 码;
rx_ctrl = 4’b0100 表示 4 字节的数据中[23:16] 为 COM 码;
rx_ctrl = 4’b1000 表示 4 字节的数据中[31:24] 为 COM 码;
基于此,当接收到有K码时就对数据进行对齐处理,也就是将数据打一拍,和新进来的数据进行错位组合,这是FPGA的底子操纵,这里不再赘述;数据对齐模块顶层接口如下:
视频数据解包
数据解包是数据组包的逆过程,代码位置如下:
UltraScale GTH解包时根据固定的指令恢复视频的场同步信号和视频有效信号;这些信号是作为后面图像缓存的告急信号;由于数据解包是数据组包的逆过程,所以这里不再过多赘述,视频数据解包模块顶层接口如下:
FDMA图像缓存
FDMA图像缓存架构实现的功能是将输入视频缓存到板载DDR中再读出送后续模块,目的是实现视频同步输出,实现输入视频到输出视频的跨时钟域问题,更好的出现显示结果;由于调用了Xilinx官方的MIG作为DDR控制器,所以FDMA图像缓存架构就是实现用户数据到MIG的桥接作用;架构如下:
FDMA图像缓存架构由FDMA控制器+FDMA组成;FDMA实际上就是一个AXI4-FULL总线主设备,与MIG对接,MIG设置为AXI4-FULL接口;FDMA控制器实际上就是一个视频读写逻辑,以写视频为例,假设一帧图像的巨细为M×N,其中M代表图像宽度,N代表图像高度;FDMA控制器每次写入一行视频数据,即每次向DDR中写入M个像素,写N次即可完成1帧图像的缓存,读视频与之一样;同时调用两个FIFO实现输入输出视频的跨时钟域处理,使得用户可以AXI4内部代码,以简单地像使用FIFO那样操纵AXI总线,从而到达读写DDR的目的,进而实现视频缓存;本计划图像缓存方式为3帧缓存;图像缓存模块代码架构如下:
基于FDMA的图像缓存架构在Block Design计划中如下:
HDMI视频输出
缓存图像从DDR4读出后经过Native时序生成模块输出标准的VGA时序视频,然后经过纯verilog显示的RGB转HDMI模块输出HDMI差分视频;最后送显示器显示即可;需要注意的是,UltraScale系列FPGA不支持oserdese2原语,所以只能用oserdese3原语实现10 bit串化,基于此,本博主提供的RGB转HDMI模块可支持7系列、ULTRASCALE系列FPGA、ULTRASCALE_PLUS系 FPGA,顶层代码如下:
代码例化如下:
别的,有的FPGA开辟板采用专用芯片实现RGB转HDMI功能,这种环境下只需设置芯片即可,本计划中有的工程就是使用了ADV7511芯片,其i2c设置代码如下:
工程源码架构
提供2套工程源码,以工程源码1为例,工程Block Design计划如下:
提供2套工程源码,以工程源码1为例,综合后的工程源码架构如下:
工程源码2使用了Zynq;PL端时钟由Zynq软核提供,所以需要运行运行SDK以启动Zynq,所以需要在SDK里运行一个简单的hello world步伐,SDK软件代码架构如下:
4、vivado工程源码1详解–>KU060版本
开辟板FPGA型号:Xilinx–Kintex UltraScale–xcku060-ffva1156-2-i;
FPGA开辟环境:Vivado2019.1;
输入:3G-SDI相机或HDMI转SDI盒子,分辨率1920x1080@60Hz;
输出:HDMI,RTL逻辑编码方案,分辨率1280x720@60Hz;
SDI视频解码方案:GS2971芯片方案;
图像缩放方案:纯verilog代码实现、恣意比例缩放的图像缩放模块;
图像缩放用例:1920x1080缩放到1280x720;
回环光口类型:SFP光口;
高速接口类型:UltraScale GTH,线速率5Gbps;
高速接口编解码协议:8b/10b编解码;
图像缓存方案:FDMA图像缓存+DDR4颗粒+3帧缓存;
实现功能:FPGA实现UltraScale GTH光口视频传输;
工程作用:此工程目的是让读者把握FPGA实现UltraScale GTH光口视频传输的计划本领,以便能够移植和计划自己的项目;
工程Block Design和工程代码架构请参考第3章节的《工程源码架构》末节内容;
工程的资源消耗和功耗如下:
5、vivado工程源码2详解–>Zynq UltraScale ZU4EV版本
开辟板FPGA型号:Xilinx–>Zynq UltraScale–xczu4ev-sfvc784-1-i;
FPGA开辟环境:Vivado2019.1;
输入:3G-SDI相机或HDMI转SDI盒子,分辨率1920x1080@60Hz;
输出:HDMI,ADV7511编码方案,分辨率1280x720@60Hz;
SDI视频解码方案:GS2971芯片方案;
图像缩放方案:纯verilog代码实现、恣意比例缩放的图像缩放模块;
图像缩放用例:1920x1080缩放到1280x720;
回环光口类型:SFP光口;
高速接口类型:UltraScale GTH,线速率5Gbps;
高速接口编解码协议:8b/10b编解码;
图像缓存方案:FDMA图像缓存+PS端DDR4颗粒+3帧缓存;
实现功能:FPGA实现UltraScale GTH光口视频传输;
工程作用:此工程目的是让读者把握FPGA实现UltraScale GTH光口视频传输的计划本领,以便能够移植和计划自己的项目;
工程Block Design和工程代码架构请参考第3章节的《工程源码架构》末节内容;
工程的资源消耗和功耗如下:
6、工程移植说明
vivado版本不一致处理
1:如果你的vivado版本与本工程vivado版本一致,则直接打开工程;
2:如果你的vivado版本低于本工程vivado版本,则需要打开工程后,点击文件–>另存为;但此方法并不保险,最保险的方法是将你的vivado版本升级到本工程vivado的版本大概更高版本;
3:如果你的vivado版本高于本工程vivado版本,解决如下:
打开工程后会发现IP都被锁住了,如下:
此时需要升级IP,操纵如下:
FPGA型号不一致处理
如果你的FPGA型号与我的不一致,则需要更改FPGA型号,操纵如下:
更改FPGA型号后还需要升级IP,升级IP的方法前面已经讲述了;
其他注意事项
1:由于每个板子的DDR不一定完全一样,所以MIG IP需要根据你自己的原理图进行设置,甚至可以直接删掉我这里原工程的MIG并重新添加IP,重新设置;
2:根据你自己的原理图修改引脚约束,在xdc文件中修改即可;
3:纯FPGA移植到Zynq需要在工程中添加zynq软核;
7、上板调试验证
预备工作
需要预备的器材如下:
SDI摄像头、GS2971转接板;
FPGA开辟板,没有开辟板可以找本博提供;
SFP光模块和光纤;
我的开辟板了毗连如下:
UltraScale GTH光口SDI视频传输结果演示
UltraScale GTH光口SDI视频传输结果演示如下:
SDI-GTP
8、工程代码的获取
代码太大,无法邮箱发送,以某度网盘链接方式发送,
资料获取方式:私,大概文章末端的V名片。
网盘资料如下:
别的,有许多朋侪给本博主提了许多意见和发起,希望能丰富服务内容和选项,因为不同朋侪的需求不一样,所以本博主还提供以下服务:
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
回复
使用道具
举报
0 个回复
正序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
发新帖
回复
反转基因福娃
金牌会员
这个人很懒什么都没写!
楼主热帖
设计模式---组合模式
Spark快速上手(4)Spark核心编程-Spark ...
拿到12家offer,想给大家分享一下面试 ...
【Unity3D】Transform组件
如何将鸿蒙(harmonyOS)系统退回安卓 ...
写了这么久Java项目,是否还记得你的第 ...
【渗透攻击】PowerShell与Shell 有什么 ...
软件工程经济学第一章
年度重磅!《2022华为开发者宝典》多元 ...
使用 Kubeadm 部署 K8S安装
标签云
挺好的
服务器
快速回复
返回顶部
返回列表