ARM32开发--DMA

2024-06-13 1108阅读

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 目录

    前言

    CPU

    RAM

    外设

    程序运行过程

    ARM32程序

    存储

    执行过程

    取数据

    执行操作

    流程总结

    思考

    DMA概念

    ARM32的DMA

    功能说明

    映射参考

    总结



    前言

    CPU

    CPU(Central Processing Unit,中央处理单元)是计算机系统中的核心部件,也被称为处理器。它是计算机的大脑,负责执行指令、处理数据以及控制计算机的各种操作。CPU通常由多个核心组成,每个核心可以独立执行指令,从而提高计算机的处理能力。

    RAM

    RAM(Random-Access Memory,随机存取存储器)是计算机中用于临时存储数据和程序的内存类型。RAM是计算机运行时存储数据的地方,其中包括操作系统、应用程序、用户数据等。与ROM(Read-Only Memory,只读存储器)不同,RAM中的数据可以被读取和写入,而ROM中的数据只能被读取。

    外设

    外设(Peripheral Device)是指连接到计算机或微控制器的附加设备,用于完成特定的功能或提供特定的输入/输出。外设可以是各种类型的硬件设备,例如定时器、显示器、存储设备、通信设备等。这些外设通过与主处理单元(如CPU)或微控制器的通信来实现数据交换和控制操作。


    程序运行过程

    我们用一段伪代码来分析程序执行的过程:

    uint8_t data = 0x01;
    串口发送(data);

    看似简单的代码,其实以上包含了多个功能模块间的交互。

    ARM32开发--DMA

    • cpu
    • SRAM
    • 外设

      ARM32程序

      存储

      ARM32开发--DMA

      在ARM32架构中,程序运行过程中,我们定义的变量其实都是存储在SRAM中,其实就是我们所说的内存。

      我们的CPU去获取这个内存空间的数据,加载到CPU的缓存区(寄存器)中,执行CPU指令,指令操作加载的数据,程序就运行起来了。

      执行过程

      取数据
      uint8_t data = 0x01;

      ARM32开发--DMA

      cpu通过总线,向SRAM发送请求,获取数据

      ARM32开发--DMA

      SRAM接收到请求,将数据通过总线传递给CPU,CPU将数据加载到自己的缓存中。

      执行操作
      串口发送(data);

      ARM32开发--DMA

      CPU通过总线,将数据交给串口,串口接收到数据后,将数据发出。

      流程总结

      1. CPU执行过程中,通过总线,到SRAM中取数据
      2. CPU将取的数据,按照逻辑处理顺序进行执行
      3. 逻辑中用到了外设部分,CPU会将对应的数据通过总线传递给外设

      这里的每一份数据都是这么个操作流程。

      思考

      大量的数据,这样传递是否存在问题。

      ARM32开发--DMA

      • 数据量大时,cpu会一直在一条线上进行反复请求数据,获取数据,执行数据等一系列操作,会消耗cpu的执行时间片。

        DMA概念

        DMA (Direct Memory Access,直接存储器存取),是一种能够在无需CPU参与的情况下,将数据从一个地址空间复制到另一个地址空间高效的传输硬件机制。可以说,DMA就是CPU的高级代理,DMA大大减轻了CPU的负担。

        ARM32开发--DMA

        ARM32的DMA

        功能说明

        GD32F4的DMA控制器有两个:DMA0,DMA1,共有16个通道,每个通道可以被分配给一个或多个特定的外设 进行数据传输。两个内置的总线仲裁器用来处理DMA请求的优先级问题。

        映射参考

        DMA0如下图

        ARM32开发--DMA

        DMA1如下图

        ARM32开发--DMA


        总结

        DMA三种传输方式

        ● 存储器到外设;

        ● 外设到存储器;

        ● 存储器到存储器(仅 DMA1 支持);

        DMA的优先级:

        支持软件优先级(低、中、高、超高)和硬件优先级(通道号越低,优先级越高)。

VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]