Zynq学习笔记-AXI DMA(Scatter/Gather)模式和例程

CSDN不方便排版,已经转移到个人主页,请前往查看
https://lgyserver.top/index.php/2022/03/22/zynq%e5%ad%a6%e4%b9%a0%e7%ac%94%e8%ae%b0-axi-dmascatter-gather%e6%a8%a1%e5%bc%8f/
谢谢!

Scatter/Gather模式简介

AXI DMA操作需要先提供一个在内存中驻留的不变空间,用于存储需要进行的DMA操作。形容这“每一次操作”的东西叫做Buffer Descriptor,缩写叫BD,这些BD是连接成链表的形式的,因为BD会动态增加,而预先分配存储BD的空间是恒定的,因此BD被连成一个环(BD Ring),其实就是一个循环链表。

Scatter/Gather 允许一个数据包(Packet)由多个描述符(BD)来描述。官方文档指出的一个典型应用是在传输网络包时,Header和数据往往是分开存储的,利用SG模式可以较好的处理向多个目标读写的操作,提高应用吞吐量。 DB Ring中DB成链存放,为了解决环形结构带来的不知道Packet的起点和终点带来的问题,DMA使用了帧开始位 (TXSOF,TX Start of Frame bit) 和帧结束位 (TXEOF,TX End of Frame Bit)来分辨一段Packet。 当 DMA 获取设置了 TXSOF 位的描述符时,将触发Packet的开始。 Packet继续获取后续描述符,直到它获取一个设置了 TXEOF 位的描述符。

在接收 (S2MM) 通道上,当开始接收数据包时,AXI DMA会自动使用 RXSOF 标记描述符,告诉软件部分这个描述符对应的buffer是一个数据包的开头。 如果正在接收的数据包的总字节数比描述符中指定的长,则用下一个描述符接着传。 这种获取和存储过程一直持续到整个接收数据包被传输完毕。 接收到数据包结尾时正在处理的描述符由AXI DMA自动标记为RXEOF=1。表明与该描述符关联的缓冲区包含数据包的结尾。

每个描述符内部指明了该特定描述符实际传输的字节数。 软件可以通过从 RXSOF 描述符通过描述符链到 RXEOF 描述符来确定为接收数据包传输的总字节数。

Scatter Gather 操作从设置控制寄存器和描述符指针开始。

设置和启动 MM2S 通道的 DMA 具体操作如下:

  • 将起始描述符的位置写入Current Descriptor寄存器中
  • 设置运行/停止位为1(MM2S_DMACR.RS=1)启动MM2S运行
  • (可选)启用中断(MM2S_DMACR.IOC_IrqEn 和 MM2S_DMACR.Err_IrqEn)
  • 将末尾描述符位置写入Tail Descriptor寄存器中,写入后会立刻触发DMA获取描述符,如果是多通道,这一步骤会在数据包到达S2MM时开始
  • 处理当前描述符,从内存中读取数据并转化成Stream输出
  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Zynq RTOS scatter/gather DMA是指在Zynq嵌入式系统中使用的一种特殊的DMA技术。DMADirect Memory Access,直接存储器访问)是一种数据传输方式,它允许外部设备直接访问系统内存,而不需要CPU的干预。 Zynq是一种集成了ARM处理器和可编程逻辑的芯片,它在嵌入式系统中常用于高性能计算和数据处理任务。而RTOS(Real-Time Operating System,实时操作系统)是一种专为嵌入式系统设计的操作系统,具有实时性和可预测性。 scatter/gather DMA是一种高效的DMA传输方式,它允许数据按照预定义的映射关系从不同的源地址传输到不同的目标地址,而无需 CPU 的介入。这种方式可以大大减轻 CPU 的负担,提高数据传输的效率和速度。 在Zynq RTOS中,scatter/gather DMA通常用于处理需要大量数据传输的应用,如音频、视频、网络数据包等。通过配置DMA控制器和内存映射表,可以实现从多个源地址到多个目标地址的数据传输,从而实现高效的数据处理。 在使用scatter/gather DMA时,首先需要配置DMA控制器,设置数据传输的源地址、目标地址、传输长度等参数。然后,根据具体的需求,配置内存映射表,定义每个源地址和目标地址之间的映射关系。最后,启动DMA传输,它会按照预定义的映射关系自动完成数据传输,无需 CPU 的干预。 通过使用Zynq RTOS scatter/gather DMA,可以实现高效的数据传输和处理,节约 CPU 的资源,提高系统性能和响应速度。这种技术在许多嵌入式系统中被广泛应用,为复杂的数据处理任务提供了一种有效的解决方案。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值