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

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

  • cpu
  • SRAM
  • 外设

ARM32程序

存储

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

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

执行过程

取数据
uint8_t data = 0x01;

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

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

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

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

流程总结

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

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

思考

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

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

DMA概念

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

ARM32的DMA

功能说明

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

映射参考

DMA0如下图

DMA1如下图


总结

DMA三种传输方式

● 存储器到外设;

● 外设到存储器;

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

DMA的优先级:

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

相关推荐
redcocal4 小时前
地平线秋招
python·嵌入式硬件·算法·fpga开发·求职招聘
辰哥单片机设计7 小时前
门磁模块详解(防盗感应开关 STM32)
stm32·单片机·嵌入式硬件·传感器
夜间去看海7 小时前
基于51单片机的自动清洗系统(自动洗衣机)
嵌入式硬件·51单片机·proteus·洗衣机
yrx0203078 小时前
stm32 IIC总线busy解决方法
stm32·单片机·嵌入式硬件
YHPsophie9 小时前
ATGM331C-5T杭州中科微BDS/GNSS全星座定位授时模块应用领域
经验分享·笔记·单片机·信息与通信·交通物流
Archie_IT10 小时前
【STM32系统】基于STM32设计的SD卡数据读取与上位机显示系统(SDIO接口驱动、雷龙SD卡)——文末资料下载
arm开发·stm32·单片机·嵌入式硬件
辰哥单片机设计10 小时前
1×4矩阵键盘详解(STM32)
stm32·单片机·嵌入式硬件·矩阵·传感器
wmkswd10 小时前
CAN总线-STM32上CAN外设
stm32·单片机·嵌入式硬件
Ruohongxu10 小时前
LAN8720A-CP-TR-ABC QFN-24 以太网收发器芯片
单片机