DMA1和DMA2是什么?DMA总线与Dcode总线有区别?SDIO又是干嘛的,system干嘛的?总线矩阵干嘛的?

前文链接:STM32芯片简介,以及STM32的存储器映射是什么?

⭐ 本节用于答疑⭐

芯片(这里指内核,或者叫CPU)和外设之间通过各种总线连接,其中驱动单元有4个,被动单元也有4个,具体见图 1‑4。为了方便理解,我们都可以把驱动单元理解成是CPU部分,被动单元都理解成外设。下面我们简单介绍下驱动单元和被动单元的各个部件。

下面我把你问的所有概念 DMA1 / DMA2、DMA 总线、DCode 总线、SDIO、System 总线、总线矩阵 全部系统性讲清楚,用最适合 STM32 理解的方式,让你彻底掌握。


一、DMA1 和 DMA2 是什么?

DMA = Direct Memory Access(直接内存访问)

作用:

让外设与内存之间的数据搬运不用 CPU 参与,提高效率。

STM32(特别是 F4 系列)内部有 两个 DMA 控制器

  • DMA1

  • DMA2

它们本质都是 DMA 控制器,但服务的 外设不同


⭐ 1.1. DMA1 和 DMA2 的区别?

特征 DMA1 DMA2
位置 APB1 外设附近 AHB1/高级外设附近
能服务的外设 USART2、USART3、SPI2、I2C1 等 SDIO、ADC、SPI1、I2S、DAC、高速设备
支持的通道 7 通道 5 通道(但更高级)

关键区别:

DMA2 可以访问到外部高速外设(如 SDIO、ADC、SPI1)。
DMA1 多用于普通外设(USART2/3、SPI2、I2C 等)。

举例:

  • SDIO(SD 卡读写)只能用 DMA2

  • ADC(高速采样)也只能 DMA2


⭐ 1.2. 为什么需要两个 DMA?

因为 F4 系列外设数量多,如果只有一个 DMA,带宽会不够。

DMA1、DMA2 对应不同的 AHB 总线:

复制代码
CPU
 |
AHB 总线矩阵
 |
+---------+    +---------+
| DMA1    |    | DMA2    |
+---------+    +---------+
 |              |
外设组1         外设组2(高速)

二、DMA 总线 vs DCode 总线(区别很大)

✔ DMA 总线 = DMA 控制器使用的访问通道

  • DMA 当作"数据搬运工"

  • 通过 AHB 总线访问 SRAM、外设

  • 不占用 CPU


✔ D-Cache / DCode 总线(数据总线)

在 STM32F4 内部 CPU 有 三个总线端口

CPU端口 名称 用途
ICode 指令总线 取指令(从 Flash)
DCode 数据总线 CPU 读取常量、Flash 中的数据
System 系统总线 访问 SRAM、外设、DMA 同步等

总结:

DCode = CPU 访问 Flash 里的常量/表数据用的通道
DMA 总线 = DMA 用来搬数据的通道

两者用途完全不同。


三、SDIO 是干嘛的?

3.1. SDIO简介:

SDIO = Secure Digital Input Output

主要功能:

用于连接 SD 卡(例如 TF 卡)和某些 SDIO 外设(如 WiFi 模块)。

它不是 SPI,那是"真 SD 标准总线",速度比 SPI 大很多:

  • SPI 模式:20~25MHz

  • SDIO 4-bit 高速:48MHz

  • SDIO 高速模式可达几十 MB/s

⭐ 3.2. STM32 SD 卡常用方式:

  • SDIO + DMA2 ⇒ 高速读取 SD 卡(FATFS 文件系统)

四、System 总线(系统总线)是什么?

System Bus = CPU 用来访问 SRAM、外设、内部寄存器的主要总线。

在 STM32F4 中 CPU 的 3 个总线端口:

cpp 复制代码
CPU Core (Cortex-M4)
 │
 ├── ICode (指令取指)
 ├── DCode (访问 Flash 里的字常量)
 └── System(访问 RAM、外设)

System Bus 的作用:

  • CPU 访问 SRAM

  • CPU 访问 外设寄存器(GPIO、USART、ADC)

  • CPU 与 DMA 共享带宽

  • System bus 还能访问 AHB/APB 总线上的外设

总结:

System 是 CPU 的"万能通道",用于读写 RAM 和外设。


五、总线矩阵(AHB Bus Matrix)是干嘛的?

非常核心!

总线矩阵的作用:

允许 CPU、DMA、外设 同时访问不同存储区,互不干扰,提高速度。

没有总线矩阵,所有访问要排队(效率差)。

有了总线矩阵:

  • CPU 可以访问 Flash

  • DMA 可以访问 SRAM

  • 外设可以访问 DMA

    同时进行!

图示:

cpp 复制代码
             ┌──────── Flash
CPU ICode ---│
             ├──────── SRAM
CPU DCode ---│
             ├──────── 外设(APB)
CPU System --│
             └──────── DMA

简化理解:

总线矩阵 = "交通枢纽"
让 CPU、DMA 不互相堵车

没有它:

  • DMA 读数据会导致 CPU 卡顿

  • CPU 读 RAM 会抢占外设资源

STM32F4 属于 多主多从总线矩阵

效率比 STM32F1 提升巨大。


🎉 总结(最关键的)

✓ DMA1 和 DMA2

  • 都是 DMA

  • DMA2 给高速外设(SDIO、ADC 等)

  • DMA1 给普通外设(USART、SPI2)

✓ DMA 总线 vs DCode

  • DMA 总线:DMA 用来搬运数据

  • DCode:CPU 访问 Flash(数据区)的总线

    完全不同

✓ SDIO

  • 专门连接 SD 卡

  • 比 SPI 快几倍

  • SD 卡工程必须用它 + DMA2

✓ System 总线

  • CPU 访问 RAM 和外设的通道

✓ 总线矩阵

  • 让 CPU、DMA、外设可以并行工作

  • 不会互相堵塞

  • STM32F4 高速的关键原因

相关推荐
17(无规则自律)34 分钟前
深入浅出 Linux 内核模块,写一个内核版的 Hello World
linux·arm开发·嵌入式硬件
芯岭技术40 分钟前
PY32MD310单片机:高性能、低功耗的32位电机控制微控制器
单片机·嵌入式硬件
wotaifuzao1 小时前
STM32 + FreeRTOS 的订阅通知组件架构
stm32·嵌入式硬件·架构·freertos·事件驱动·嵌入式架构
小龙报2 小时前
【51单片机】深度解析 51 串口 UART:原理、配置、收发实现与工程化应用全总结
c语言·开发语言·c++·stm32·单片机·嵌入式硬件·51单片机
Lester_11019 小时前
STM32 高级定时器PWM互补输出模式--如果没有死区,突然关闭PWM有产生瞬间导通的可能吗
stm32·单片机·嵌入式硬件·嵌入式软件
小李独爱秋11 小时前
“bootmgr is compressed”错误:根源、笔记本与台式机差异化解决方案深度指南
运维·stm32·单片机·嵌入式硬件·文件系统·电脑故障
梁洪飞13 小时前
内核的schedule和SMP多核处理器启动协议
linux·arm开发·嵌入式硬件·arm
进击的小头13 小时前
实战案例:51单片机低功耗场景下的简易滤波实现
c语言·单片机·算法·51单片机
宵时待雨17 小时前
STM32笔记归纳8:时钟
笔记·stm32·单片机·嵌入式硬件
JJRainbow18 小时前
SN75176 芯片设计RS-232 转 RS-485 通信模块设计原理图
stm32·单片机·嵌入式硬件·fpga开发·硬件工程