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)
的