DMA技术

目录

前言

[1. DMA简介](#1. DMA简介)

[2. DMA 的核心工作流程与优势](#2. DMA 的核心工作流程与优势)

2.1工作流程

2.2优势

潜在挑战

[3. DMA 的三种工作模式](#3. DMA 的三种工作模式)


前言

DMA(Direct Memory Access,直接存储器访问)是计算机科学中一个至关重要的概念,特别是在嵌入式系统、高频交易和高性能计算领域。简单来说,它就像是给计算机雇了一个"搬运工",让 CPU 从繁琐的数据搬运工作中解脱出来,但一般不用在FPGA中,因为FPGA可以并行处理。但像Zynq(PS + PL)中会用到DMA。本文将对DMA技术进行介绍。

1. DMA简介

DMA 是一种允许外设(如网卡、显卡、磁盘、ADC 等)直接与系统内存(RAM)进行数据交换的机制,而无需 CPU 的全程干预

在没有 DMA 的年代,数据交换采用 PIO(Programmed I/O) 模式:

  • CPU 发出读取指令。

  • CPU 等待外设准备好数据。

  • CPU 将数据读入寄存器。

  • CPU 将数据从寄存器写入内存。

    该模式流程如图1-1所示*。结果:* 大量 CPU 时钟周期被浪费在单纯的"搬运"上。

图 1-1PIO模式流程图

2. DMA 的核心工作流程与优势

2.1工作流程

DMA 的操作通常分为四个阶段:

  • 初始化: CPU 通过设置 DMA 控制器的寄存器(源地址、目的地址、传输数据量、控制字等)来"下达任务"。

  • 请求(DMA Request): 外设准备好数据后,向 DMA 控制器发送请求信号。

  • 接管总线(Bus Arbitration): DMA 控制器向 CPU 申请总线控制权(Hold)。CPU 完成当前总线周期后释放总线(HLDA),由 DMA 接管。

  • 数据传输: DMA 直接控制地址总线和数据总线,完成内存与外设间的数据移动。

  • 结束(Interrupt): 传输完成后,DMA 控制器向 CPU 发起中断,告知"活儿干完了"。

该流程如图2-1所示。
图 2-1 DMA控制器的五个关键阶段

将传统的CPU搬运方式和DMA架构方式做对比,如图2-2所示。
图 2-2 DMA工作原理对比

2.2优势

DMA搬运数据具有以下优势:

  • 提升 CPU 效率: CPU 可以并行处理逻辑运算,而不是卡在 I/O 等待上。

  • 提高吞吐量: 数据路径更短,减少了寄存器中转带来的延迟。

  • 低功耗: 在某些应用中,可以让 CPU 进入睡眠模式,只留 DMA 在搬运传感器数据。

潜在挑战

  • 缓存一致性(Cache Coherency): DMA 直接改写了内存,但 CPU 的 Cache 里可能还是旧数据。这需要硬件维护一致性或软件进行 Invalidate/Flush 操作。

  • 总线竞争: 如果 DMA 占用总线太久,会造成 CPU "饥饿"。

3. DMA 的三种工作模式

根据对总线占用方式的不同,DMA 有以下三种常见模式:

模式 描述 优缺点
停止 CPU 访问 (Burst Mode) DMA 一旦获得总线,就连续传输完所有数据才释放。 ,但传输期间 CPU 被完全挂起,实时性差。
周期挪用 (Cycle Stealing) 每次 DMA 只传输一个字/字节就归还总线,等下一个请求再申请。 对 CPU 影响小,但总线申请开销大,适合慢速外设。
透明模式 (Transparent Mode) 仅在 CPU 不使用总线(如译码阶段)时才偷偷传输。 对 CPU 完全透明,但电路设计极其复杂且传输效率不可控。

以上就是本次笔记的内容。

相关推荐
旭日初扬2 小时前
N32H762IIL时钟树
单片机·嵌入式硬件
良许Linux2 小时前
汽车电子技术和汽车网络
网络·单片机·嵌入式硬件·汽车·嵌入式·制造
forAllforMe2 小时前
STM32 中断分组解析 说明,以及优先级
stm32·单片机·嵌入式硬件
不脱发的程序猿2 小时前
嵌入式Linux:阻塞式I/O与非阻塞式I/O
linux·服务器·单片机·嵌入式硬件·嵌入式
炸膛坦客2 小时前
单片机/C语言八股:(三)C 语言编译器的优化功能,包括 keil(仅作了解)
c语言·单片机·嵌入式硬件
csg11073 小时前
PIC单片机高阶实战(一):PIC32MX振荡器与定时器
单片机·嵌入式硬件·物联网
逐步前行3 小时前
STM32_GPIO_标准库操作
stm32·单片机·嵌入式硬件
LCG元3 小时前
USB设备开发:STM32F105实现USB HID设备,虚拟串口通信实战
stm32·单片机·嵌入式硬件
香水5只用六神3 小时前
【TIM】基本定时器定时实验(2)
c语言·开发语言·stm32·单片机·嵌入式硬件·mcu·学习