news 2026/5/9 3:53:04

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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为例)

汇编指令:

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

CMSIS函数(C语言):

void__disable_irq(void);// 置位 PRIMASKvoid__enable_irq(void);// 清零 PRIMASKvoid__set_FAULTMASK(uint32_tvalue);uint32_t__get_FAULTMASK(void);void__set_BASEPRI(uint32_tvalue);uint32_t__get_BASEPRI(void);

典型使用场景

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

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/4 5:24:42

小猫影视 - 影视播放器

链接&#xff1a;https://pan.quark.cn/s/6eb332dc88cb支持平台&#xff1a;#Windows #macOS #Linux #Android一款影视播放器&#xff0c;支持视频点播&#xff08;VOD&#xff09;和JavaScript扩展源。可以通过简单的操作快速找到并播放自己喜欢的影视内容。支持多种视频格式&…

作者头像 李华
网站建设 2026/5/8 0:13:16

哔哩下载姬DownKyi:专业B站视频管理工具深度体验

哔哩下载姬DownKyi&#xff1a;专业B站视频管理工具深度体验 【免费下载链接】downkyi 哔哩下载姬downkyi&#xff0c;哔哩哔哩网站视频下载工具&#xff0c;支持批量下载&#xff0c;支持8K、HDR、杜比视界&#xff0c;提供工具箱&#xff08;音视频提取、去水印等&#xff09…

作者头像 李华
网站建设 2026/4/30 22:46:11

Shell脚本部署——8day

Shell脚本部署课程目标掌握shell脚本的思路完成shell脚本的编写课程实验shell脚本的思路shell脚本的编写课堂引入部署项目中&#xff0c;有很多都是固定的模式与内容&#xff0c;所有的东西都需要人工去操作的话&#xff0c;成本就比较高&#xff0c;也比较麻烦&#xff0c;能不…

作者头像 李华
网站建设 2026/4/30 23:50:48

AI 自动生成报表

1. AI 生成图表 向上汇报经常需要制作图表&#xff0c;如果没有顺手的工具&#xff0c;可能需要花费大量的时间消耗在报表的制作上。随着AI的迅猛发展&#xff0c;我们通过一个简单的对话来低成本实现报表的生成。 2. 使用到的工具 MCP 平台&#xff1a;https://www.modelscope…

作者头像 李华
网站建设 2026/4/30 22:46:18

Unity学习笔记(十二)碰撞中的刚体和碰撞器

碰撞产生的必要条件 两个物体都有碰撞器&#xff0c;至少有一个物体有刚体刚体1.它就是模拟力的作用2.Mass质量 默认为KG 质量越大 阻性越大3.Drag空气阻力 根据力移动对象时影响对象的空气阻力大小。影响移动&#xff0c;0表示没有空气阻力4.Use Gravity 是否受重力影响5.Angu…

作者头像 李华
网站建设 2026/5/6 21:09:42

微服务架构下的全方位测试策略

微服务架构的测试挑战与机遇随着企业数字化转型加速&#xff0c;微服务架构因其灵活性、可扩展性和技术异构性成为主流。据预测&#xff0c;到2025年&#xff0c;超70%的新建系统将采用此架构。然而&#xff0c;分布式系统带来的服务依赖复杂、部署频繁、故障隔离困难等挑战&am…

作者头像 李华