目录
1、前言
PCIE(PCIExpress)采用了目前业内流行的点对点串行联接,比起PCI以及更初期的计算机总线的共享并行构架,每位设备都有自己的专用联接,不须要向整个总线恳求带宽linux驱动程序开发视频,并且可以把数据传输率提升到一个很高的频度,达到PCI所不能提供的高带宽,是目前各行业高速插口的优先选择方向,具有很高的实用价值和学习价值;
本设计使用Xilinx官方的XDMA方案搭建基于Xilinx系列FPGA的PCIE通讯平台,该方案只适用于Xilinx系列FPGA,一并提供了XDMA的安装驱动和QT上位机源代码,省去了使用XDMA繁杂的驱动寻觅和上位机软件开发的不知所措,并以搭建好vivado工程,省去了不晓得怎么使用XDMA的难堪,致使PCIE的使用显得简单易上手,而不用关心其复杂的PCIE合同;因为我的开发板只支持PCIEX4,所以提供的代码是PCIEX4构架,若须要PCIEX1、X2、X8、X16、X32的同学,可自行更改本工程,也可关注我,我会实时发布新的工程。
本工程实现基础的PCIE测速试验上进行了更改,借助开发板自带的HDMI输入插口,实时采集HDMI输入视频,缓存DDR3后输出XDMA,通过PCIE发送给QT上位机显示程序;
本文详尽描述了基于XDMA搭建PCIE的HDMI视频采集设计方案,工程代码可综合编译上板调试,可直接项目移植linux驱动程序开发视频,适用于在校中学生、研究生项目开发,也适用于在职工程师做项目开发,可应用于医疗、军工等行业的高速插口和图象传输领域;
提供完整的、跑通的工程源码和技术支持;
工程源码和技术支持的获取方法放到了文章末尾,请耐心见到最后;
2、我已有的PCIE方案
我的主页有PCIE通讯专栏,既有基于RIFFA实现的PCIE方案,也有基于XDMA实现的PCIE方案;既有简单的数据交互、测速,也有应用级别的图象采集传输,以下是专栏地址:
点击直接抵达
3、PCIE理论
这部份可自行百度或csdn或知乎学习理论知识,虽然用了XDMA,早已不太须要直至PCIE复杂的合同和理论了。。。
4、总体设计思路和方案
总体设计思路和方案如下:
PCIe通讯类库由三部份组成:FPGA端程序、PCIe卡驱动、PCIe上位机测试程序:
FPGA端工程:负责构建与PCIe通讯需具备的FPGA框架,PCIe通讯合同的建立;
PCIe驱动:负责上位机测试程序与PCIe卡的数据交换;
PCIe上位机测试程序:此处时PCIe显示;
视频输入:电脑模拟HDMI视频输入源;
HDMI解码,使用silicon9134芯片完成HDMI解码,silicon9134须要i2c配置就能使用linux格式化命令,关于silicon9134的i2c配置使用,请参考我之前写的文章:点击直接抵达
图象缓存:使用AXI4总线实现了图象读写DDR3,此处做了3帧缓存;
输出:PCIEX4;
QT测速上位机:提供源代码和可执行程序,发开版本为QT5.6.2;
5、vivado工程解读
开发板FPGA机型:Xilinxxc7a100tfgg484-2;
开发环境:Vivado2019.1;
输入:HDMI;
输出:PCIEX4;
应用:QT上位机显示试验;
工程BD如下:
综合后的工程代码构架如下:
综合编译完成后的FPGA资源消耗和帧率预估如下:
6、驱动安装
提供提供Win系统驱动,目录如下:
驱动安装参考上面的测速试验:点击直接抵达
7、QT上位机软件
QT显示上位机:提供源代码和可执行程序,发开版本为QT5.6.2;位置如下:
部份源码截图如下:
8、上板调试验证
开启上位机测程序进行PCIe显示测试嵌入式linux,打开右图的显示软件pcie2screen,软件在如下位置,实验结果如下:
打开上位机之后可以看见软件暂停播放:
点击中间的按键,开始播放HDMI输入视频源的视频:
9、福利:工程代码的获取
福利:工程代码的获取
代码太大,难以邮箱发送,以某度云盘链接形式发送,
资料获取方法:私,或则文章末尾的V名片。
云盘资料如下: