xilinx XDMA

一 . xdma简介

xdma 是 xilinx 提供的 Pcie 总线桥的IP核,类似于硬件的透传模块;该 ip 核主要作用是将pcie总线转换成axi总线,可以通过该模块直接操作 axi 总线上设备寄存器。模块最新好像可以支持 pcie x16 接口。当前介绍的只支持 x4。

二. 简单配置

2.1 Pcie 基础设置

分成两个部分,具体大致如下:

左侧 Pcie 总线 相关右侧 AXI 总线相关
MODEAXI 总线地址位宽
lane 宽度AXI 传输数据位宽
最大link速度dma 功能选择
Pcie参考时钟源AXI 从模块功能引脚使能

注意:其中DMA 功能选择:内存映射功能和流式传输功能;内存映射功能,即dma访问内存的方式间接获取数据,流式即dma直接访问设备的传输FIFO,从对列中直接拿数据。
在这里插入图片描述

2.2 Pcie 总线标准硬件协议设置

这里主要是配置
在这里插入图片描述

2.3 Pcie BAR 内存映射设置

该内存映射主要是axi总线映射到bar空间的地址,这样便可以通过pcie 直接操作bar空间的地址从而操作axi总线地址设备。
在这里插入图片描述

2.4 Pcie 总线中断功能配置

配置内容:

  1. 用户中断总线宽度个数,即表示该 ip 核最高支持的中断个数;
  2. 中断机制,该中断机制分成 INTx 和 MSI 两种方式;INTx 一种类型仅支持一个用户中断,当前模块 MSI 最多可支持 16 (32) 个用户中断;(INTx 传统中断(INTA、INTB、INTC、INTD),非MSI中断,PCI设备使用INTx中断请求的方式与电平触发类似,而 MSI/MSI-X 中断请求的方式与边沿触发方式类似,是通过直接写内存进行触发中断)
  3. MSI capability 若是选择了该项, MSI-X capability 就必须关闭;
    在这里插入图片描述

2.5 pcie 自带dma配置

  1. dma 通道配置,分成了读写通道配置 dma 的数量;
  2. Number of Request IDs for Read (Write) channe:每个通道允许最大读写通道个数;

在这里插入图片描述

三. 引脚接口介绍

主要介绍一下各个引脚的功能;
在这里插入图片描述

接口说明
sys_clkpcie 总线使用的时钟
sys_rst_npcie 上电复位
usr_irq_req用户子模块中断数量
M_AXIAXI 接口可通过 xdma 转换成 PCIe总线数据,速度较高,可用于控制或者数据传输
M_AXI_LITEAXI 接口可通过 xdma 转换成 PCIe总线数据,低速,主要用于控制
pcie_mgtpcie 连接的硬件接口
user_lnk_up用户连接之后的状态
axi_aclkaxi 总线时钟
axi_aresetnaxi 总线子模块片选
usr_irq_ack用户中断响应信号,即在处理完中断后该引脚会有一个电平,告知中断已经响应
msi_enablemsi 使能引脚
msi_vector_widthmsi 向量表宽度
xilliix pcie dma 驱动 (基于 xilnx xdma ip核 4.0 的WDF驱动) --- # XDMA Windows Driver This project is Xilinx's sample Windows driver for 'DMA/Bridge Subsystem for PCI Express v4.0' (XDMA) IP. *Please note that this driver and associated software are supplied to give a basic generic reference implementation only. Customers may have specific use-cases and/or requirements for which this driver is not suitable.* ### Dependencies * Target machine running Windows 7 or Windows 10 * Development machine running Windows 7 (or later) * Visual Studio 2015 (or later) installed on development machine * Windows Driver Kit (WDK) version 1703 (or later) installed on development machine ## Directory Structure ``` / |__ build/ - Generated directory containing build output binaries. |__ exe/ - Contains sample client application source code. | |__ simple_dma/ - Sample code for AXI-MM configured XDMA IP. | |__ streaming_dma/ - Sample code for AXI-ST configured XDMA IP. | |__ user_events/ - Sample code for access to user event interrupts. | |__ xdma_info/ - Utility application which prints out the XDMA core ip | | configuration. | |__ xdma_rw/ - Utility for reading/writing to/from xdma device nodes such | | as control, user, bypass, h2c_0, c2h_0 etc. | |__ xdma_test/ - Basic test application which performs H2C/C2H transfers on | all present channels. |__ inc/ - Contains public API header file for XDMA driver. |__ libxdma/ - Static kernel library for XDMA IP. |__ sys/ - Reference driver source code which uses libxdma |__ README.md - This file. |__ XDMA.sln - Visual Studio Solution. ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值