ARM 架构中的 PRIMASK、FAULTMAST、BASEPRI 寄存器

ARM 架构中的 PRIMASK、FAULTMAST、BASEPRI 寄存器

这三个是 ARM Cortex-M 系列处理器 中的关键系统异常屏蔽寄存器,用于控制中断和异常的行为。下面分别解释:


1. PRIMASK(优先级屏蔽寄存器)

  • 作用:临时屏蔽所有可配置优先级的中断(即除NMI、HardFault外的异常)。
  • 位宽:1位(只有最低位有效)。
    • 0:允许所有中断(默认)。
    • 1:屏蔽所有可屏蔽中断(进入临界区)。
  • 使用场景
    • 保护临界代码,防止被中断打断。
    • 通常用 __disable_irq()__enable_irq() CMSIS函数操作。
  • 注意:不影响NMI、HardFault等不可屏蔽异常。

2. FAULTMASK(故障屏蔽寄存器)

  • 作用 :屏蔽除NMI外的所有异常(包括可配置优先级的中断和HardFault)。
  • 位宽:1位(只有最低位有效)。
    • 0:允许所有异常(默认)。
    • 1:屏蔽所有异常(仅NMI能响应)。
  • 使用场景
    • 用于故障处理程序(如HardFault)中,防止其他异常干扰。
    • 可以屏蔽HardFault自身,使当前故障升级为NMI。
  • 注意:通常只有操作系统或错误恢复代码使用。

3. BASEPRI(基础优先级寄存器)

  • 作用 :屏蔽优先级低于或等于某个阈值的中断。
  • 位宽:取决于具体Cortex-M内核(如M3/M4为8位,支持256级优先级)。
    • 0:关闭屏蔽功能(默认)。
    • 非0:屏蔽所有优先级值大于等于该数值的中断(数值越大,逻辑优先级越低)。
  • 使用场景
    • 选择性屏蔽低优先级中断,允许高优先级中断响应。
    • 更精细的临界区保护。
  • 示例
    • 设置 BASEPRI = 0x20,则屏蔽优先级 ≥ 0x20(数字越大优先级越低)的中断。
    • 允许优先级更高的中断(数值 < 0x20)继续响应。

三者的比较

寄存器 屏蔽对象 是否屏蔽NMI/HardFault 粒度
PRIMASK 所有可屏蔽中断 全有或全无
FAULTMASK 所有中断 + HardFault 仅NMI可响应 全有或全无
BASEPRI 优先级低于等于某阈值的中断 优先级阈值

操作方式(以Cortex-M为例)

汇编指令:

assembly 复制代码
CPSID I   ; 置位PRIMASK(关中断)
CPSIE I   ; 清零PRIMASK(开中断)
CPSID F   ; 置位FAULTMASK
CPSIE F   ; 清零FAULTMASK
MSR BASEPRI, r0 ; 设置BASEPRI
MRS r0, BASEPRI ; 读取BASEPRI

CMSIS函数(C语言):

c 复制代码
void __disable_irq(void);    // 置位 PRIMASK
void __enable_irq(void);     // 清零 PRIMASK
void __set_FAULTMASK(uint32_t value);
uint32_t __get_FAULTMASK(void);
void __set_BASEPRI(uint32_t value);
uint32_t __get_BASEPRI(void);

典型使用场景

  1. 实时任务保护 :使用 PRIMASKBASEPRI 保护短暂临界区。
  2. 错误处理 :在 HardFault 处理中操作 FAULTMASK 避免嵌套异常。
  3. 任务调度 :RTOS 在切换上下文时用 BASEPRI 屏蔽低优先级中断。

总结:这三个寄存器是 Cortex-M 异常/中断管理的关键,PRIMASK 用于全局中断开关,FAULTMASK 用于故障处理时的强屏蔽,BASEPRI 提供基于优先级的精细中断控制。

相关推荐
XD7429716362 小时前
001. MSP430G2553 入门总述:从零开始学习这颗单片机
单片机·嵌入式硬件·学习·嵌入式·msp430g2553
CinzWS2 小时前
A53 FPGA原型验证:从RTL到可运行系统的挑战
arm开发·嵌入式·芯片验证·原型验证·a53
AI服务老曹2 小时前
深度解析:支持 GB28181/RTSP 及异构计算(X86/ARM+GPU/NPU)的 AI 视频管理平台架构方案(附源码交付与 Docker 部署)
arm开发·人工智能·音视频
珠海西格电力2 小时前
零碳园区管理系统“云-边-端”架构协同的价值及具体案例
大数据·数据库·人工智能·架构·能源
ai产品老杨3 小时前
深度架构解析:基于异构计算与 Docker 容器化的 AI 视频管理平台实战
人工智能·docker·架构
2302_813806223 小时前
基础环境篇 – 交叉编译环境搭建与NFS服务配置
arm开发
极创信息3 小时前
信创领域五种主流CPU架构(X86 / ARM / RISC-V / MIPS / LoongArch)
java·arm开发·数据库·spring boot·mysql·软件工程·risc-v
Freak嵌入式3 小时前
亲测可用!可本地部署的 MicroPython 开源仿真器
ide·驱动开发·嵌入式·仿真·micropython·upypi
沐风清扬3 小时前
复杂业务系统架构:CQRS 读写分离与 ES/RabbitMQ 基础指南
微服务·架构
AI服务老曹4 小时前
节省95%开发成本:支持X86/ARM与GPU/NPU异构部署的AI视频云网关架构深度解析
arm开发·人工智能·音视频