Hi3531 PCIe 控制器内含DMA 控制器,DMA 控制器包含有两个DMA 通道(一个

DMA 读通道和一个DMA 写通道)。PCIe 控制器内包含的DMA 控制器用于大数据量

的存储器读写事务,以提高数据传输的速率。

DMA 控制器可以实现如下的存储器读写事务:

DMA 控制寄存器

软件可通过DMA 控制寄存器来配置DMA 传输,也可以通过DMA 控制寄存器启动和

停止DMA 传输。DMA 控制寄存器位于PCIe 控制器的配置寄存器空间内,DMA 控制

寄存器的定义请参考本章的PCIe 寄存器描述。

注意中提到的部分DMA 控制寄存器包含:

 DMA_CH_CTRL 寄存器;

DMA_TRANS_SIZE 寄存器;

DMA_SAR_LOW 和DMA_SAR_HIGH 寄存器;

DMA_DAR_LOW 和DMA_DAR_HIGH 寄存器;

DMA_LINK_PT_LOW 和DMA_LINK_PT_HIGH 寄存器。

1. 软件设置DMA_CH_INDEX[ch_dir]=1,表明后续操作目标寄存器为读通道控制寄存

器。

2. 软件设置DMA_TRANS_SIZE=0x400,表明传输长度为1024Byte。

DMA 读/写通道使能

DMA 通道在系统复位后默认是没有使能的,要使用PCIe 的DMA 通道,需使能DMA

的读写通道。

通过设置DMA_RD_ENGINE_EN[dma_rd_engine_en]为1,使能DMA 读通道。

通过设置DMA_WR_ENGINE_EN[dma_wr_engine_en]为1,使能DMA 写通道。

DMA 源地址和目标地址

DMA 写:源地址(SAR)为本地内存空间,目标地址(DAR)为对端设备内存空间。

DMA 读:源地址(SAR)为对端设备内存空间,目标地址(DAR)为本地内存空间。

配置DMA 读或写通道的DMA_SAR_LOW 和DMA_SAR_HIGH 寄存器可以指定DMA

传输的源地址,配置DMA 读或写通道的DMA_DAR_LOW 和DMA_DAR_HIGH 寄存

器可以指定DMA 传输的目的地址。DMA 源地址和目的地址寄存器请参看PCIe DMA

控制寄存器定义。

DMA 传输过程中,源地址和目的地址寄存器随着传输过程而递增。可以通过读取源地

址和目的地址寄存器的值来确定DMA 当前传输所获取数据的源地址和当前所写数据

的目标地址。

DMA 源地址和DMA 目的地址都是双字节对齐的,因此最低两比特都必须设置为0。

在传输过程中此最低两比特也一直为0。

DMA 传输长度

DMA 读或写操作的传输长度由DMA 读或写通道的DMA_TRANS_SIZE 寄存器来指

定。该寄存器的值表示DMA 请求传输的数据的字节数。在DMA 传输过程,此寄存器

的值会随着传输过程递减,可以通过读取此寄存器确定当前还有多少字节未传输。传

输成功结束后此寄存器值应该为0。

DMA 传输长度取值范围为:最小为1 个字节,最大为4G 字节。

启动DMA 传输

在配置好DMA 读通道的控制寄存器之后,通过向

DMA_RD_DOORBELL[rd_doorbell_num]写入0 来启动DMA 读传输。

在配置好DMA 写通道的控制寄存器之后,通过向

DMA_WR_DOORBELL[wr_doorbell_num]写入0 来启动DMA 写传输。

停止DMA 传输

在DMA 传输过程中如果需要停止DMA 传输,可以通过如下寄存器控制来手动停止

DMA 读或者DMA 写传输:

 通过向DMA_RD_DOORBELL[dma_rd_stop]写入1 来停止DMA 读传输。

通过向DMA_RD_DOORBELL[dma_wr_stop]写入1 来停止DMA 读传输。

如果DMA 传输过程中没有发生错误,DMA 传输将在所有的数据传输完成后自动停

止。

HI_MPI_SYS_SetReg(0x20800A6C,0x00000000);//bit31 0 WRITE  DMA_CH_INDEX

    HI_MPI_SYS_SetReg(0x20800A78,0x00000010);//DMA_TRANS_SIZE 10

HI_MPI_SYS_SetReg(0x2080097c,0x00000001);//使能写操作

HI_MPI_SYS_SetReg(0x20800A7c,0xc0000000);// 源地址—低位

    HI_MPI_SYS_SetReg(0x20800A80,0x00000000);// 源地址—高位

HI_MPI_SYS_SetReg(0x20800A84,0x0544f000);// 目标地址—低位 PC机申请的物理地址

    HI_MPI_SYS_SetReg(0x20800A88,0x00000000);// 目标地址—高位

HI_MPI_SYS_SetReg(0x20800980,0x00000000);//启动写操作

HI3531由DMA 发起PCIe 事务的更多相关文章

  1. PCIe事务层包TLP Header详解

    1.事务层包的一般格式: 包的header为3DW(double word)或者4DW(一个DW代表4字节),数据负载为1~1024DW(即4~4096byte,最大4M),TLP Digest可选, ...

  2. PCIe事务层の详解(一)

    PCIe总线的通信机制:当一个设备要想另一个设备进行读取通信时,请求方requester需要向另一个设备发送请求request,靶向方作为事件完成方completer,以complete Packet ...

  3. hi3531的pcie控制器使能

    1. 关闭PCIe 控制器: 通过向系统控制寄存器PERIPHCTRL30[pcie0_app_ltssm_enabl]写入0 关闭PCIe0 控制 器. 通过向系统控制寄存器PERIPHCTRL77 ...

  4. FPGA与PCI-E

    从并行到串行: PCI Express(又称PCIe)是一种高性能.高带宽串行通讯互连标准,取代了基于总线的通信架构,如:PCI.PCI Extended (PCI-X) 以及加速图形端口(AGP). ...

  5. 转载 大话pcie

    原文https://blog.csdn.net/abcamus/article/details/76167747 一.PCIe DMA机制 PCIe控制器也提供DMA(Direct Memory ac ...

  6. 图解PCIE原理(从软件角度)

    1  PCIE基本概念 1.1   PCIE拓扑架构图 1.2 PCIE Switch内部结构图 1.3  PCIE协议结构图 2 PCIE枚举原理 2.1 Type0&Type1配置头空间 ...

  7. Xilinx DMA的几种方式与架构

    DMA是direct memory access,在FPGA系统中,常用的几种DMA需求: 1. 在PL内部无PS(CPU这里统一称为PS)持续干预搬移数据,常见的接口形态为AXIS与AXI,AXI与 ...

  8. [WCF编程]12.事务:事务传播

    一.事务传播概述 WCF可以跨越服务边界传递事务.这可以让服务参与到客户端事务里,客户端还可以在同一个事务里调用多个服务.客户端本身不一定是WCF服务.客户端事务是否传播到服务端可以通过绑定和操作契约 ...

  9. (6)redis 事务

    redis对事务的支持目前还比较简单.redis只能保证一个client发起的事务中的命令可以连续的执行,而中间不会插入其他client的命令. 由于redis是单线程来处理所有client的请求的所 ...

随机推荐

  1. wpf datagrid row height 行高自动计算使每行行高自适应文本

    wpf 的datagrid的行高 要么是Auto,要么是定值:但会带来麻烦就是每行行高都一样. 当需要按内容(主要是wrap 换行的textbox或textblock)来动态调整行高的时候,需要用到d ...

  2. Oracle 12cR1 RAC 在VMware Workstation上安装(中)—图形界面安装

    Oracle 12cR1 RAC 在VMware Workstation上安装(中)—图形界面安装 1.1  图形界面安装 1.1.1  安装GRID 安装日志:/u01/app/oraInvento ...

  3. CentOS下mysql数据库data目录迁移和配置优化

    目录迁移 关闭数据库服务 service mysqld stop 复制数据库 mv /var/lib/mysql /data/mysql # 或者使用cp -a复制 # 这两个命令都会带权限到新目录去 ...

  4. Using Custom Domains With IIS Express In Asp.Net Core

    IIS Express是一个Mini版的IIS,能够支持所有的Web开发任务,但是这种设计有一些缺陷,例如只能通过localhost:<port>的方式来访问我们的应用程序,看起来就有点不 ...

  5. es随想一

    一.安全问题 前段时间网上看到的,大量的MongoDB服务器和ElasticSearch服务器被黑客攻击,留下勒索信息. ElasticSearch的2种客户端连接方式,transport方式默认的9 ...

  6. BZOJ 4517: [Sdoi2016]排列计数 [容斥原理]

    4517: [Sdoi2016]排列计数 题意:多组询问,n的全排列中恰好m个不是错排的有多少个 容斥原理强行推♂倒她 $恰好m个不是错排 $ \[ =\ \ge m个不是错排 - \ge m+1个不 ...

  7. Retrofit 实践

    Retrofit是一套RESTful架构的Android(Java)客户端实现,基于注解,提供JSON to POJO(Plain Ordinary Java Object,简单Java对象),POJ ...

  8. git恢复误删除文件

    在git仓库管理下误删除文件一般会分为以下3种情况: 1.手动直接删掉,如选择-右击-删除 这种删除未修改本地仓库[版本库],只修改了工作区,直接git checkout -- fileName即可恢 ...

  9. python 3.x 爬虫基础---Urllib详解

    python 3.x 爬虫基础 python 3.x 爬虫基础---http headers详解 python 3.x 爬虫基础---Urllib详解 前言 爬虫也了解了一段时间了希望在半个月的时间内 ...

  10. 一步一步配置ABP Core Template with Angular

    1.首先去https://aspnetboilerplate.com/Templates下载模板工程,按如下勾选 2.下载后打开工程如下图,并设置Web.host 作为启动项目,rebuild 还原n ...