STM32中DMA工作流程

本文详细介绍了STM32中DMA的工作流程,包括DMA的简介、基本结构、数据宽度与对齐、错误管理和中断。重点讲解了DMA通道与请求的仲裁机制,以及结构体和库函数的使用,如DMA_Init()、DMA_Cmd()等,帮助读者理解如何配置和控制STM32的DMA传输。
摘要由CSDN通过智能技术生成

DMA介绍

DMA简介

DMA(Direct Memory Access)—直接存储器存取,用来提供在外设和存储器之间或者存储器和存储器之间的高速数据传输。无须CPU干预,数据可以通过DMA快速地移动,这就节省了CPU的资源来做其他操作。

DMA框图

 DMA通道与请求

        如果外设要想通过 DMA 来传输数据,必须先给 DMA 控制器发送 DMA 请求, DMA 收到请求信号之后,控制器会给外设一个应答信号,当外设应答后且 DMA 控制器收到应答信号之后,就会启动 DMA 的传输,直到传输完毕。
        DMA 有 DMA1 DMA2 两个控制器, DMA1 7 个通道, DMA2 5 个通道,不同的DMA 控制器的通道对应着不同的外设请求,

仲裁器

当发生多个 DMA 通道请求时,就意味着有先后响应处理的顺序问题,这个就由仲裁器也管理。仲裁器管理 DMA 通道请求分为两个阶段。第一阶段属于软件阶段,可以在DMA_CCRx 寄存器中设置。第二阶段属于硬件阶段,如果两个或以上的 DMA 通道请求设置的优先级一样,则他们优先级取决于通 道编号,编号越低优先权越高,比如通道 0 高于通道 1

DMA基本结构

  方向: 外设是指数据源,存储器是指数据目的地。

 数据宽度与对齐

 错误管理

        读写一个保留的地址区域,将会产生DMA 传输错误。当在 DMA 读写操作时发生 DMA 传输错误
时,硬件会自动地清除发生错误的通道所对应的通道配置寄存器 (DMA_CCRx)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值