FPGA实现AD7606数据采集转PCIE传输,基于XDMA中断架构,提供8套工程源码和技术支持

文章介绍了使用XilinxXDMA方案构建的FPGAPCIE通信平台,详细阐述了设计思路、Vivado工程设置、驱动安装、QT上位机软件和工程移植步骤。项目涉及AD7606数据采集和DDR3缓存,提供了完整工程代码与技术支持。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


FPGA实现AD7606数据采集转PCIE传输,基于XDMA中断架构,提供8套工程源码和技术支持

1、前言

FPGA实现PCIE数据传输现状;
目前基于Xilinx系列FPGA的PCIE通信架构主要有以下2种,一种是简单的、傻瓜式的、易于开发的、对新手友好的XDMA架构,该架构对PCIE协议底层做了封装,并加上了DMA引擎,使得使用的难度大大降低,加之Xilinx提供了配套的Windows和Linux系统驱动和上位机参考源代码,使得XDMA一经推出就让工程师们欲罢不能;另一种是更为底层的、需要设计者有一定PCIE协议知识的、更易于定制化开发的7 Series Integrated Block for PCI Express架构,该IP实现的是PCIe 的物理层、链路层和事务层,提供给用户的是以 AXI4-stream 接口定义的TLP 包,使用该IP 核,需要对PCIe 协议有清楚的理解,特别是对事务包TLP报文格式;本设计采用第一种方案,使用XDMA的中断模式实现PCIE通信;本架构既有简单的测速实验,也有视频采集应用;

工程概述

本设计使用Xilinx系列FPGA为平台,调用Xilinx官方的XDMA方案搭建基中断模式下的AD7606数据采集转PCIE传输;输入源为AD数据源,我用到的是示波器,用示波器产生一个正弦波,然后示波器信号接入AD7606转接板;AD7606有两种输出模式,一是串行模式,可以节约IO引脚,方便PCB布线,二是并行模式,IO引脚较多,本设计使用到了两种AD7606转接板,分别对应串行模式和并行模式;FPGA端用纯verilog代码设计了AD7606驱动,该驱动配置AD7606并采集AD数据,有串行模式和并行模式两个版本;AD7606在驱动的加持下将模拟信号转换为数字信号后传给FPGA;然后使用本博主常用的FDMA数据缓存架构将采集到的AD7606数据进行缓存缓存;缓存介质设计了两种方案,一是FPGA板载的DDR3作为缓存介质,对应你的开发板有DDR3的情况,二是FPGA内部的BRAM作为缓存介质,对应你的开发板无DDR3的情况;本设计为选取AD7606全部8通道的其中2个通道进行缓存,缓存4096个点后就发起一次用户中断给XDMA,XDMA收到用户中断后通知QT上位机发起一次XDMA读数据操作,XDMA再从DDR中读取一帧视频并通过PCIE总线发送给QT上位机,QT上位机接收并显示当前采集的AD数据;本博客提供8套工程源码,具体如下:
在这里插入图片描述
现对上述8套工程源码做如下解释,方便读者理解:

工程源码1

开发板FPGA型号为Xilinx–>Artix7-100T–xc7a100tfgg484-2;输入源为AD数据源,我用到的是示波器,用示波器产生一个正弦波,然后示波器信号接入AD7606转接板;AD7606输出模式为串行模式;FPGA端用纯verilog代码设计了AD7606驱动,该驱动配置AD7606并采集AD数据;AD7606在驱动的加持下将模拟信号转换为数字信号后传给FPGA;然后使用本博主常用的FDMA数据缓存架构将采集到的AD7606数据进行缓存缓存;缓存介质为FPGA板载的DDR3;本设计为选取AD7606全部8通道的其中2个通道进行缓存,缓存4096个点后就发起一次用户中断给XDMA,XDMA收到用户中断后通知QT上位机发起一次XDMA读数据操作,XDMA再从DDR中读取一帧视频并通过PCIE总线发送给QT上位机,QT上位机接收并显示当前采集的AD数据;板载PCIE为1 Lane的PCIE2.0;单Lane线速率配置为5GT/s;由此形成AD7606+XDMA+PCIE+QT的高端架构;该工程适用于PCIE接口的AD数据采集卡应用;

工程源码2

开发板FPGA型号为Xilinx–>Artix7-100T–xc7a100tfgg484-2;输入源为AD数据源,我用到的是示波器,用示波器产生一个正弦波,然后示波器信号接入AD7606转接板;AD7606输出模式为串行模式;FPGA端用纯verilog代码设计了AD7606驱动,该驱动配置AD7606并采集AD数据;AD7606在驱动的加持下将模拟信号转换为数字信号后传给FPGA;然后使用本博主常用的FDMA数据缓存架构将采集到的AD7606数据进行缓存缓存;缓存介质为FPGA板载的BRAM;本设计为选取AD7606全部8通道的其中2个通道进行缓存,缓存4096个点后就发起一次用户中断给XDMA,XDMA收到用户中断后通知QT上位机发起一次XDMA读数据操作,XDMA再从DDR中读取一帧视频并通过PCIE总线发送给QT上位机,QT上位机接收并显示当前采集的AD数据;板载PCIE为1 Lane的PCIE2.0;单Lane线速率配置为5GT/s;由此形成AD7606+XDMA+PCIE+QT的高端架构;该工程适用于PCIE接口的AD数据采集卡应用;

工程源码3

开发板FPGA型号为Xilinx–>Artix7-100T–xc7a100tfgg484-2;输入源为AD数据源,我用到的是示波器,用示波器产生一个正弦波,然后示波器信号接入AD7606转接板;AD7606输出模式为并行模式;FPGA端用纯verilog代码设计了AD7606驱动,该驱动配置AD7606并采集AD数据;AD7606在驱动的加持下将模拟信号转换为数字信号后传给FPGA;然后使用本博主常用的FDMA数据缓存架构将采集到的AD7606数据进行缓存缓存;缓存介质为FPGA板载的DDR3;本设计为选取AD7606全部8通道的其中2个通道进行缓存,缓存4096个点后就发起一次用户中断给XDMA,XDMA收到用户中断后通知QT上位机发起一次XDMA读数据操作,XDMA再从DDR中读取一帧视频并通过PCIE总线发送给QT上位机,QT上位机接收并显示当前采集的AD数据;板载PCIE为4 Lane的PCIE2.0;单Lane线速率配置为5GT/s;由此形成AD7606+XDMA+PCIE+QT的高端架构;该工程适用于PCIE接口的AD数据采集卡应用;

工程源码4

开发板FPGA型号为Xilinx–>Artix7-100T–xc7a100tfgg484-2;输入源为AD数据源,我用到的是示波器,用示波器产生一个正弦波,然后示波器信号接入AD7606转接板;AD7606输出模式为并行模式;FPGA端用纯verilog代码设计了AD7606驱动,该驱动配置AD7606并采集AD数据;AD7606在驱动的加持下将模拟信号转换为数字信号后传给FPGA;然后使用本博主常用的FDMA数据缓存架构将采集到的AD7606数据进行缓存缓存;缓存介质为FPGA板载的BRAM;本设计为选取AD7606全部8通道的其中2个通道进行缓存,缓存4096个点后就发起一次用户中断给XDMA,XDMA收到用户中断后通知QT上位机发起一次XDMA读数据操作,XDMA再从DDR中读取一帧视频并通过PCIE总线发送给QT上位机,QT上位机接收并显示当前采集的AD数据;板载PCIE为4 Lane的PCIE2.0;单Lane线速率配置为5GT/s;由此形成AD7606+XDMA+PCIE+QT的高端架构;该工程适用于PCIE接口的AD数据采集卡应用;

工程源码5

开发板FPGA型号为Xilinx–>Kintex7–35T–xc7k325tffg900-2;输入源为AD数据源,我用到的是示波器,用示波器产生一个正弦波,然后示波器信号接入AD7606转接板;AD7606输出模式为串行模式;FPGA端用纯verilog代码设计了AD7606驱动,该驱动配置AD7606并采集AD数据;AD7606在驱动的加持下将模拟信号转换为数字信号后传给FPGA;然后使用本博主常用的FDMA数据缓存架构将采集到的AD7606数据进行缓存缓存;缓存介质为FPGA板载的DDR3;本设计为选取AD7606全部8通道的其中2个通道进行缓存,缓存4096个点后就发起一次用户中断给XDMA,XDMA收到用户中断后通知QT上位机发起一次XDMA读数据操作,XDMA再从DDR中读取一帧视频并通过PCIE总线发送给QT上位机,QT上位机接收并显示当前采集的AD数据;板载PCIE为8 Lane的PCIE2.0;单Lane线速率配置为5GT/s;由此形成AD7606+XDMA+PCIE+QT的高端架构;该工程适用于PCIE接口的AD数据采集卡应用;

工程源码6

开发板FPGA型号为Xilinx–>Kintex7–35T–xc7k325tffg900-2;输入源为AD数据源,我用到的是示波器,用示波器产生一个正弦波,然后示波器信号接入AD7606转接板;AD7606输出模式为串行模式;FPGA端用纯verilog代码设计了AD7606驱动,该驱动配置AD7606并采集AD数据;AD7606在驱动的加持下将模拟信号转换为数字信号后传给FPGA;然后使用本博主常用的FDMA数据缓存架构将采集到的AD7606数据进行缓存缓存;缓存介质为FPGA板载的BRAM;本设计为选取AD7606全部8通道的其中2个通道进行缓存,缓存4096个点后就发起一次用户中断给XDMA,XDMA收到用户中断后通知QT上位机发起一次XDMA读数据操作,XDMA再从DDR中读取一帧视频并通过PCIE总线发送给QT上位机,QT上位机接收并显示当前采集的AD数据;板载PCIE为8 Lane的PCIE2.0;单Lane线速率配置为5GT/s;由此形成AD7606+XDMA+PCIE+QT的高端架构;该工程适用于PCIE接口的AD数据采集卡应用;

工程源码7

开发板FPGA型号为Xilinx–>Kintex7–35T–xc7k325tffg900-2;输入源为AD数据源,我用到的是示波器,用示波器产生一个正弦波,然后示波器信号接入AD7606转接板;AD7606输出模式为并行模式;FPGA端用纯verilog代码设计了AD7606驱动,该驱动配置AD7606并采集AD数据;AD7606在驱动的加持下将模拟信号转换为数字信号后传给FPGA;然后使用本博主常用的FDMA数据缓存架构将采集到的AD7606数据进行缓存缓存;缓存介质为FPGA板载的DDR3;本设计为选取AD7606全部8通道的其中2个通道进行缓存,缓存4096个点后就发起一次用户中断给XDMA,XDMA收到用户中断后通知QT上位机发起一次XDMA读数据操作,XDMA再从DDR中读取一帧视频并通过PCIE总线发送给QT上位机,QT上位机接收并显示当前采集的AD数据;板载PCIE为8 Lane的PCIE2.0;单Lane线速率配置为5GT/s;由此形成AD7606+XDMA+PCIE+QT的高端架构;该工程适用于PCIE接口的AD数据采集卡应用;

工程源码8

开发板FPGA型号为Xilinx–>Kintex7–35T–xc7k325tffg900-2;输入源为AD数据源,我用到的是示波器,用示波器产生一个正弦波,然后示波器信号接入AD7606转接板;AD7606输出模式为并行模式;FPGA端用纯verilog代码设计了AD7606驱动,该驱动配置AD7606并采集AD数据;AD7606在驱动的加持下将模拟信号转换为数字信号后传给FPGA;然后使用本博主常用的FDMA数据缓存架构将采集到的AD7606数据进行缓存缓存;缓存介质为FPGA板载的BRAM;本设计为选取AD7606全部8通道的其中2个通道进行缓存,缓存4096个点后就发起一次用户中断给XDMA,XDMA收到用户中断后通知QT上位机发起一次XDMA读数据操作,XDMA再从DDR中读取一帧视频并通过PCIE总线发送给QT上位机,QT上位机接收并显示当前采集的AD数据;板载PCIE为8 Lane的PCIE2.0;单Lane线速率配置为5GT/s;由此形成AD7606+XDMA+PCIE+QT的高端架构;该工程适用于PCIE接口的AD数据采集卡应用;

本文详细描述了FPGA基于XDMA中断模式实现实现AD7606数据采集转转PCIE传输的设计方案,工程代码可综合编译上板调试,可直接项目移植,适用于在校学生、研究生项目开发,也适用于在职工程师做项目开发,可应用于医疗、军工等行业的高速接口领域;
提供完整的、跑通的工程源码和技术支持;
工程源码和技术支持的获取方式放在了文章末尾,请耐心看到最后;

免责声明

本工程及其源码即有自己写的一部分,也有网络公开渠道获取的一部分(包括CSDN、Xilinx官网、Altera官网等等),若大佬们觉得有所冒犯,请私信批评教育;基于此,本工程及其源码仅限于读者或粉丝个人学习和研究,禁止用于商业用途,若由于读者或粉丝自身原因用于商业用途所导致的法律问题,与本博客及博主无关,请谨慎使用。。。

2、相关方案推荐

我已有的PCIE方案

我的主页有PCIE通信专栏,该专栏基于XDMA的轮询模式实现与QT上位机的数据交互,既有基于RIFFA实现的PCIE方案,也有基于XDMA实现的PCIE方案;既有简单的数据交互、测速,也有应用级别的图像采集传输,以下是专栏地址:
点击直接前往
此外,我的主页有中断模式的PCIE通信专栏,该专栏基于XDMA的中断模式实现与QT上位机的数据交互,以下是专栏地址:
点击直接前往
此外,还有基于RIFFA架构的PCIE通信专栏,以下是专栏地址:
点击直接前往

3、PCIE基础知识扫描

PCIe 总线架构与以太网的 OSI 模型类似,是一种分层协议架构,分为事务层(Transaction Layer)、数据链路层(Data Link Layer) 和物理层(Physical Layer)。这些层中的每一层都分为两部分:一部分处理出站(要发送的)信息,另一部分处理入站(接收的)信息,如下图:
在这里插入图片描述
事务层
事务层的主要责任是事务层包 TLP(Transaction Layer Packet)的组装和拆卸。事务层接收来自 PCIe 设备核心层的数据,并将其封装为 TLP。TLP 用于传达事务,例如读取和写入,以及确定事件的类型。事务层还负责管理 TLP 的基于信用的流控制。每个需要响应数据包的请求数据包都作为拆分事务实现。每个数据包都有一个唯一标识符,该标识符使响应数据包可以定向到正确的始发者。数据包格式支持不同形式的寻址,具体取决于事务的类型(内存、I/O、配置和消息)。数据包可能还具有诸如 No Snoop、Relaxed Ordering 和基于 ID 的排序(IDO)之类的属性。事务层支持四个地址空间:包括三个 PCI 地址空间(内存、I/O 和配置)并添加消息空间。该规范使用消息空间来支持所有先前 PCI 的边带信号,例如中断、电源管理请求等,作为带内消息事务。

数据链路层
数据链路层充当事务层和物理层之间的中间阶段。数据链路层的主要职责包括链路管理和数据完整性,包括错误检测和错误纠正。数据链路层的发送方接受事务层组装的 TLP,计算并应用数据保护代码和 TLP序列号,以及将它们提交给物理层以在链路上传输。接收数据链路层负责检查接收到的 TLP 的完整性,并将它们提交给事务层以进行进一步处理。在检测到 TLP 错误时,此层负责请求重发 TLP,直到正确接收信息或确定链路失败为止。数据链路层还生成并使用用于链路管理功能的数据包。为了将这些数据包与事务层(TLP)使用的数据包区分开,当指代在数据链路层生成和使用的数据包时,将使用术语“数据链路层数据包(DLLP)”。

物理层
PCIe 总线的物理层为 PCIe 设备间的数据通信提供传送介质,为数据传送提供可靠的物理环境。物理层包括用于接口操作的所有电路,包括驱动器和输入缓冲器、并行至串行和串行至并行转换、PLL 和阻抗匹配电路。它还包括与接口初始化和维护有关的逻辑功能。物理层以实现特定的格式与数据链路层交换信息。该层负责将从数据链路层接收的信息转换为适当的序列化格式,并以与连接到链路另一端的设备兼容的频率和通道宽度在 PCI Express 链路上传输该信息。物理层是 PCIe 体系结构最重要,也是最难以实现的组成部分(该层对用户透明,开发 PCIe 程序时无需关心)。PCIe 总线的物理层定义了 LTSSM (Link Training and Status State Machine)状态机,PCIe 链路使用该状态机管理链路状态,并进行链路训练、链路恢复和电源管理。PCIe 总线使用端到端的连接方式,在一条PCIe 链路的两端只能各连接一个设备,这两个设备互为数据发送端和数据接收端。由于 PCIe 是支持全双工通信的,所以发送端和接收端中都含有TX (发送逻辑) 和RX (接收逻辑)。在PCIe 总线的物理链路的一个数据通路(Lane) 中,有两组差分信号,共4 根信号线组成。其中发送端的TX 与接收端的RX 使用一组差分信号连接,该链路也被称为发送端的发送链路,也是接收端的接收链路;而发送端的RX 与接收端的TX 使用另一组差分信号连接,该链路也被称为发送端的接收链路,也是接收端的发送链路。一个PCIe 链路可以由多个Lane 组成。目前PCIe 链路可以支持1、2、4、8、12、16 和32 个Lane,即×1、×2、×4、×8、×12、×16 和×32 宽度的PCIe 链路。每一个Lane 上使用的总线频率与PCIe 总线使用的版本相关。

4、工程详细设计方案

工程设计原理框图

工程详细设计方案框图如下:
在这里插入图片描述

AD模拟数据输入设备

我用到的是示波器作为输入,你也可以用高精度的开关电源作为输入,或者其他;示波器输出如下:
在这里插入图片描述

AD7606数据手册解读

AD7606英文原版数据手册只有37页,但真正看懂的兄弟却很少,本博主提供中文版数据手册,下面解读一下这个手册:
DAQ7606 是 16 位 8 通道同步采样模数数据采集系统(DAS)。AD7606 内置模拟输入箝位保护、二阶抗混叠滤波器、跟踪保持放大器、16 位电荷再分配逐次逼近型 ADC、灵活的数字滤波器、2.5V 基准电压源、基准电压缓冲以及高速串行和并行接口。AD7606 采用 5V 单电源供电,可以处理±10V 和±5V 真双极性输入信号,同时所有通道均能以高达 200 kSPS 的吞吐速率采样。输入箝位保护电路可以耐受最高达±16.5V 的电压。无论以何种采样频率工作,AD7606 的模拟输入阻抗均为 1 MΩ。它采用单电源工作方式,具有片内滤波和高输入阻抗,因此无需驱动运算放大器和外部双极性电源。AD7606 抗混叠滤波器的 3 dB 截止频率为 22 kHz;当采样速率为 200 ksps 时,它具有 40 dB 抗混叠抑制特性。灵活的数字滤波器采用引脚驱动,可以改善信噪比(SNR),并降低 3 dB 带宽。
写了这么多你看懂了吗?我猜你应该是云里雾里,下面举例说人话,让你听得懂:
AD7606芯片框图如下:
在这里插入图片描述
红线即是信号输出输出的数据通路;

AD7606输入信号采集范围

AD7606可以处理±10V 和±5V 真双极性输入信号,即输入信号可以是±10V 和±5V,由RANGE引脚上下拉决定;
下拉处理±5V 信号;
上拉处理±10V 信号;
一旦选择了输入信号范围,就别乱给信号源了,否则烧板子了。。。
原文如下:
在这里插入图片描述

AD7606输出模式选择

红线以通道1为例:
输入数据位单端模拟数据,进过复杂的转换后可输出串行数字信号或者并行数据信号;
如果你的板子设计引脚资源有限,则选择串行输出;串行输出的优点是节约IO,缺点是采集时序复杂些;
如果你的板子设计引脚足够多,则选择并行输出,并行输出数据线占用16个IO口,并行输出的优点是采集时序简单,缺点是费IO;可自行选择;
输出模式选择通过PAR/SER/BYTE SEL引脚的上下拉决定;
上拉选择串行输出;
下拉选择并行输出;
具体的时序细节放在后面的章节;
原文如下:
在这里插入图片描述

AD7606过采样率设置

过采样率设置由OS的三个引脚上下拉决定,可以固定用电阻上下拉,这种模式就定死了,除非飞线,也可以用FPGA引脚给高低电平配置,具体配置模式如下图:
在这里插入图片描述
作为FPGA开发者,需要知道这些就行了,具体的时序细节放在后面的章节;

AD7606串行输出采集

AD7606串行采集时钟的范围要求如下:
在这里插入图片描述
这里我们选择16.666MHz时钟,不高也不低;
系统参考时钟选择100M,那个1个时钟周期就是1000÷100=10ns;
采集时钟是16.666M,那个1个时钟周期就是1000÷16.666=60ns;
记住这两个时钟周期,很重要;
串行输出流程时序图如下:
在这里插入图片描述
这张图采用边转换边读取的方式,还有转换完成后再读取的方式,既然可以边转换边读取,为何还要等转换完成后再读取呢?所以我们直接用这种方式。并行采集使用的则是转换完成后再读取的方式。
第一步:

拉高RESET引脚至少至少50ns,数据手册规定如下:
在这里插入图片描述
第二步:

拉低CONVSTA或者CONVSTB持续最多0.5ms(500ns),注意这里是最多,所以在代码里只需一个参考时钟周期足以,比如你用的100M,一个参考时钟周期就是10ns,当然,CONVSTA和CONVSTB也可同时拉低,这样就是8个通道同时采集,时间由数据手册得知,如下:
在这里插入图片描述
CONVSTA开启V1-V4通道的转换;
CONVSTB开启V5-V8通道的转换;
原文如下:
在这里插入图片描述
第三步:

等待BUSY为高后,拉低CS,这个BUSY是AD7606输出给用户的,表征AD转换正在进行,他有一个最大时间,我们一定要满足他的最大时间,不然人家还没转换完你就结束采集了,岂不唧唧了;那么,CS在什么时刻拉低呢?既然前面我们已经选择了边转换边读取的方式,所以在BUSY拉高的期间CS拉低,数据手册最大推荐4.15us,代码里直接设置5ms,由数据手册得知,如下:
在这里插入图片描述
流程看完了,来看具体的采集时序:
在这里插入图片描述
采集时序如下:
首先用户拉低CS,并给出SCLK到AD7606,AD7606在CS为低期间,在SCLK的上升沿输出数据(但根据时序图,我感觉是SCLK高电平期间输出的),一个通道一次转换后输出16位采样数据;
既然AD7606是在SCLK上升沿输出,那么FPGA就应该在SCLK下降沿采集(或者低电平采集);
AD7606有8个模拟输入通道,串行输出模式下只有两个数字输出通道,每个输入通道输出16位采样数据;
DOUTA对应CH1、CH2、CH3、CH4四个输出通道;
DOUTB对应CH5、CH6、CH7、CH8四个输出通道;
因为每个输入通道输出16位采样数据,需要16个SCLK周期,所以4个输入通道输出16位采样数据,需要64个SCLK周期;那个我们需要一个计数器,计数到64时输出64位的采集数据,呢么采集到的每个通道数据对应如下:
wire [15:0] ad_ch1 = ad_out_a[63:48];
wire [15:0] ad_ch2 = ad_out_a[47:32];
wire [15:0] ad_ch3 = ad_out_a[31:16];
wire [15:0] ad_ch4 = ad_out_a[15: 0];
wire [15:0] ad_ch5 = ad_out_b[63:48];
wire [15:0] ad_ch6 = ad_out_b[47:32];
wire [15:0] ad_ch7 = ad_out_b[31:16];
wire [15:0] ad_ch8 = ad_out_b[15: 0];
串行采集代码顶层接口代码如下:

module helai_ad7606_ser#(
	parameter	SYS_CLK = 100_000_000,	//系统时钟
	parameter	SPI_CLK = 16_666_666	//AD采集时钟 
)
(
	input          i_sys_clk   ,	//系统时钟            
	input          i_rstn      ,	//系统复位,低有效
	input          i_ad_cha    ,	//AD7606串行输出通道A
	input          i_ad_chb    ,	//AD7606串行输出通道B	
	input          i_ad_busy   ,	//输入BUSY
	output [2:0]   o_ad_os     ,	//输出采样率配置
	output    	   o_ad_cs     ,	//输出片选
	output reg     o_ad_sclk   ,	//输出采样时钟
	output         o_ad_rst    ,	//输出复位
	output    	   o_ad_convsta,	//输出开启V1-V4通道采集
	output    	   o_ad_convstb,	//输出开启V5-V8通道采集
	output         o_ad_range  ,	//输入信号范围配置
	output [15:0]  o_ad_ch1    ,	//输出通道1
	output [15:0]  o_ad_ch2    ,	//输出通道2
	output [15:0]  o_ad_ch3    ,	//输出通道3
	output [15:0]  o_ad_ch4    ,	//输出通道4
	output [15:0]  o_ad_ch5    ,	//输出通道5
	output [15:0]  o_ad_ch6    ,	//输出通道6
	output [15:0]  o_ad_ch7    ,	//输出通道7
	output [15:0]  o_ad_ch8    ,	//输出通道8
	output 		   o_ad_rxdone 		//输出数据有效信号,高有效
 );

AD7606串行输出采集仿真

在AD7606串行输出版本工程中,本博主提供了仿真代码,该仿真旨在验证AD7606数据采集模块的正确性,包括AD7606数据采集模块、AD7606仿真模型、仿真代码三部分组成,如下图:
在这里插入图片描述
仿真如下:
在这里插入图片描述
你可以修改仿真代码,使仿真时间边长,以便采集更多数据;

AD7606并行输出采集

并行采集时序,由于官方画的图太繁琐,我直接重画了一个图来表示,如下:
在这里插入图片描述
第一步:拉高RESET引脚至少至少50ns,和串行采集一样;
第二步:拉低CONVSTA或者CONVSTB持续最多0.5ms(500ns),和串行采集一样;
第三步:等待转换完成再读取数据,即采用转换完成后再读取的方式;
第四步:拉低CS片选信号;
第五步:拉低RD信号,在RD和CS同时为低时即可依次读取V1-V8通道的数据;
相应的时间问题也是重要的,具体查看手册;
并行采集代码顶层接口代码如下:

module helai_ad7606_par(
	input                        clk          ,	//系统时钟,100M	
	input                        rst_n        ,	//系统复位,低有效
	input [15:0]                 ad_data      ,	//输入并行数据
	input                        ad_busy      ,	//输入BUSY
	input                        first_data   ,	//未用到此信号
	output [2:0]                 ad_os        ,	//输出采样率配置
	output reg                   ad_cs        ,	//输出片选
	output reg                   ad_rd        ,	//输出读数据
	output reg                   ad_reset     ,	//输出复位
	output reg                   ad_convstab  ,	//输出开启V1-V8通道采集
	output                       ad_data_valid,	//输出数据有效信号,高有效
	output reg [15:0]            ad_ch1       ,	//输出通道1
	output reg [15:0]            ad_ch2       ,	//输出通道2
	output reg [15:0]            ad_ch3       ,	//输出通道3
	output reg [15:0]            ad_ch4       ,	//输出通道4
	output reg [15:0]            ad_ch5       ,	//输出通道5
	output reg [15:0]            ad_ch6       ,	//输出通道6
	output reg [15:0]            ad_ch7       ,	//输出通道7
	output reg [15:0]            ad_ch8       	//输出通道8
);

FDMA AD数据缓存

FDMA AD数据缓存架构实现的功能是将采集到的AD数据缓存到板载DDR3或者BRAM中,由于调用了Xilinx官方的MIG作为DDR控制器,所以FDMA AD数据缓存架构就是实现用户数据到MIG或者BRAM的桥接作用;架构如下:
在这里插入图片描述
FDMA AD数据缓存架构由FDMA控制器+FDMA组成;FDMA实际上就是一个AXI4-FULL总线主设备,与MIG或者BRAM对接,MIG配置为AXI4-FULL接口;FDMA控制器实际上就是一个数据读写逻辑,以写AD数据为例,假设一帧AD数据的大小为M×N,其中M代表一包AD数据的大小,N代表有多少包数据;FDMA控制器每次写入一包AD数据,即每次向DDR3或者BRAM中写入M个点,写N次即可完成1帧一帧AD数据的缓存,本设计只用到了FDMA控制器的写功能,FDMA控制器IP配置如下:
在这里插入图片描述
FDMA AD数据缓存架构在Block Design中如下:
在这里插入图片描述

XDMA配置及使用

根据Xilinx官方手册,XDMA框图如下:
在这里插入图片描述
由图可知,XDMA封装了Integrated Block for PCI Express IP,不仅完成了事务层的组包解包,还添加了完整的 DMA 引擎;
XDMA 一般情况下使用AXI4 接口,AXI4 接口可以加入到系统总线互联,适用于大数据量异步传输,而且通常情况下使用 XDMA 都会使用到 BRAM 或 DDR 内存;AXI4-Stream 接口适用于低延迟数据流传输。XDMA 允许在主机内存和 DMA 子系统之间移动数据。它通过对包含有关要传输的数据的源、目标和数量的信息的“描述符”进行操作来实现此目的。这些直接内存传输既可以用于主机到卡(Host to Card,H2C)的传输,也可以用与卡到主机(Card to Host,C2H)的传输。可以将 DMA 配置为由所有通道共享一个 AXI4 Master 接口,或者为每个启用的通道提供一个 AXI4-Stream 接口。内存传输是基于每个通道的描述符链接列表指定的,DMA 从主机内存和进程中获取这些链接列表。诸如描述符完成和错误之类的事件通过中断来发出信号。XDMA 还提供多达 16 条用户中断线,这些中断线会向主机生成中断。本设计需要配置为中断模式;如下图:
在这里插入图片描述
XDMA详情参考《AXI Bridge for PCI Express Gen3 Subsystem Product Guide(PG194)》;XDMA在Block Design中如下:
在这里插入图片描述

XDMA中断模块

XDMA中断模块和XDMA IP配合使用,XDMA中断模块主要执行两个任务,一是获取XDMA的状态,输出用户中断使能信号,以指示用户此时可以发起中断,该任务通过AXI_Lite接口与XDMA连接,其从机地址受PC端软件控制;二是转发用户中断给XDMA,当用户侧检测到XDMA处于可接受中断状态时,用户逻辑可以发起中断,XDMA中断模块将此中断转发给XDMA IP;将模块直接拖入Block Design中,显示如下:
在这里插入图片描述

用户中断发起逻辑

本设计为选取AD7606全部8通道的其中2个通道进行缓存,缓存4096个点后就发起一次用户中断给XDMA,XDMA收到用户中断后通知QT上位机发起一次XDMA读数据操作,XDMA再从DDR中读取一帧视频并通过PCIE总线发送给QT上位机,QT上位机接收并显示当前采集的AD数据;核心代码如下:
在这里插入图片描述

Windows版本XDMA驱动安装

提供Windows和Linux系统驱动,本章节介绍Windows下XDMA驱动安装;
在这里插入图片描述
Windows下驱动安装步骤如下:友情提示,Windows下驱动秩序安装一次即可;

第一步:使系统禁用签名并进入测试模式,方法如下:
在这里插入图片描述
也可百度其他方法实现上述目的,完成后电脑屏幕右下角应有如下显示:
在这里插入图片描述
第二步:定位到驱动目录下,提供Windows7和Windows10两个版本驱动,由于我的电脑选择Windows10,如下:
在这里插入图片描述
单击鼠标右键安装即可,如下:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
第三步:下载FPGA工程bit到FPGA开发板,然后重启电脑,打开我的电脑–>管理–>设备管理器,应看到如下设备:
在这里插入图片描述

Linux版本XDMA驱动安装

提供Windows和Linux系统驱动,本章节介绍Linux下XDMA驱动安装;
在这里插入图片描述
Linux下驱动安装步骤如下:友情提示,Linux下,每次下载FPGA bit后都需要重启电脑才能安装驱动;

进入到Linux驱动目录下,一次执行以下两条指令即可安装,如下:
• 驱动编译终端指令:make -j8
•驱动安装终端指令:sudo insmod xdma.ko
在这里插入图片描述

QT上位机

提供Linux和Win10版本的QT上位机,位置如下:
在这里插入图片描述
以Win10版本为例,源码位置如下:
在这里插入图片描述
以Win10版本下,可以点击已经编译好的QT软件直接运行,位置如下:
在这里插入图片描述
Linux下必须先安装QT软件,然后打开QT工程才能运行,如下:
在这里插入图片描述
QT上位机运行效果如下:
在这里插入图片描述

工程源码架构

以工程源码1为例,工程Block Design设计如下:
在这里插入图片描述
以工程源码1为例,综合后的工程源码架构如下:
在这里插入图片描述

Vivado工程注意事项

Vivado工程需要配合修改过的Xilinx官方XDMA驱动和QT上位机一起使用,所以Vivado工程必须做到以下几点:
1:XDMA中的AXI4_Lite基地址必须设为0x44A00000,这是XDMA驱动修改的规定,感兴趣的可以去看驱动源码,配置如下;
在这里插入图片描述
2:MIG的DDR基地址必须从0x00000000开始,这是QT上位机代码的规定,感兴趣的可以去看QT源码,配置如下;
在这里插入图片描述

PCIE上板调试注意事项

1:必须先安装本博提供的XDMA驱动,详情请参考第4章节的《XDMA驱动及其安装》,Windows版本驱动只需安装一次;
2:Windows版本下载FPGA工程bit后需要重启电脑,电脑才能识别到XDMA驱动;程序固化后也需要重启电脑;Linux版本每次载FPGA工程bit后都需要重启电脑,都需要安装XDMA驱动;
3:FPGA板卡插在主机上后一般不需要额外供电,如果你的板子元器件较多功耗较大,则需要额外供电,详情咨询开发板厂家,当然,找我买板子的客户可以直接问我;
4:PCIE调试需要电脑主机,但笔记本电脑理论上也可以外接出来PCIE,详情百度自行搜索一下,电脑主机PCIE插槽不方便操作时可以使用延长线接出来,某宝有卖;

5、vivado工程源码1详解–>Artix7-100T,AD7606串行模式–DDR3缓存

开发板FPGA型号:Xilinx–Artix7–xc7a100tfgg484-2;
FPGA开发环境:Vivado2019.1;
QT开发环境:VS2015 + Qt 5.12.10;
输入:示波器产生正弦波送AD7606转接板;
输出:PCIE2.0;
AD7606输出模式:串行模式;
图像缓存方案:FDMA图像缓存;
图像缓存介质:板载DDR3;
PCIE底层方案:Xilinx XDMA;
PCIE详情:PCIE2.0版本,X1,5GT/s单lane线速率;
实现功能:FPGA实现AD7606数据采集转转PCIE传输;
工程作用:此工程目的是让读者掌握FPGA实现AD7606数据采集转转PCIE传输的设计能力,以便能够移植和设计自己的项目;
工程Block Design和工程代码架构请参考第4章节的《工程源码架构》小节内容;
工程的资源消耗和功耗如下:
在这里插入图片描述

6、vivado工程源码2详解–>Artix7-100T,AD7606串行模式–BRAM缓存

开发板FPGA型号:Xilinx–Artix7–xc7a100tfgg484-2;
FPGA开发环境:Vivado2019.1;
QT开发环境:VS2015 + Qt 5.12.10;
输入:示波器产生正弦波送AD7606转接板;
输出:PCIE2.0;
AD7606输出模式:串行模式;
图像缓存方案:FDMA图像缓存;
图像缓存介质:FPGA内部BRAM;
PCIE底层方案:Xilinx XDMA;
PCIE详情:PCIE2.0版本,X1,5GT/s单lane线速率;
实现功能:FPGA实现AD7606数据采集转转PCIE传输;
工程作用:此工程目的是让读者掌握FPGA实现AD7606数据采集转转PCIE传输的设计能力,以便能够移植和设计自己的项目;
工程Block Design和工程代码架构请参考第4章节的《工程源码架构》小节内容;
工程的资源消耗和功耗如下:
在这里插入图片描述

7、vivado工程源码3详解–>Artix7-100T,AD7606并行模式–DDR3缓存

开发板FPGA型号:Xilinx–Artix7–xc7a100tfgg484-2;
FPGA开发环境:Vivado2019.1;
QT开发环境:VS2015 + Qt 5.12.10;
输入:示波器产生正弦波送AD7606转接板;
输出:PCIE2.0;
AD7606输出模式:并行模式;
图像缓存方案:FDMA图像缓存;
图像缓存介质:板载DDR3;
PCIE底层方案:Xilinx XDMA;
PCIE详情:PCIE2.0版本,X4,5GT/s单lane线速率;
实现功能:FPGA实现AD7606数据采集转转PCIE传输;
工程作用:此工程目的是让读者掌握FPGA实现AD7606数据采集转转PCIE传输的设计能力,以便能够移植和设计自己的项目;
工程Block Design和工程代码架构请参考第4章节的《工程源码架构》小节内容;
工程的资源消耗和功耗如下:
在这里插入图片描述

8、vivado工程源码4详解–>Artix7-100T,AD7606并行模式–BRAM缓存

开发板FPGA型号:Xilinx–Artix7–xc7a100tfgg484-2;
FPGA开发环境:Vivado2019.1;
QT开发环境:VS2015 + Qt 5.12.10;
输入:示波器产生正弦波送AD7606转接板;
输出:PCIE2.0;
AD7606输出模式:并行模式;
图像缓存方案:FDMA图像缓存;
图像缓存介质:FPGA内部BRAM;
PCIE底层方案:Xilinx XDMA;
PCIE详情:PCIE2.0版本,X4,5GT/s单lane线速率;
实现功能:FPGA实现AD7606数据采集转转PCIE传输;
工程作用:此工程目的是让读者掌握FPGA实现AD7606数据采集转转PCIE传输的设计能力,以便能够移植和设计自己的项目;
工程Block Design和工程代码架构请参考第4章节的《工程源码架构》小节内容;
工程的资源消耗和功耗如下:
在这里插入图片描述

9、vivado工程源码5详解–>Kintex7-325T,AD7606串行模式–DDR3缓存

开发板FPGA型号:Xilinx–>Kintex7–35T–xc7k325tffg900-2;
FPGA开发环境:Vivado2019.1;
QT开发环境:VS2015 + Qt 5.12.10;
输入:示波器产生正弦波送AD7606转接板;
输出:PCIE2.0;
AD7606输出模式:串行模式;
图像缓存方案:FDMA图像缓存;
图像缓存介质:板载DDR3;
PCIE底层方案:Xilinx XDMA;
PCIE详情:PCIE2.0版本,X8,5GT/s单lane线速率;
实现功能:FPGA实现AD7606数据采集转转PCIE传输;
工程作用:此工程目的是让读者掌握FPGA实现AD7606数据采集转转PCIE传输的设计能力,以便能够移植和设计自己的项目;
工程Block Design和工程代码架构请参考第4章节的《工程源码架构》小节内容;
工程的资源消耗和功耗如下:
在这里插入图片描述

10、vivado工程源码6详解–>Kintex7-325T,AD7606串行模式–BRAM缓存

开发板FPGA型号:Xilinx–>Kintex7–35T–xc7k325tffg900-2;
FPGA开发环境:Vivado2019.1;
QT开发环境:VS2015 + Qt 5.12.10;
输入:示波器产生正弦波送AD7606转接板;
输出:PCIE2.0;
AD7606输出模式:串行模式;
图像缓存方案:FDMA图像缓存;
图像缓存介质:FPGA内部BRAM;
PCIE底层方案:Xilinx XDMA;
PCIE详情:PCIE2.0版本,X8,5GT/s单lane线速率;
实现功能:FPGA实现AD7606数据采集转转PCIE传输;
工程作用:此工程目的是让读者掌握FPGA实现AD7606数据采集转转PCIE传输的设计能力,以便能够移植和设计自己的项目;
工程Block Design和工程代码架构请参考第4章节的《工程源码架构》小节内容;
工程的资源消耗和功耗如下:
在这里插入图片描述

11、vivado工程源码7详解–>Kintex7-325T,AD7606并行模式–DDR3缓存

开发板FPGA型号:Xilinx–>Kintex7–35T–xc7k325tffg900-2;
FPGA开发环境:Vivado2019.1;
QT开发环境:VS2015 + Qt 5.12.10;
输入:示波器产生正弦波送AD7606转接板;
输出:PCIE2.0;
AD7606输出模式:并行模式;
图像缓存方案:FDMA图像缓存;
图像缓存介质:板载DDR3;
PCIE底层方案:Xilinx XDMA;
PCIE详情:PCIE2.0版本,X8,5GT/s单lane线速率;
实现功能:FPGA实现AD7606数据采集转转PCIE传输;
工程作用:此工程目的是让读者掌握FPGA实现AD7606数据采集转转PCIE传输的设计能力,以便能够移植和设计自己的项目;
工程Block Design和工程代码架构请参考第4章节的《工程源码架构》小节内容;
工程的资源消耗和功耗如下:
在这里插入图片描述

12、vivado工程源码8详解–>Kintex7-325T,AD7606并行模式–BRAM缓存

开发板FPGA型号:Xilinx–>Kintex7–35T–xc7k325tffg900-2;
FPGA开发环境:Vivado2019.1;
QT开发环境:VS2015 + Qt 5.12.10;
输入:示波器产生正弦波送AD7606转接板;
输出:PCIE2.0;
AD7606输出模式:并行模式;
图像缓存方案:FDMA图像缓存;
图像缓存介质:FPGA内部BRAM;
PCIE底层方案:Xilinx XDMA;
PCIE详情:PCIE2.0版本,X8,5GT/s单lane线速率;
实现功能:FPGA实现AD7606数据采集转转PCIE传输;
工程作用:此工程目的是让读者掌握FPGA实现AD7606数据采集转转PCIE传输的设计能力,以便能够移植和设计自己的项目;
工程Block Design和工程代码架构请参考第4章节的《工程源码架构》小节内容;
工程的资源消耗和功耗如下:
在这里插入图片描述

13、工程移植说明

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软核;

14、上板调试验证

准备工作

需要准备的器材如下:
示波器等模拟数据输入设备;
AD7606转接板,板载AD7606芯片的除外;
FPGA开发板,没有开发板可以找本博提供;
带PCIE卡槽的电脑主机;
我的开发板了连接如下:
在这里插入图片描述

AD7606数据采集转PCIE输出效果演示

AD7606数据采集转PCIE输出效果演示如下:
在这里插入图片描述

15、福利:工程代码的获取

福利:工程代码的获取
代码太大,无法邮箱发送,以某度网盘链接方式发送,
资料获取方式:私,或者文章末尾的V名片。
网盘资料如下:
在这里插入图片描述
此外,有很多朋友给本博主提了很多意见和建议,希望能丰富服务内容和选项,因为不同朋友的需求不一样,所以本博主还提供以下服务:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

9527华安

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值