DMA与AXI DMA ip

文章目录

  • [AXI DMA](#AXI DMA)
    • [Read Channel(读通道)](#Read Channel(读通道))
    • [Write Channel(写通道)](#Write Channel(写通道))
  • [# 其他选项](# 其他选项)
  • [Scatter Gather Engine](#Scatter Gather Engine)

AXI DMA

配置项 说明
Component Name (axi_dma) DMA组件的名称,可以自定义。
Enable Asynchronous Clocks 允许DMA在不同时钟域之间工作,适用于不同频率的模块。
Enable Scatter Gather Engine 启用SG,DMA可处理不连续内存块的数据传输。
Enable Micro DMA 启用微DMA,适合资源需求低的应用场景。
Enable Multi Channel Support 启用多通道支持,允许DMA处理多个数据通道。
Enable Control / Status Stream 启用控制/状态流,DMA可生成控制和状态信号的AXI流接口。
Width of Buffer Length Register (8-26 bits) 指定描述数据传输长度的寄存器宽度,范围为8-26位,当前为14位。
Address Width (32-64 bits) AXI地址的宽度,可选32位或64位,当前为32位。

Read Channel(读通道)

配置项 说明
Enable Read Channel 启用DMA的读通道,从存储器读取数据传输到外设。
Number of Channels 读通道的数量
Memory Map Data Width AXI内存映射数据宽度
Stream Data Width AXI流数据宽度
Max Burst Size 每次传输的最大突发数据量

Write Channel(写通道)

配置项 说明
Enable Write Channel 启用DMA的写通道,将数据从外设传输到内存。
Number of Channels 写通道的数量,当前设置为1个。
Memory Map Data Width AXI内存映射数据宽度,当前为32位。
Stream Data Width AXI流数据宽度,当前为8位。
Max Burst Size 每次传输的最大突发数据量,当前设置为256。
Allow Unaligned Transfers 允许未对齐的数据传输,适用于未严格对齐的数据传输场景。

# 其他选项

配置项 说明
Enable Single AXI4 Data Interface 使用单一的AXI4数据接口。
Use RxLength In Status Stream 在状态流中包含接收数据长度。

Scatter Gather Engine

Scatter-Gather Engine 是一种DMA(Direct Memory Access)模式,在这种模式下,DMA控制器能够处理不连续的内存块的数据传输。简单来说,它允许数据分散(scatter)在不同的内存区域内,但能够聚集(gather)到连续的外设设备或其他内存区域,反之亦然。

特点

效率高:在大多数应用场景下,数据并不总是连续的。Scatter-Gather模式可以一次性处理多个不连续的内存区域,避免了传统DMA对连续内存的严格要求,从而提高了传输效率。

控制灵活:使用一个描述符链表(descriptor list)来描述多个内存块的地址和大小。DMA读取这些描述符,依次进行数据传输。

适用于大数据传输:特别适合网络通信、音视频处理等需要传输大数据的场景。

工作流程

准备描述符表:描述符表中包含源地址、目标地址、数据传输的长度、以及其他控制信息。

DMA读取描述符表:DMA根据描述符表中的信息,将数据从源地址读取并传输到目标地址。

自动处理多个块:当一个描述符的传输完成后,DMA会自动读取下一个描述符,继续传输。

相关推荐
上海合宙LuatOS3 小时前
LuatOS核心库API——【 string】字符串操作
运维·服务器·物联网·junit·硬件工程·信息与通信·嵌入式实时数据库
上海合宙LuatOS4 小时前
LuatOS核心库API——【sys】LuatOS运行框架
运维·服务器·物联网·硬件工程·lua·软件工程·信息与通信
Peter·Pan爱编程7 小时前
第1节:现代GPU硬件架构精讲
硬件架构
listeningwk8 小时前
nvme驱动分析
驱动开发
阿拉斯攀登11 小时前
第 13 篇 输入设备驱动(触摸屏 / 按键)开发详解,Linux input 子系统全解析
android·linux·运维·驱动开发·rk3568·瑞芯微·rk安卓驱动
阿拉斯攀登12 小时前
第 11 篇 RK 平台安卓驱动实战 4:I2C 设备驱动开发,以 OLED 屏为例
android·驱动开发·i2c·瑞芯微·嵌入式驱动·rk3576·嵌入式安卓
阿拉斯攀登12 小时前
第 9 篇 RK 平台安卓驱动实战 2:中断驱动开发,按键中断的完整实现
驱动开发·嵌入式硬件·rk3568·中断·瑞芯微·rk3576·rk安卓驱动
_muffinman12 小时前
LED点阵8*8驱动开发笔记(Ai8051U单片机)
驱动开发·笔记·单片机
LCMICRO-1331084774612 小时前
长芯微LDC64115完全P2P替代AD4115,是一款低功耗、低噪声、24位、Σ-Δ(Σ-Δ)模数转换器(ADC)
stm32·单片机·嵌入式硬件·fpga开发·硬件工程·模数转换器
徐先生 @_@|||12 小时前
AI 大模型编程的软件开发范式:SDD(Specification-Driven Development)模式驱动开发
人工智能·驱动开发