前文链接: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 高速的关键原因