DMA,全称Direct Memory Access,即直接存储器访问。
DMA传输:将数据从一个地址空间复制到另一个地址空间。(数据搬运工)
DMA传输无需CPU直接控制传输,也没有中断处理方式那样保留现场和恢复现场过程,通过硬件为RAM何IO设备开辟一条直接传输数据的通道,使得CPU的效率大大提高。
作用:为CPU减负

一般外设挂载在APB1或APB2总线上,但是DMA挂载在在AHB总线上
DMA2仅存在大容量产品和互联型产品。
DMA就是建立数据传输通道。


每个通道用来管理来自于一个或多个外设对存储器访问的请求,且都有一个仲裁器,用于处理DMA请求间的优先级。
仲裁器管理DMA通道请求分为两个阶段:(1)软件阶段、(2)硬件阶段
软件阶段:每个通道的优先级可在DMA_CCRx寄存器中设置,有四个等级:最高、高、中和低优先级。
硬件阶段:若两个请求有相同软件优先级,较低编号的通道比较高编号的通道有较高的优先级。
大容量芯片中,DMA控制器拥有高于DMA2控制器的优先级。
多个请求通过逻辑或输入到DMA控制器,只能有一个请求有效。

在非循环模式下传输结束,要开始新的DMA传输,需要在关闭DMA通道情况下,在传输数量寄存器中重新写入数值。

__HAL_LINKDMA():用来连接DMA和外设句柄。


USART1_TX DMA1_CH4
DMA中断使用:HAL_NVIC_EnableIRQ、HAL_NVIC_SetPriority,编写中断服务函数xxx_IRQHandler