Cortex-M3-STM32F1 开发:(十一)ARM Cortex-M 内核中的 MPU 和 FPU

上一篇 下一篇
F1 的时钟系统

一、MPU

Memory Protection Unit:内存保护单元

MPU 是一个集成在处理器核心内部的硬件模块,用于监控和控制处理器对内存区域的访问权限。它将物理内存划分为多个"区域"(Regions),并为每个区域设置详细的访问规则。

① 核心功能:

  • 内存区域划分:
    • 可以定义多个内存区域(如 Flash、SRAM、外设寄存器、堆栈等)。
    • 每个区域可以设置起始地址、大小和属性。
  • 访问权限控制:
    • 特权/用户模式访问:例如只允许操作系统内核(特权模式)访问某些关键内存,而用户任务(用户模式)无法访问。
    • 读写执行权限:
      • 可配置为只读、只写、读写、不可访问。
      • 可设置是否允许代码执行(XN, eXecute Never),防止数据区被当作代码运行,抵御缓冲区溢出攻击。
    • 共享/非共享:控制多核系统中的内存一致性。
  • 内存类型和缓存策略:
    • 定义内存是普通 RAM、设备内存(外设寄存器)还是强序内存。
    • 设置缓存策略(如回写、直写、不可缓存),确保对外设访问的正确性。

② 工作原理:

当处理器尝试访问某个内存地址时,MPU 会检查该地址所属的区域及其访问规则。如果访问违反了设定的权限(如用户模式写入只读区域),MPU 会触发一个 MemManage Fault 异常,由操作系统或故障处理程序决定如何处理(如终止违规任务)。

③ 主要用途:

  • 增强系统可靠性:防止一个任务(或buggy代码)破坏另一个任务或操作系统的内存。
  • 支持 RTOS:实现任务间的内存隔离,是构建稳定多任务系统的基础。
  • 安全防护:通过 XN 位防止恶意代码注入和执行。
  • 调试辅助:帮助定位内存越界、野指针等错误。

④ 支持的 Cortex-M 核心:

  • Cortex-M3, M4, M7, M33, M55, M85 等中高端核心支持 MPU。
  • M0/M0+/M23 等超低功耗核心通常不包含 MPU。

二、FPU

Floating-Point Unit:浮点运算单元

FPU 是一个专门用于执行浮点数(Floating-Point)算术运算 的硬件协处理器。它直接处理 float (32位) 和 double (64位, 部分 FPU 支持) 类型的数据。

① 核心功能:

  • 硬件加速浮点运算:
    • 直接执行 +, -, *, / 等浮点运算。
    • 支持复杂的数学函数(如开方、三角函数,部分FPU支持)。
  • 专用寄存器:
    • 拥有自己的一组浮点寄存器(S0-S31 for single-precision, D0-D15 for double-precision)。
    • 有独立的浮点状态寄存器(FPSCR)。
  • 遵循 IEEE 754 标准:确保浮点计算的精度和一致性。

② 工作原理:

当编译器生成浮点运算指令时,如果存在 FPU,这些指令会被发送到 FPU 执行。FPU 在硬件层面完成计算,速度远快于用整数运算模拟浮点运算(Soft-float)。在没有 FPU 的 MCU 上可能需要调用几十甚至上百条整数指令来模拟,而在有 FPU 的 MCU 上只需几条指令即可完成。

③ 主要用途:

  • 数字信号处理 (DSP):音频、语音、滤波算法中大量使用浮点数。
  • 传感器融合:加速度计、陀螺仪、磁力计的数据融合(如卡尔曼滤波)。
  • 图形与图像处理:坐标变换、颜色空间转换。
  • 科学计算与控制算法:PID 控制、电机矢量控制、机器人运动学。
  • 机器学习 (ML) 推理:边缘AI模型(尤其是使用浮点权重的模型)的推理。

④ 支持的 Cortex-M 核心:

  • Cortex-M4F:带单精度 FPU(可选)。
  • Cortex-M7F:带双精度 FPU(通常标配)。
  • Cortex-M33F, M55F, M85F:带 FPU。
  • M0/M0+/M3/M23 等核心不支持硬件 FPU,浮点运算是通过软件库模拟的,效率很低。

相关推荐
✎ ﹏梦醒͜ღ҉繁华落℘3 小时前
单片机开发---分层架构设计
单片机·嵌入式硬件·mongodb
国科安芯4 小时前
AS32S601ZIT2抗辐照MCU在商业卫星飞轮系统中的可靠性分析
服务器·网络·人工智能·单片机·嵌入式硬件·fpga开发·1024程序员节
应用市场4 小时前
STM32卡尔曼滤波算法详解与实战应用
人工智能·stm32·算法
点灯小铭6 小时前
基于单片机的±5V数字电压表设计
单片机·嵌入式硬件·毕业设计·课程设计·期末大作业
djarmy6 小时前
使用定时器14(GPIOF9复用映射到TIM14_CH1)控制LED0闪烁实验
stm32·单片机·嵌入式硬件
GilgameshJSS7 小时前
STM32H743-ARM例程29-HTTP
c语言·arm开发·stm32·单片机·http
学工科的皮皮志^_^7 小时前
锂电池充放电管理学习
经验分享·笔记·单片机·嵌入式硬件·学习·1024程序员节
wanglong371314 小时前
STM32单片机PWM驱动无源蜂鸣器模块C语言程序
stm32·单片机·1024程序员节
不脱发的程序猿21 小时前
如何检测和解决I2C通信死锁
stm32·单片机·嵌入式·1024程序员节