HI3531由DMA 发起PCIe 事务

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);//启动写操作

 

 

时间: 2024-10-28 21:23:29

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

hi3531的pcie控制器使能

1. 关闭PCIe 控制器: 通过向系统控制寄存器PERIPHCTRL30[pcie0_app_ltssm_enabl]写入0 关闭PCIe0 控制 器. 通过向系统控制寄存器PERIPHCTRL77[pcie1_app_ltssm_enabl]写入0 关闭PCIe1 控制 器. 2. 使能PCIe 控制器相关的时钟: 设置CRG 寄存器PERI_CRG30[pcie0_cken]使能PCIe0 控制器时钟. 设置CRG 寄存器PERI_CRG30[pcie1_cken]使能PCIe1 控制器时

GTS for DRDS分布式事务的实现理解

GTS介绍 全局事务服务(Global Transaction Service,简称 GTS)是一款高性能.高可靠.接入简单的分布式事务中间件,用于解决分布式环境下的数据一致性问题. 一个完整的业务往往需要调用多个子业务或服务,随着业务的不断增多,涉及的服务及数据也越来越多,越来越复杂.传统的系统难以支撑,出现了应用和数据库等的分布式系统.分布式系统又带来了数据一致性的问题,从而产生了分布式事务. 分布式事务是指事务发起者.资源管理器.事务协调者及资源分别位于不同的分布式系统的不同节点之上. G

Oracle分布式事务和两阶段提交(2PC)

分布式事务是指发生在多台数据库之间的事务,Oracle中通过dblink方式进行事务处理, 分布式事务比单机事务要复杂的多.大部分的关系型数据库通过两阶段提交(2 Phase Commit 2PC)算法来完成分布式事务,下面重点介绍下2PC算法. 1.分布式事务的 组成 在分布式事务中,主要有以下几个组成部分: Client:调用其它数据库信息的节点 Database:接受来自其它节点请求的节点 Global Coordinator (GC):发起分布式事务的节点 Local Coordinat

《深入浅出DPDK》目录—导读

引 言 动机 2015年4月,第一届DPDK中国峰会在北京成功召开.来自中国移动.中国电信.阿里巴巴.IBM.Intel.华为以及中兴的专家朋友登台演讲,一起分享了以DPDK为中心的技术主题.表1列出了2015 DPDK中国峰会的主题及演讲者. 这次会议吸引了来自各行业.科研单位与高校的200多名开发人员.专家和企业代表参会.会上问答交流非常热烈,会后我们就想,也许是时间写一本介绍DPDK.探讨NFV数据面的技术书籍.现在,很多公司在招聘网络和系统软件人才时,甚至会将DPDK作为一项技能罗列在招

基于java得web服务器实现[Z]

web|web服务|web服务器 基于Java的Web服务器工作原理1 一个 Web 服务器也被称为 HTTP 服务器,它通过 HTTP 协议与客户端通信.这个客户端通常指的是 Web 浏览器.一个基于 Java 的 Web 服务器用到二个重要的类,java.net.Socket 与 java.net.ServerSocket ,并通过 HTTP 消息通信.因此,本文从讨论 HTTP 与这二个类开始,然后我将解释一个与本文相关的简单的 Web 应用. The Hypertext Transfer

enode框架入门:saga的思想与实现

因为enode框架的思想是,一次修改只能新建或修改一个聚合根:那么,如果一个用户请求要涉及多个聚合 根的新建或修改该怎么办呢?本文的目的就是要分析清楚这个问题在enode框架下是如何解决的.如果想直接 通过看代码的朋友,可以直接下载源代码,源码中共有三个例子,BankTransferSagaSample这个例子就是本文 所用的例子. saga的由来 saga这个术语,可能很多人都还很陌生.saga的提出,最早是为了解 决可能会长时间运行的分布式事务(long-running process)的问

深入理解Java内存模型系列篇

[本文转载于深入理解Java内存模型,可点击每个章节标题查看原文] 深入理解Java内存模型(一)--基础 并发编程模型的分类 在并发编程中,我们需要处理两个关键问题:线程之间如何通信及线程之间如何同步(这里的线程是指并发执行的活动实体).通信是指线程之间以何种机制来交换信息.在命令式编程中,线程之间的通信机制有两种:共享内存和消息传递. 在共享内存的并发模型里,线程之间共享程序的公共状态,线程之间通过写-读内存中的公共状态来隐式进行通信.在消息传递的并发模型里,线程之间没有公共状态,线程之间必

ENode 1.0 - Saga的思想与实现

开源地址:https://github.com/tangxuehua/enode 因为enode框架的思想是,一次修改只能新建或修改一个聚合根:那么,如果一个用户请求要涉及多个聚合根的新建或修改该怎么办呢?本文的目的就是要分析清楚这个问题在enode框架下是如何解决的.如果想直接通过看代码的朋友,可以直接下载源代码,源码中共有三个例子,BankTransferSagaSample这个例子就是本文所用的例子. Saga的由来 saga这个术语,可能很多人都还很陌生.saga的提出,最早是为了解决可

一文掌握云数据库现状与前沿技术

「一切都会运行在云端」.现在越来越多的业务从自己维护基础设施转移到公有(或者私有)云上, 带来的好处也是无需赘述的,极大降低了 IaaS 层的运维成本,对于数据库层面来说的,以往需要很强的 DBA 背景才能搞定弹性扩容高可用什么的高级动作,现在大多数云服务基本都或多或少提供了类似的服务. 今天的分享主要集中在比较顶尖的云服务商的云数据库方案背后的架构,以及我最近观察到的一些对于云数据库有意义的工业界的相关技术的进展. Amazon RDS 其实说到公有云上的云数据库,应该最早 Amazon 的