0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

AXI DMA详解与应用篇

冬至子 来源:根究FPGA 作者:叫什么好呢啊 2023-08-10 12:50 次阅读

一、DMA简介

DMA是一种内存访问技术,允许某些计算机内部的硬件子系统可以独立的直接读写内存,而不需要CPU介入处理,从而不需要CPU的大量中断负载,否则,CPU需要从来源把每一片段的数据复制到寄存器,然后在把他们再次写回到新的地方,在这个时间里,CPU就无法执行其他的任务。

DMA是一种快速数据传送方式,通常用来传送数据量较多的数据块。使用DMA时,CPU向DMA控制器发送一个存储器传输请求,这样当DMA控制器在传输的时候,CPU执行其他的操作,传输完成时DMA以中断的方式通知CPU。

DMA传输过程的示意图为:

图片

DMA的传输过程为:

1、为了配置用DMA传输数据到存储器,处理器(Cortex-A9)发出一条指令。

2、DMA控制器把数据从外设传输到存储器或者从存储器传输到存储器,从而较少CPU处理的事务量。

3、输出传输完成后,向CPU发出一个中断通知DMA传输可以关闭。

为了发起传输事务,DMA控制器必须得到以下信息

(1)、源地址——数据被读出的地址

(2)、目的地址——数据被写入的地址

(3)、传输长度——应传输的字节数

二、ZYNQ DMA简介

ZYNQ提供了两种DMA,一种是集成在PS中的硬核DMA,另一种是PL中使用的软核AXI DMA IP。

ARM APU(Application Processor Unit,应用处理单元)设计过程中,已经考虑到大量数据搬移的情况,因此在APU中自带了一个DMA控制器DAMC,这个DMAC驻留在PS内,而且必须通过驻留在内存中的DMA指令编程,这些程序往往需要CPU准备,因此需要部分的CPU参与。DMAC支持多达8个通道,所以多个DMA结构的核可以挂载在单个DMAC上。

DMAC与PL的连接是通过AXI-GP接口,这个接口最高支持到32位宽,这也限制了这种模式下的传输速率,理论上最大为600MB/s,这种模式不占用PL资源,但需要对DMA指令编程,会增加软件的复杂性。

为了获取更高的速率,可以空间换时间,在PL中添加AXI DMA IP core,并利用AXI_HP接口完成高速的数据传输,各种接口的传输比较为:

图片

图片

ZYNQ中ACI_HP接口的分布为:

图片

通过PL的DMA和AXI_HP接口传输方式的拓扑图为:

图片

DMA的数据传输经过S_AXI_HP接口,每一个HP接口都含有控制和数据fifo,这些fifo为大数据量突发传输提供缓冲,使得HP成为理想的高速数据接口。

对DMA的控制或配置通过M_AXI_GP接口(M代表master为PS),传输状态通过中断传达到PS的中断控制器。

关于GP接口在米联客和原子的教程中当时都没理解太透,现在对M_AXI_GP0理解是:

在ZYNQ7处理器系统IP core中,在PS-PL Configuration下的AXI Non Secure Enablement下有一个GP Master AXI Interface选项,可选一个M_AXI_GP0接口。

该接口的作用是对PL侧的IP core通过AXI-Lite总线进行配置,如果不仅需要的话直接不使能即可。

图片

图片

、AXI DMA IP****简介

ZYNQ提供了两种DMA,一种是集成在PS中的硬核DMA,另一种是PL中使用的软核AXI DMA IP。

AXI DMA IP核在AXI4-Stream IP接口之间提供高带宽直接存储访问。其可选的scatter gather(SG,链式相关)功能还可以从基于处理器的系统中的中央处理单元(CPU)卸载数据搬运任务。初始化、状态和管理寄存器通过AXI-Lite从接口访问(即数据发出方为PL,PS为Slave),核心功能组成为(这张图很有助于理解DMA中断以及SDK代码,下面会解释):

图片

原图位于AXI_DMA数据手册的第五页。

AXI DMA使用了三种总线,分别是:

(1)、AXI Memory Map,用于内存交互,AXI4 Memory Map Read用于从DMA读取,AXI4 Memory Map用于向DMA写入。

(2)、AXI4-Lite同于对寄存器的配置。

(3)、AXI4-Stream接口用于对外设的读写,S2MM(Stream to Memory Mapped,数据流向内存映射)用于对外设读取。AXI_MM2S和AXI_S2MM是AXI_Stream总线,可以发送和接收连续的数据流,无需地址。

AXI DMA提供3种模式:

(1)、Direct Register模式:用于在MM2S和S2MM通道上执行简单的DMA传输,小的FPGA资源少。有两个通道:一个从Device到DMA,另一个从DMA到Device。应用程序必须设置缓冲区地址和长度字段以启动相应通道中的传输。

(2)、Scatter/Gather模式:允许在单个DMA事务中将数据传输到多个存储区域传输数据。

(3)、Cyclic DMA模式:

四、AXI DMA参数与接口分析

图片

1、接口分析:

(1)、 M_AXI_MM2S :DMA的读通道,从DDR中读取数据。受Enable Read Channel控制,表现为M_AXI_MM2S。

(2)、 M_AXI_S2MM :DMA的写通道,将数据写入DDR中。受Enable Write Channel控制,表现为M_AXI_S2MM。

(3)、 M_AXIS_MM2S :DMA将数据发送到具有stream接口IP。

(4)、 S_AXIS_S2MM :DMA将数据从具有Stream接口的IP中将数据读入。

(5)、 mm2s_introut :DMA将数据从DDR的映射单元中读出,然后将数据发送到具有Stream接口的IP完成信号

(6)、 s2mm_introut :DMA将数据从具有stream接口的IP中读入,并写入到内存映射单元的完成中断信号。

2、参数分析

图片

(1)、Enable Scatter Gatter Engine

链式DMA操作,取消选中该选项可启用directregister模式操作。

(2)、Enable Micro DMA

改选项会生成高度优化的DMA,资源数量较少,用于传输极少量数据的应用程序。

(3)、Width of Buffer Length Register

根据IP手册pg021,在direct register模式下,此整数值用于指定控制字段缓冲区长度的有效位数,字节数等于2^(width),即字节读取和字节写入的有效长度都是2^(width)。比如宽度设置为26,可传输的字节数为2^(26)字节。(pg021,78页)。

(4)、Address Width

指定地址空间的宽度,默认32。

(5)、Enable Read Channel

**Memory Map Data Width** :AXI MM2S存储映射读取总线的数据位宽,可为32、64、128、256、512、1024。

Stream Data Width :AXI MM2S AXI-Stream数据总线的位宽,该值必须小于等于Memory Map Data Width,可以为8、16、32、64、128、512、1024。

Max Burst Size :最大突发长度设置,指定的是MM2S的AXI4-Memory Map侧的突发周期的最大值,可为2、4、8、16、32、64、128、256。

(6)、Enable Write channel:同Read channel。

3、关于中断的理解

(1)、 M_AXI_MM2S :DMA的读通道,从DDR中读取数据。受Enable Read Channel控制,表现为M_AXI_MM2S。

在AXI_DMA ip core的输出信号中,有两个中断信号,分别是s2mm_introut和mm2s_introut,mm指的是Memory Mapped,S指的是Stream。

Memory Map指的是什么?根据AXI DMA的介绍,AXI DMA提供一个介于AXI4 Memory Mapped 与AXI4 Stream IP之间的高带宽DMA:

原话位于IP参考的page5:

The AXI DirectMemory Access (AXI DMA) IP core provides high-bandwidth direct memory accessbetween the AXI4 memory mapped and AXI4-Stream IP interfaces.

所以,对于DMA来说,S2MM,就是Stream形式的数据到达DDR映射空间,具体的实现方式是Stream数据流先进入DMA,之后再从DMA到Memeory Mapped。

MM2S是Memory Mapped将数据送入具有AXI Stream接口的IP。

从这里分析mm2s_introut与s2mm_introut信号的区别是分析不出来的,因为数据都是先到DMA,再从DMA发送出去。

在第5页还有一张图,讲述AXI DMA的架构:

图片

分析这张图,DDR内存映射空间的读写都是通过AXI4Memory Map完成的,也就是说s2mm与mm2s的重点不在PS DDR侧,重点在PL侧,当Stream接口的数据将输出传到DMA时候,这个过程叫做DMA的接收,DMA将映射单元的数据写到stream接口的IP,这个过程叫做DMA的发送。

所以!也就可以理解在SDK中将s2mm_introut定义为DMA接收中断,将mm2s_introut定义为发送中断了!

所以以下语句就很容易理解了:

// DMA接收通道的中断ID

#define RX_INTR_ID XPAR_FABRIC_AXIDMA_0_S2MM_INTROUT_VEC_ID

#define TX_INTR_ID XPAR_FABRIC_AXIDMA_0_MM2S_INTROUT_VEC_ID

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 处理器
    +关注

    关注

    68

    文章

    19349

    浏览量

    230328
  • DDR
    DDR
    +关注

    关注

    11

    文章

    712

    浏览量

    65407
  • FIFO存储
    +关注

    关注

    0

    文章

    103

    浏览量

    6018
  • DMA控制器
    +关注

    关注

    1

    文章

    43

    浏览量

    12303
  • Zynq处理器
    +关注

    关注

    0

    文章

    2

    浏览量

    942
收藏 人收藏

    评论

    相关推荐

    ZYNQ SOC案例开发:AXI DMA使用解析及环路测试

    一、AXI DMA介绍 本篇博文讲述AXI DMA的一些使用总结,硬件IP子系统搭建与SDK C代码封装参考米联客ZYNQ教程。若想让ZYNQ的PS与PL两部分高速数据传输,需要利用P
    的头像 发表于 12-31 09:52 8761次阅读
    ZYNQ SOC案例开发:<b class='flag-5'>AXI</b> <b class='flag-5'>DMA</b>使用解析及环路测试

    AMBA_AXI总线详解

    AMBA_AXI总线详解
    发表于 04-18 11:48

    如何在ZedBoard中使用AXI DMA核心

    你好最近我一直在研究如何在ZedBoard中使用AXI_DMA核心。我正在使用s2mm通道以分散聚集模式将数据传输到DRAM。框图如下图所示(基于Mohammadsadegh Sadri Zynq
    发表于 04-09 11:53

    AXI-DMA怎么批量发送数据到DMA

    利用AXI-DMA批量发送数据到DMAinit_intr_sys函数分析
    发表于 03-10 06:57

    AXI接口协议详解

    1、AXI接口协议详解  AXI 总线  上面介绍了AMBA总线中的两种,下面看下我们的主角—AXI,在ZYNQ中有支持三种AXI总线,拥有
    发表于 10-14 15:31

    Adam Taylor玩转MicroZed系列68:AXI DMA Ⅲ,软件部分

    上周的博客中我们完成了硬件的搭建,并且把硬件部分导入到SDK,见Adam Taylor’s MicroZed Chronicles Part 67: AXI DMA II,下一步通过写一个简单的程序
    发表于 02-08 05:53 416次阅读
    Adam Taylor玩转MicroZed系列68:<b class='flag-5'>AXI</b> <b class='flag-5'>DMA</b> Ⅲ,软件部分

    Adam Taylor玩转MicroZed系列67:AXI DMA II

    上周的博客中我们学习了Zynq SoC的AXI DMA,我解释了怎样利用AXI DMA控制器将数据从PL搬运到PS。在本期博客中我们将学习怎样完成硬件的搭建。 首先我们要更深入的了解一
    发表于 02-08 08:10 390次阅读

    从应用角度详解什么是AXI

    本节介绍的AXI是个什么东西呢,它其实不属于Zynq,不属于Xilinx,而是属于ARM。它是ARM最新的总线接口,以前叫做AMBA,从3.0以后就称为AXI了。 书上讲的AXI比较具体,本节呢不打算落入俗套,从应用角度解释
    的头像 发表于 07-13 07:08 1.1w次阅读
    从应用角度<b class='flag-5'>详解</b>什么是<b class='flag-5'>AXI</b>

    zynq linux AXI DMA传输步骤教程详解

    本文主要介绍zynq linux AXI DMA传输步骤教程,具体的跟随小编一起来了解一下。
    的头像 发表于 07-08 05:46 3w次阅读
    zynq linux <b class='flag-5'>AXI</b> <b class='flag-5'>DMA</b>传输步骤教程<b class='flag-5'>详解</b>

    一文详解ZYNQ中的DMAAXI4总线

    在ZYNQ中,支持AXI-Lite,AXI4和AXI-Stream三种总线,但PS与PL之间的接口却只支持前两种,AXI-Stream只能在PL中实现,不能直接和PS相连,必须通过
    的头像 发表于 09-24 09:50 5364次阅读
    一文<b class='flag-5'>详解</b>ZYNQ中的<b class='flag-5'>DMA</b>与<b class='flag-5'>AXI</b>4总线

    你必须了解的AXI总线详解

    不同类型的DMA GPIO PL general purpose AXI GP AXI utlilizing PS DMAC High performance w/DMA ACP w/
    的头像 发表于 10-09 18:05 7534次阅读
    你必须了解的<b class='flag-5'>AXI</b>总线<b class='flag-5'>详解</b>

    ZYNQ中DMAAXI4总线

    ZYNQ中DMAAXI4总线 为什么在ZYNQ中DMAAXI联系这么密切?通过上面的介绍我们知道ZYNQ中基本是以AXI总线完成相关功能
    的头像 发表于 11-02 11:27 4355次阅读
    ZYNQ中<b class='flag-5'>DMA</b>与<b class='flag-5'>AXI</b>4总线

    Petalinux加速axi-dma内核驱动缓冲区读过程

    Petalinux 加速axi-dma内核驱动缓冲区读过程
    的头像 发表于 02-16 16:21 3625次阅读
    Petalinux加速<b class='flag-5'>axi-dma</b>内核驱动缓冲区读过程

    浅析AXI DMA收发数据传输过程

    MAIP的M_AXI_MM2S接口接收到数据完成后通过mm2s_introut接口输出高电平告诉PS端DMA接收数据传输完成,PS端开始执行发送中断程序。
    发表于 10-11 15:16 2387次阅读

    ZYNQ基础---AXI DMA使用

    Xilinx官方也提供有一些DMA的IP,通过调用API函数能够更加灵活地使用DMA。 1. AXI DMA的基本接口 axi
    的头像 发表于 01-06 11:13 158次阅读
    ZYNQ基础---<b class='flag-5'>AXI</b> <b class='flag-5'>DMA</b>使用