STM32 DMA工作原理

DMA工作原理

DMA介绍

直接存储器存取(DMA)用来提供在外设和存储器之间或者存储器和存储器之间的高速数据传输。无须CPU干预,数据可以通过DMA快速地移动,这就节省了CPU的资源来做其他操作。两个DMA控制器有12个通道(DMA1有7个通道,DMA2有5个通道),每个通道专门用来管理来自于一个或多个外设对存储器访问的请求。还有一个仲裁器来协调各个DMA请求的优先权。

DMA主要特征

●  12个独立的可配置的通道(请求):DMA1有7个通道,DMA2有5个通道

●  每个通道都直接连接专用的硬件DMA请求,每个通道都同样支持软件触发。这些功能通过软件来配置。

●  在同一个DMA模块上,多个请求间的优先权可以通过软件编程设置(共有四级:很高、高、中等和低),优先权设置相等时由硬件决定(请求0优先于请求1,依此类推) 。

●  独立数据源和目标数据区的传输宽度(字节、半字、全字),模拟打包和拆包的过程。源和目标地址必须按数据传输宽度对齐。

DMA主要特征

●  支持循环的缓冲器管理

●  每个通道都有3个事件标志(DMA半传输、DMA传输完成和DMA传输出错),这3个事件标志逻辑或成为一个单独的中断请求。

●  存储器和存储器间的传输

●  外设和存储器、存储器和外设之间的传输

●  闪存、SRAM、外设的SRAM、APB1 、APB2和AHB外设均可作为访问的源和目标。

●  可编程的数据传输数目:最大为65535

DMA1请求映像

从外设(TIMx[x=12 34] ADC1 SPI1SPI/I2S2I2Cx[x=12]USARTx[x=123])产生的7个请求,通过逻辑或输入到DMA1控制器,这意味着同时只能有一个请求有效。

DMA2请求映像

从外设(TIMx[56 7 8] ADC3 SPI/I2S3 UART4DAC通道12SDIO)产生的5个请求,经逻辑或输入到DMA2控制器,这意味着同时只能有一个请求有效。

 

5.设定了外设数据宽度

6.设定了内存数据宽度

7.设置了DMA的工作模式

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值