XILINX 7系列XDMA使用_IP核介绍以及工程搭建

文章目录

  • 一、XDMA IP核
    • 1.1、接口说明
    • 1.2、配置页说明
  • 二、XDMA工程搭建
    • 2.1、BD搭建
    • 2.2 Linux下XDMA驱动安装
    • 2.3 Linux下使用XDMA进行数据传输

一、XDMA IP核

在这里插入图片描述

1.1、接口说明

sys_clk:主机给PCIE提供的时钟信号,通过原理图查看
sys_rst_n:主机提供的冷复位,原理图查看
usr_irq_req:用户中断请求
M_AXI:主机通过该AXI接口访问FPGA的存储空间,一般接DDR
M_AXI_LITE:用户自己拓展的BAR空间
pcie_mgt:PCIE的GT收发器通道
user_link_up:拉高表示FPGA与主机连接正常
axi_aclk:AXI接口时钟
axi_aresetn:AXI接口复位
usr_irq_ack:用户中断请求的响应,表示主机接收到了中断请求
msi_enable:表示主机支持MSI中断
msi_vector_width:支持的MSI中断向量个数

1.2、配置页说明

在这里插入图片描述
PCIE Block Location:PCIe 的物理位置,根据原理图的位置选择,本实验为ZYNQ7100,PCIE位置为X0Y0,由于是X8,占俩个GT BANK,但这好像只能选一个。
Lane Width:根据板卡实际选择,我这里是PCIE2.0 X 8
Link Speed: PCIe 最大的传输速率,PCIe-1.0 的最大传输速率为 2.5GT/S,PCIe-2.0 的最大传输速率为 5GT/S。选择为 5GT/S。
reference clock:参考时钟频率的选择,常用 100MHz。
剩余都是AXI的一些配置

在这里插入图片描述
第二页为PCIe 配置空间中的基础信息的配置。如说厂商 ID,设备 ID,设备类型等。这些信息都是存于 PCIe 的配置空间中。

在这里插入图片描述
第三页中主要配置 BAR 的信息与DMA Bypass 的信息。

在这里插入图片描述
中断信息配置,后续说明

在这里插入图片描述
传输通道数选择

二、XDMA工程搭建

2.1、BD搭建

在这里插入图片描述
添加DDR和一个AXI_LITE从机接口用于测试主机通过XDMA读写FPGA存储空间,并且添加了一些ILA进行上板观察。
注意以下几点:

  1. 在BD当中进行地址分配时,AXI_LITE的基地址要与XDMA当中填写一致。
  2. DDR单独给一个复位信号,不要用PCIE的冷复位信号
  3. 有些板卡的PCIE LANE 线序是反的,得在IP核的XDC文件当中修改一下

2.2 Linux下XDMA驱动安装

我使用的Linux系统为ubuntu22,所以官方驱动要改一下才能用,网上有一个可以用于22的:https://github.com/MischaBaars/dma_ip_drivers
至于其他测试都很简单,关于驱动的东西我个人了解较少,后续再慢慢学习吧。

测试流程:

  1. 下载bit流到板卡

  2. 连接好主机和FPGA的PCIE,保持FPGA上电状态,重启电脑
    在终端输入lspci查看PCIE设备,出现以下内容说明成功识别板卡
    在这里插入图片描述

  3. 编译驱动

ubuntu22:~/xdma_driver/dma_ip_drivers/XDMA/linux-kernel/xdma$ make all
  1. 安装驱动
~/xdma_driver/dma_ip_drivers/XDMA/linux-kernel/tests$ ./load_driver.sh
  1. 驱动测试
~/xdma_driver/dma_ip_drivers/XDMA/linux-kernel/tests$ ./run_test.sh

出现以下内容则说明驱动安装成功。
在这里插入图片描述

2.3 Linux下使用XDMA进行数据传输

  1. 寄存器读写
    使用/tool文件当中的reg_rw工具,输入./reg_rw -h查看使用方法
    在这里插入图片描述
    读写示例如下图:
    在这里插入图片描述
    注意:这个寄存器读写工具,是读写我们在设置IP核的时候自己添加的BAR0空间,也就是AXI_LITE接口,所以最大位宽为32,地址也不能超过我们设置的大小,下图是我设置的AXI_LITE地址大小:
    在这里插入图片描述
    可从0x000写到0xFFF,每次读的地址必须是4的整数倍,不然读出来是错的,最大写地址不可以超过0xFFF,如:

在这里插入图片描述

  1. 文件读写
    使用/tool文件当中的dma_to_device和dma_from_device工具,输入./dma_to_device -h可查看使用说明
    在这里插入图片描述
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/710024.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

宠物健康顾问系统的设计

管理员账户功能包括:系统首页,个人中心,顾问管理,用户管理,健康知识管理,管理员管理,论坛管理,公告管理 顾问账户功能包括:系统首页,个人中心,顾…

宝藏速成秘籍(3)选择排序法

一、前言 1.1、概念 选择排序法(Selection Sort)是一种简单直观的排序算法。它的基本思想是:每次从待排序的数组中选择最小(或最大)的元素,将其放在已排序部分的末尾,直到所有元素都排序完毕。…

资源分享—2021版乡级制图规范符号库

汇总整理超图平台软件相关的各类资源(包括但不限于符号库、地图模板、地理处理模型等),助力项目的高效制图、提高数据生产效率等业务。 本次分享新版国土空间规划【2021版乡级制图规范符号库】,提供SuperMap格式符号库下载。 符…

简单了解CPU的工作原理

目录 一、基本结构以及对应功能 (1)基本结构 (2)几个重要寄存器的详细介绍 操作码 (Opcode) 操作数 (Operands) 指令表 (Instruction Table) 第一个:程序计数器 (PC) 第二个:指令寄存器 (IR&#x…

头歌资源库(3)爬楼梯问题

一、 问题描述 二、算法思想 假设要爬上n阶楼梯,我们可以将问题分解为子问题:爬到第n-1阶楼梯的方法数加上爬到第n-2阶楼梯的方法数加上爬到第n-3阶楼梯的方法数。 设f(n)表示爬到第n阶楼梯的方法数,则有递推关系:f(n) f(n-1…

有声读物管理平台Booksonic-Air

老苏最近在听评书,所以想找个软件来管理和收听,找了一圈,感觉 Booksonic-Air 可能能满足老苏的需求。 什么是 Booksonic-Air ? Booksonic-Air 是一个用于流式传输有声读物的服务器,是原始 Booksonic 服务器的后继者。…

windows上运行arm32架构的安卓模拟器

说明 主要功能:在win10上研究和学习32位arm汇编指令的执行 环境如下 主机环境: windows10 目标模拟器环境:armeabi-v7a调试环境搭建 1、下载android studio [下载地址](https://developer.android.com/studio?hlzh-cn) ![在这里插入图片描述](https://img-blog…

RedHat9 | Mariadb数据库的配置与管理

一、实验环境 1、Mariadb数据库介绍 MariaDB数据库管理系统是一个开源的关系型数据库管理系统,与MySQL高度兼容,并提供了更多的功能和性能优化。 起源和背景 MariaDB是MySQL的一个分支,主要由开源社区维护。由MySQL的创始人Michael Widen…

【面试干货】Java集合类详解:List、Set、Queue、Map、Stack的特点与用法

【面试干货】Java集合类详解:List、Set、Queue、Map、Stack的特点与用法 1、Map1.1 特点1.2 用法1.3 常见的实现类 2、Set2.1 特点2.2 用法2.3 常见的实现类 3、List3.1 特点3.2 用法3.3 常见的实现类 4、Queue4.1 特点4.2 用法4.3 常见的实现类 5、Stack5.1 特点5.…

Springboot实现微信小程序登录功能

目录 一 什么是微信登录功能 二 实现微信登录功能的整体逻辑 三 微信登录功能实现步骤 一 什么是微信登录功能 微信小程序登录功能一般用于开发微信小程序的时候,我们需要使用微信授权登录我们的微信小程序,本篇博客就微信小程序实现微信授权登录以及s…

基于LangChain-Chatchat实现的RAG-本地知识库的问答应用[2]-简洁部署版

基于LangChain-Chatchat实现的RAG-本地知识库的问答应用[2]-简洁部署版 1.环境要求 1.1 软件要求 要顺利运行本代码,请按照以下系统要求进行配置 已经测试过的系统 Linux Ubuntu 22.04.5 kernel version 6.7其他系统可能出现系统兼容性问题。 最低要求 该要求仅针对标准模…

OpenStack入门体验及一键部署

OpenStack入门体验 技能目标: 了解云计算概念 了解OpenStack 了解OpenStack的构成 会OpenStack单机环境一键部署 从控制台认识OpenStack各项功能会 通过OpenStack控制台创建云主机 什么是云计算 云计算(cloudcomputing)是一种基于网络的超级计算模式&a…

Docker安装Nginx(各种错误版)

Docker安装-CSDN博客 安装启动Docker之后 docker run -d -p 81:81 --name nginx nginx 这样没有指定版本 docker run:启动一个新的容器。-d:以分离模式运行容器(后台运行)。-p 81:81:将主机的 81 端口映射到容器的 …

用Vue3和p5.js打造一个交互式数据可视化仪表盘

本文由ScriptEcho平台提供技术支持 项目地址:传送门 基于 Vue.js 集成 p5.js 实现交互式波形图 应用场景介绍 在数据可视化领域,波形图广泛应用于展示动态变化的数据,如声音信号、心跳曲线等。通过动态绘制波形图,用户可以直观…

网络标准架构--OSI七层、四层

OSI七层网络架构,以及实际使用的四层网络架构。

细说ARM MCU的串口发送数据的实现过程

目录 1、条件及工程配置 2、实现串口发送的库函数 3、修改whlie(1)中的代码 4、修改回调函数 5、下载运行 前面的文章介绍了用串口的接收中断来接收数据,本文介绍通过串口从MCU向外发送数据。 1、条件及工程配置 文章依赖的硬件及工程配置同本文作者的其他文…

热门开源项目推荐:智谱GLM-4-9B和ChatGLM3-6B

目录 热门开源项目推荐:智谱GLM-4-9B和ChatGLM3-6B 1.引言 1.1 开源文化简介 1.2 开源项目的重要性 1.3 博客目的和读者价值 2.什么是开源项目? 2.1 开源定义 2.2 开源许可证类型 2.3 开源社区的作用 3.为什么程序员应该关注开源项目&#xff…

javaWeb项目-ssm+jsp学生请假系统功能介绍

本项目源码:java-ssm-jsp学生请假系统源码说明文档资料资源-CSDN文库 项目关键技术 开发工具:IDEA 、Eclipse 编程语言: Java 数据库: MySQL5.7 框架:ssm、Springboot 前端:Vue、ElementUI 关键技术:springboot、SSM、vue、MYSQL…

HashMap底层源码分析

目录 一、知识点二、数据结构三、resize() 扩容方法四、putVal() 添加数据方法五、remove() 删除方法六、removeTreeNode() 退化链表方法 一、知识点 加载因子: HashMap 的默认的加载因子: 0.75,用来限定阈值(用于控制 HashMap 的饱和度) 阈值…

适合小白学习的项目1906java Web智慧食堂管理系统idea开发mysql数据库web结构java编程计算机网页源码servlet项目

一、源码特点 java Web智慧食堂管理系统是一套完善的信息管理系统,结合java 开发技术和bootstrap完成本系统,对理解JSP java编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。 前段主要技术 bootstra…