STM32的DMA(直接存储器访问)模块(寄存器和HAL库两种代码实现方式)

DMA(direct memory access)介绍:目的解放CPU:

外设可通过中断或直接存储器存取(DMA)两种方式向CPU发起数据请求:若采用中断机制,CPU需响应中断:通过地址总线定位内存地址,再经数据总线读取数据至缓存,最终转发给外设,外设接收数据后反馈状态;若采用DMA方式,CPU仅需完成初始化设置,数据即可在内存与外设间直接高速传输,无需CPU干预,传输完成后DMA再通知CPU。DMA技术显著节省了CPU资源,使其能并行处理其他任务。

DMA控制器和Cortex™-M3核心共享系统数据总线,执行直接存储器数据传输。当CPU和DMA同时访问相同的目标(RAM或外设)时,DMA优先占用总线避免外设数据丢失,DMA请求会暂停CPU访问系统总线达若干个周期(DMA处理完后,CPU立刻回收),总线仲裁器执行循环调度,以保证CPU至少可以得到一半的系统总线(存储器或外设)带宽。

DMA功能框图:

DMA请求:

外设给DMA控制器发送DMA请求,DMA应答后就可以传输数据了。

STM32内部有2个DMA:

STM32内部有2个DMA控制器有12个通道(DMA1有7个通道,DMA2有5个通道),不同通道对应不同的多个外设请求,专线专用。

DMA1:

DMA2: 

仲裁器来协调各个DMA请求的优先权(类似中断优先级):软件优先级高于硬件优先级,同级软件优先级看硬件优先级

两个阶段:软件阶段(DMA_CCRx通道配置寄存器):4个等级(非常高,高,中,低),硬件阶段,如果两个或以上的DMA通道请求设置的优先级一样,那么它们优先级取决于通道编

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

得单片机的运

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值