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,浮点运算是通过软件库模拟的,效率很低。

相关推荐
宵时待雨1 小时前
STM32笔记归纳8:时钟
笔记·stm32·单片机·嵌入式硬件
JJRainbow2 小时前
SN75176 芯片设计RS-232 转 RS-485 通信模块设计原理图
stm32·单片机·嵌入式硬件·fpga开发·硬件工程
不做无法实现的梦~2 小时前
PX4编译环境配置和qgc配置安装教程(2)
linux·stm32
花月mmc2 小时前
CanMV K230 波形识别——整体部署(4)
人工智能·python·嵌入式硬件·深度学习·信号处理
宁静致远20212 小时前
STM32模拟IIC读取PCF8563
stm32·单片机·嵌入式硬件
三佛科技-134163842123 小时前
宠物洗澡打泡机方案,宠物泡泡机MCU方案开发设计分享
单片机·嵌入式硬件·物联网·智能家居·pcb工艺·宠物
芯岭技术3 小时前
低成本315/433M接收芯片 XL420 SOP8封装,支持 1527 等常见 OOK编码
单片机·嵌入式硬件
听风吹雨yu3 小时前
STM32F407-MD5码计算/Digest认证计算
stm32·单片机·嵌入式硬件
yugi9878383 小时前
RN8302B电表芯片驱动开发指南(基于SPI通信)
驱动开发·单片机·嵌入式硬件
youcans_4 小时前
【STM32-MBD】(15)Simulink 模型开发之三相互补 PWM
stm32·单片机·嵌入式硬件·matlab·foc