DMA简介
DMA 全称Direct Memory Access,即直接存储器访问
DMA传输将数据从一个地址空间复制到另一个地址空间。当CPU初始化这个传输动作,传输动作本身是由DMA控制器来实现和完成。DMA传输方式无需CPU直接控制传输,也没有中断处理方式那样保留现场和恢复现场过程,通过硬件为RAM和IO设备开辟一条直接传输数据的通道,使得CPU的效率大大提高。
作用:DMA的就是CPU的助手、数据搬运工。
STM32F1最多有2个DMA控制器,DMA2仅存在大容量产品中,DMA1有7个通道,DMA2有5个通道。每个通道专门用来管理来自于一个或多个外设对存储器访问的请求。还有一个仲裁起来协调各个DMA请求的优先权。
STM32的DMA有以下一些特性:
1、每个通道都直接连接专用的硬件DMA请求,都支持软件触发,这些通过软件来配置
2、在七个请求间的优先权可以通过软件编程设置(共有四级:很高、高、中等和低),假如在相等优先权时由硬件决定(请求0优先于请求1,依此类推)。
3、独立的源和目标数据区的传输宽度(字节、半字、全字),模拟打包和拆包的过程。源和目标地址必须按数据传输宽度对齐。
4、支持循环的缓冲器管理
5、每个通道都有3个事件标志(DMA半传输,DMA传输完成和DMA传输出错)这3个事件标志逻辑或成为一个单独的中断请求。
6、外设和存储器,存储器和外设的传输,存储器和存储器间的传输
7、闪存、SRAM、外设的SRAM、APB1、APB2和AHB外设均可作为访问的源和目标。
8、可编程的数据传输数目:最大为65536
8、可编程的数据传输数目:最大为65536