0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

小白都看得懂的STM32的DMA知识

撞上电子 2023-11-27 08:00 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

一、DMA简介

1、DMA简介

DMA(Direct Memory Access:直接内存存取)是一种可以大大减轻CPU工作量的数据转移方式。

CPU有转移数据、计算、控制程序转移等很多功能,但其实转移数据是可以不需要CPU参与。比如希望外设A的数据拷贝到外设B,只要给两种外设提供一条数据通路,再加上一些控制转移的部件就可以完成数据的拷贝。

DMA就是基于以上设想设计的,它的作用就是解决大量数据转移过度消耗CPU资源的问题。有了DMA使CPU更专注于更加实用的操作--计算、控制等。

2、DMA的工作原理

DMA的作用就是实现数据的直接传输,而去掉了传统数据传输需要CPU寄存器参与的环节,主要涉及四种情况的数据传输,但本质上是一样的,都是从内存的某一区域传输到内存的另一区域(外设的数据寄存器本质上就是内存的一个存储单元)。四种情况的数据传输如下:

外设到内存

内存到外设

内存到内存

外设到外设

当用户将参数设置好,主要涉及源地址、目标地址、传输数据量这三个,DMA控制器就会启动数据传输,传输的终点就是剩余传输数据量为0。换句话说只要剩余传输数据量不是0,而且DMA是启动状态,那么就会发生数据传输。


3、DMA是否影响CPU的运行

在X86架构系统中,当DMA运作时,DMA实际上会占用系统总线周期中的一部分时间。也就是说,在DMA未开启前,系统总线可能完全被CPU使用;当DMA开启后,系统总线要为DMA分配一定的时间,以保证DMA和CPU同时运作。那么显然,DMA会降低CPU的运行速度。

STM32控制器中,芯片采用Cortex-M3架构,总线结构有了很大的优化,DMA占用另外的总线,并不会与CPU的系统总线发生冲突。也就是说,DMA的使用不会影响CPU的运行速度。


二、STM32的DMA结构

1、DMA的主要特性

● 12个 独立的可配置的通道DMA1有7个通道,DMA2 有5个通道
● 每个通道都直接连接专用的硬件DMA请求,每个通道都同样支持软件发。这些功能通过软件来配置。
● 在七个请求间的优先权可以通过软件编程设置(共有四级:很高、高、中等和低),假如在相等优先权时由硬件决定(请求0优先于请求1,依此类推) 。
● 独立的源和目标数据区的传输宽度(字节、半字、全字),模拟打包和拆包的过程。源和目标地址必须按数据传输宽度对齐。
● 支持循环的缓冲器管理
● 每个通道都有3个事件标志(DMA 半传输,DMA传输完成和DMA传输出错),这3个事件标志逻辑或成为一个单独的中断请求。
●存储器和存储器间的传输
●外设和存储器,存储器和外设的传输
● 闪存、SRAM 、外设的SRAM 、APB1 APB2和AHB外设均可作为访问的源和目标。
● 可编程的数据传输数目:最大为65536
下面为功能框图:  

2、两个DMA控制器结构

① DMA1 controller

② DMA2 controller

3、DMA寄存器列表

① 中断类

DMA_ISR:DMA中断状态寄存器DMA_IFCRDMA中断标志位清除寄存器说明:DMA1、DMA2分别有一组寄存器。

② 控制传输类

DMA_CCRxDMA通道x配置寄存器DMA_CNDTRxDMA通道x数据数量寄存器DMA_CPARxDMA通道x外设地址寄存器DMA_CMARx:DMA通道x内存地址寄存器
说明: 1> 每一个通道都有一组寄存器。2> DMA_CPARx、DMA_CMARx是没有差别的,它们都可以存放外设的地址、内存的地址。DMA_CPARx、DMA_CMARx只不过起得名字有差别而已。


4、STM32的DMA工作特点

① DMA进行数据传输的必要条件

剩余传输数据量大于0

DMA通道传输使能

通道上DMA数据传输有事件请求

前两者都好理解,对于第三点确实需要详细的解释,请看下边的三条。

② 外设到XX方向的传输

假设是ADC到存储器的数据传输,显然ADC的DMA传输的源地址是ADC的数据寄存器。并不是说只要DMA通道传输使能后,就立即进行数据传输。只有当一次ADC转化完成,ADC的DMA通道的传输事件有效,DMA才会从ADC的数据寄存器读出数据,写入目的地址。当DMA在读取ADC的数据寄存器时,同时使ADC的DMA通道传输事件无效。显然,要等到下一次ADC转换完成后,才能启动再一次的数据传输。

③存储器对XX的DMA传输

因为数据是准备好的,不像ADC还需要等待数据到位。所以,不需要对应通道的事件。只要使能DMA数据传输就一直传输,直到达到设定的传输量。

举个例子:1.内存到内存DMA传输请求一直有效2.内存到串口 DMA传输请求一直有效

一种解释:存储器对存储器的置位,就相当于相应通道的事件有效。对应通道的事件有效和存储器对存储器的置位,就是传输的触发位。每次传输的事件置位一次,完成一次传输。如果是由外设引发的DMA传输,则传输完成后,相应传输事件会置为无效,而存储器对存储器的传输,则一次传输完成后,相应事件一直有效,直至完成设定的传输量。

④外设以DMA方式工作时,能否再以软件方式进行操作?

有一点是肯定的,当外设以DMA方式正在数据传输时,不可能再相应CPU的软件控制命令,否则这不符合逻辑。

但是,倘若外设仅仅配置成DMA工作方式,但是DMA请求并未产生,数据传输并没有进行。此时,软件控制命令仍然能够对外设进行控制。这是笔者在串口以DMA方式发送数据情形下,所得到的测试结论。

三、STM32的DMA软件编程

1、“内存到内存”模式传输

①初始化配置

/** * @brief USART1 TX DMA 配置,内存到内存 * @param 无 * @retval 无 */void DMA_Mem2Mem_Config(void){ DMA_InitTypeDef DMA_InitStructure; /*开启DMA时钟*/ RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE); /*设置DMA源地址*/ DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)SendBuff;
/*设置DMA目的地址*/ DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)ReceiveBuff;
/*方向:从内存SendBuff到内存ReceiveBuff*/ DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralDST; /*传输大小DMA_BufferSize=SENDBUFF_SIZE*/ DMA_InitStructure.DMA_BufferSize = SENDBUFF_SIZE;
/*ReceiveBuff地址自增*/ DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Enable;
/*SENDBUFF_SIZE地址自增*/ DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
/*ReceiveBuff数据单位*/ DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;
/*SENDBUFF_SIZE数据单位*/ DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_Byte;
/*DMA模式:正常模式*/ DMA_InitStructure.DMA_Mode = DMA_Mode_Normal ;
/*优先级:中*/ DMA_InitStructure.DMA_Priority = DMA_Priority_Medium;
/*使能内存到内存的传输 */ DMA_InitStructure.DMA_M2M = DMA_M2M_Enable; /*配置DMA1的4通道*/ DMA_Init(DMA1_Channel4, &DMA_InitStructure); /*失能DMA1的4通道,一旦使能就开始传输*/ DMA_Cmd (DMA1_Channel4,DISABLE); }

②DMA中断配置

/* * @brief DMA 中断配置 * @param 无 * @retval 无 */void DMA_NVIC_Configuration(void){ NVIC_InitTypeDef NVIC_InitStructure; /* 配置中断源 */ NVIC_InitStructure.NVIC_IRQChannel = DMA1_Channel4_IRQn; NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1; NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure);
/* 配置DMA发送完成后产生中断 */ DMA_ITConfig(DMA1_Channel4,DMA_IT_TC,ENABLE);}

③启动传输

DMA_Cmd (DMA1_Channel4,ENABLE);

2、利用DMA实现循环传输

方法1:单次传输模式

当传输结束时,触发DMA中断,在中断程序中首先失能DMA通道,然后修改该通道的传输数据量。最后重新使能DMA通道,注意只有失能的DMA通道才能成功修改传输数据量。


方法2:循环传输模式

当传输结束时,硬件自动会将传输数据量寄存器进行重装,进行下一轮的数据传输。


四、再谈STM32的DMA传输是否影响CPU的运行速度

声明:经过笔者测试,当DMA工作在内存到外设的传输和内存到内存的传输时,都不会影响CPU的运行速度。为了给这种现象一个合理的解释,笔者做以下猜测:

1、S3C2440的DMA传输

S3C2440的SDRAM是外置的,并且SDRAM的数据线、地址线、控制线总共只有一组。假设DMA传输的方向是内存到外设,当DMA运作时,需要占用SDRAM的三类线才才能实现传输;而与此同时CPU也需要通过这三类线来访问SDRAM来读取程序、读写数据。

显然,DMA的运行与CPU的运行有交叉点,DMA就会影响到CPU的运行。

2、STM32的DMA传输

STM32与S3C2440的区别是很大的,S3C2440是微处理器,RAM外置且空间很大;STM32是微控制器,RAM片内集成且空间较小。此时,ST公司就有可能提升DMA的运作效率,使DMA的工作不影响到CPU的运行。外设与外设之间的DMA传输,因为与CPU的运行没有交叉点(CPU的数据流注意是在Flash、内存、寄存器中传输),所以不会影响CPU的运行速度。唯一有可能影响的是外设与内存或者内存与内存之间的DMA传输。倘若ST公司的SRAM是一个双口RAM,也就是同时可以由两组接口对RAM进行访问,就可以很好的解决速度影响问题。倘若CPU恒定占有一组接口,而另一组接口留给DMA控制器。那么当外设与内存或者内存与内存之间的DMA传输时,由于不与CPU的访问SRAM接口冲突,所以可以解决速度影响问题。但其实偶尔还是会影响的,当CPU访问SRAM的空间和DMA访问SRAM的空间相同时,SRAM势必会对这种情况进行仲裁,这可能会影响到CPU的访问SRAM的速度。其实,这种情况的概率也是很小的,所以即使影响CPU的运行速度,也不会很大。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 寄存器
    +关注

    关注

    31

    文章

    5590

    浏览量

    129112
  • STM32
    +关注

    关注

    2305

    文章

    11124

    浏览量

    371261
  • dma
    dma
    +关注

    关注

    3

    文章

    577

    浏览量

    105377
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    天下武功 唯快不破 ——高帧率CMOS图像传感器

    高帧率CMOS图像传感器是现代视觉系统从“看得见”迈向“看得清”、“看得懂”的关键一环。它通过捕捉和解析高速瞬态过程,为工业自动化、科学探索、安全保障和艺术创作提供了前所未有的洞察力。随着技术的不断
    的头像 发表于 11-16 21:13 96次阅读
    天下武功 唯快不破 ——高帧率CMOS图像传感器

    感知即安全:安防监控系统的价值重构

    在数字技术飞速发展的当下,安防监控系统正在经历一场深刻的认知革命。这套系统已不再满足于传统意义上的“看得见”,而是向着“看得懂、能预警、会思考”的智能视觉中枢演进,成为城市治理和企业运营的视觉神经
    的头像 发表于 10-22 14:43 106次阅读

    聆思大模型智能FAE,看得懂技术,答得准问题

    聆思大模型智能FAE,看得懂技术,答得准问题 在智能硬件开发的嵌入式技术支持中,响应迟缓、人员培训成本高企、服务时间覆盖不足等痛点,常常制约FAE团队效率 聆思大模型智能FAE作为专为智能硬件
    发表于 09-30 11:29

    从“看得见”到“看得懂”:物联网智能监控系统 #物联网 #plc

    物联网
    juying
    发布于 :2025年09月22日 15:06:58

    stm32支持canfd和dma结合使用吗?

    stm32支持canfd和dma结合使用吗
    发表于 08-01 07:15

    索尼水产养殖智能监控摄像头模块——FCB-EV9520L

    当传统摄像机还在为“看得见”挣扎时,索尼FCB-EV9520L已通过宽动态与HDR技术,为水产养殖行业打开“看得清、看得懂、用得好”的新维度。
    的头像 发表于 07-18 17:24 546次阅读

    瑞芯微全新AI视觉芯片RV1126B:多场景智能终端方案介绍

    技术、硬件级安全机制等创新特性,为智慧安防、工业视觉、智慧车载、服务机器人等AIoT应用场景提供强大助力,推动终端设备从「看得清」迈向「看得懂」的全新阶段。RV1
    的头像 发表于 07-16 17:00 4159次阅读
    瑞芯微全新AI视觉芯片RV1126B:多场景智能终端方案介绍

    高光谱相机让农业“看得懂作物”!病虫害一拍识别

    在传统农业中,判断作物是否健康,主要依赖经验和肉眼观察:叶子黄了,是不是缺氮?叶片上有斑,是不是病害?但这些判断不仅主观性强,而且往往滞后——等肉眼看到问题,作物可能已经受损。 现在,一种新技术正在改变这一切。它就是 高光谱相机 。在智慧农业场景中,它被称为“作物的医生眼”,能看见作物细胞层级的变化,用光谱语言解读植物的真实状态。 一、什么是高光谱相机? 高光谱相机不是普通照相机。它不是拍“彩照”,而是捕捉物
    的头像 发表于 06-12 18:25 596次阅读
    高光谱相机让农业“<b class='flag-5'>看得懂</b>作物”!病虫害一拍识别

    观测云:从云时代走向AI时代

    、业务链路的全面掌控。 5月13日的产品发布会上,我们正式宣布: 观测云,已从云时代迈入 AI 时代。 在数据量爆炸、系统复杂度日益提升的今天,仅依靠传统的监控手段已经难以满足企业对“看得见、看得懂看得清”的需求。从早期的
    的头像 发表于 05-15 10:47 595次阅读

    传统摄像头为什么需要升级为AI盒子?多场景痛点解析

    系统具备了“看得懂”的能力,大幅提升了管理效率并降低了人力成本。   那么, 为什么传统摄像头需要升级AI盒子? 哪些场景必须依赖AI分析?小编将从安防、零售、工业三大典型场景出发,解析传统方案的痛点,并说明AI盒子如何解
    的头像 发表于 05-14 17:53 762次阅读

    经典智能电路300例

    328例智能电路中,使读者看得懂用得上。 纯分享贴,有需要可以直接下载附件获取文档! (如果内容有帮助可以关注、点赞、评论支持一下哦~)
    发表于 04-19 15:26

    涂鸦打造超强AI IPC技术!深度融合视觉+听觉感知能力,颠覆传统IPC交互玩法

    随着AI大模型能力的突破与成本的下降,IPC开始从单一的“看得见”向“看得懂”迭代,并进一步向“智能交互、主动决策”的方向升级演进。目前主流设备已标配三大能力:即智能识别与分析、多模态交互与自动化管
    的头像 发表于 04-17 18:20 902次阅读
    涂鸦打造超强AI IPC技术!深度融合视觉+听觉感知能力,颠覆传统IPC交互玩法

    STM32虚拟仿真系统:零基础小白到嵌入式全栈工程师的进阶秘籍

    在嵌入式开发领域,硬件原理的抽象性和项目全流程的复杂性一直是初学者面临的挑战,尤其是像STM32单片机开发这种软硬件结合的方向,初学者很容易被复杂的硬件知识、寄存器配置、PCB设计这些东西劝退
    的头像 发表于 03-12 11:46 1068次阅读
    <b class='flag-5'>STM32</b>虚拟仿真系统:零基础<b class='flag-5'>小白</b>到嵌入式全栈工程师的进阶秘籍

    STM32H7ZGT6使用SPI+DMA方式驱动屏幕,使用DMA方式会花屏,为什么?

    STM32H7ZGT6使用SPI+DMA方式驱动屏幕时候,使用阻塞式发送不会花屏幕,但是使用DMA方式会花屏。
    发表于 03-12 06:03

    ZYNQ基础---AXI DMA使用

    前言 在ZYNQ中进行PL-PS数据交互的时候,经常会使用到DMA,其实在前面的ZYNQ学习当中,也有学习过DMA的使用,那就是通过使用自定义的IP,完成HP接口向内存写入和读取数据的方式。同样
    的头像 发表于 01-06 11:13 3629次阅读
    ZYNQ基础---AXI <b class='flag-5'>DMA</b>使用