基础
基础知识
- STM所有产品线(列举型号):
- STM产品的3内核架构(列举ARM芯片架构):
- STM32的3开发方式:
- STM32的5开发工具和套件:
- 若要在电脑上直接硬件级调试STM32设备,则需要仿真器。
STM32CubeIDE仅支持ST-LINK仿真器和J-LINK仿真器。 - STM32F41CEU6与Cortex-M4有何区别?
- STM32F41CEU6是微控制器(MCU);Cortex-M4是嵌入式处理器(Embedded CPU)。
- STM32F41CEU6微控制器的核心组件,是Cortex-M4嵌入式处理器。
- 单片机为什么需要晶振才能正常工作?
- 单片机基于数字电路,而数字电路需要节拍的推动才能正常工作。
- 由于晶振元件材料的特殊性,在为其通电后,会周期性的持续输出变化的电压。这种精确变化的电压信号,就可以为各种数字电路提供"心跳"信号。
STM32F41CEU6微控制器(MCU)
特性
项 | 特性 | 备注 |
---|---|---|
CPU | ARM Cortex-M4 | 1. 32 位。 2. RISC 架构。 3. 最大速度 100MHz。 4. 有硬件级的单精度浮点计算单元(FPU)。 5. 有硬件级的数字信号处理器(DSP),支持 DSP 指令,以加速特定任务。 |
RAM | 128K | 1. 嵌入式内存(Embedded RAM)。 2. 静态内存(Static RAM)。 3. 有内存保护单元(Memory Protection Unit),以管理 CPU 对存储器的访问,避免因某个任务执行出错而影响其他任务的数据。 |
ROM | 512K | 1. 嵌入式存储器(Embedded Flash Memory)。 2. Flash 存储器(Flash Memory)。 3. 非易失性存储器(Non-volatile Memory)。 4. 基于冯诺依曼结构,可同时存储程序和数据。 |
存储器加速器 | ART | 通过指令预取队列和分支缓存技术,减少了高速的 CPU 在计算时需经常等待低速的 Flash 的情况。 |
工作电压 | 1.7V ~ 3.6V | 支持低电压工作,以支持低功耗设计。 |
总线 | 6 条主控总线、5 条被控总线 | 参见:[STM32F41CEU6 微控制器(MCU) - 总线](#项 特性 备注 CPU ARM Cortex-M4 1. 32 位。 2. RISC 架构。 3. 最大速度 100MHz。 4. 有硬件级的单精度浮点计算单元(FPU)。 5. 有硬件级的数字信号处理器(DSP),支持 DSP 指令,以加速特定任务。 RAM 128K 1. 嵌入式内存(Embedded RAM)。 2. 静态内存(Static RAM)。 3. 有内存保护单元(Memory Protection Unit),以管理 CPU 对存储器的访问,避免因某个任务执行出错而影响其他任务的数据。 ROM 512K 1. 嵌入式存储器(Embedded Flash Memory)。 2. Flash 存储器(Flash Memory)。 3. 非易失性存储器(Non-volatile Memory)。 4. 基于冯诺依曼结构,可同时存储程序和数据。 存储器加速器 ART 通过指令预取队列和分支缓存技术,减少了高速的 CPU 在计算时需经常等待低速的 Flash 的情况。 工作电压 1.7V ~ 3.6V 支持低电压工作,以支持低功耗设计。 总线 6 条主控总线、5 条被控总线 参见:STM32F41CEU6 微控制器(MCU) - 总线。 时钟 多时钟 参见:STM32F41CEU6 微控制器(MCU) - 时钟。)。 |
时钟 | 多时钟 | 参见:[STM32F41CEU6 微控制器(MCU) - 时钟](#项 特性 备注 CPU ARM Cortex-M4 1. 32 位。 2. RISC 架构。 3. 最大速度 100MHz。 4. 有硬件级的单精度浮点计算单元(FPU)。 5. 有硬件级的数字信号处理器(DSP),支持 DSP 指令,以加速特定任务。 RAM 128K 1. 嵌入式内存(Embedded RAM)。 2. 静态内存(Static RAM)。 3. 有内存保护单元(Memory Protection Unit),以管理 CPU 对存储器的访问,避免因某个任务执行出错而影响其他任务的数据。 ROM 512K 1. 嵌入式存储器(Embedded Flash Memory)。 2. Flash 存储器(Flash Memory)。 3. 非易失性存储器(Non-volatile Memory)。 4. 基于冯诺依曼结构,可同时存储程序和数据。 存储器加速器 ART 通过指令预取队列和分支缓存技术,减少了高速的 CPU 在计算时需经常等待低速的 Flash 的情况。 工作电压 1.7V ~ 3.6V 支持低电压工作,以支持低功耗设计。 总线 6 条主控总线、5 条被控总线 参见:STM32F41CEU6 微控制器(MCU) - 总线。 时钟 多时钟 参见:STM32F41CEU6 微控制器(MCU) - 时钟。)。 |
总线
- 总线分布:
- 功能分布:
据上2图可知:- 6条主控总线分别为:
- Cortex-M4嵌入式处理器的
指令总线
(I-bus)(上图中标注的S0)。
以使CPU从总线矩阵中取指。 - Cortex-M4嵌入式处理器的
数据总线
(D-bus)(上图中标注的S1)。
以使CPU立即加载到数据和调试。 - Cortex-M4嵌入式处理器的
系统总线
(S-bus)(上图中标注的S2)。
以使CPU从内存或外设中取数据。 - 直接内存存取(DMA)控制器1的
DMA控制总线
(DMA_MEM1)(上图中标注的S3)。
以使DMA控制器直接接管在存储器间、存储器与外设间的数据传输。 - 直接内存存取(DMA)控制器2的
DMA控制总线
(DMA_MEM2)(上图中标注的S4)。
以使DMA控制器直接接管在存储器间、存储器与外设间的数据传输。 - 直接内存存取(DMA)控制器2的
DMA外设控制总线
(DMA_P2)(上图中标注的S5)。
以使数据无需经CPU处理而直接在外设与内存间传输。
- Cortex-M4嵌入式处理器的
- 5条被控总线分别为:
- Flash存储器的
程序指令总线
(ICODE)(上图中标注的M0)。
因为Flash存储器是同时存储程序与数据的,故需要有一条总线专用于程序指令的取指、执行。 - Flash存储器的
数据读写总线
(DCODE)(上图中标注的M1)。
因为Flash存储器是同时存储程序与数据的,故需要有一条总线专用于数据的读写。 系统内存总线
(上图中标注的M2)。
用于内存与CPU间、内存与DMA控制器间的数据传输。高级高速总线
1(AHB1)的总线(上图中标注的M3)。
属于AHB总线的一个分支,是高速的外设总线。
可将高速运行的、高数据吞吐量的外围设备与系统互相连接起来,以实现互访。高级高速总线
2(AHB2)的总线(上图中标注的M4)。
属于AHB总线的一个分支,是高速的外设总线。
可将高速运行的、高数据吞吐量的外围设备与系统互相连接起来,以实现互访。
- Flash存储器的
- 4条外设总线。其中:
- AHB1总线与AHB2总线,在结构上相对独立。
- AHB1总线又向下派生出2条总线,分别为APB1总线、APB2总线。
- 除APB1是低速总线外,其余3个均为高速总线。
- 6条主控总线分别为:
时钟
- 时钟分布:
据上图可知:- 不同于STC51系列等早期的单片机,其晶振只有一个,且频率固定。
在STM32系列单片机中,晶振若干,且频率可调,以适应更多场景、满足更多需求(上图中标注的红、绿、粉框)。 - 时钟的分类:
据上图可知: - 系统时钟(SYSCLK)的时钟信号来源,可由以下3个时钟提供:
- HSI时钟(时钟分布图中标注的序号1)。
- HSE时钟(时钟分布图中标注的序号2)。
- 主PPL时钟(Main PLL)中的P分支(PLLP)(时钟分布图中标注的序号3)。
- 锁相环时钟(PLL)的时钟信号来源,可由以下2个时钟提供:
- HSI时钟(时钟分布图中标注的序号4)。
- HSE时钟(时钟分布图中标注的序号5)。
- 锁相环时钟(PLL),输出以下2路时钟信号:
-
给主PLL(Main PLL)输出提供时钟信号(时钟分布图中标注的序号6)。
主PLL(Main PLL),又输出2路时钟信号:
-
通过P分支(PLLP)给系统时钟(SYSCLK)输出提供信号(时钟分布图中标注的序号3)。
-
通过Q分支(PLLQ)给USB OTG FS/随机数发生器/SDIO输出提供信号(时钟分布图中标注的序号8)。
-
-
给I2S输出提供信号(时钟分布图中标注的序号7)。
-
单片机的CPU频率,由系统(SYSCLK)时钟经AHB分频器分频后的HCLK时钟决定。
-
- 不同于STC51系列等早期的单片机,其晶振只有一个,且频率固定。