中断屏蔽实现方法-ARM内核

文章目录

    • 前言
    • 寄存器定义
      • [SHPR-System Handler Priority Registers](#SHPR-System Handler Priority Registers)
      • [BASEPRI-Base Priority Mask Register](#BASEPRI-Base Priority Mask Register)
      • [PRIMASK-Priority Mask Register](#PRIMASK-Priority Mask Register)
      • [FAULTMASK-Fault Mask Register](#FAULTMASK-Fault Mask Register)
    • 总结

前言

之前一直搞不清OS中屏蔽中断和开中断是如何实现的,导致部分中断没有在OS中配置而引发了一些临界区的问题,本文介绍ARM内核手册中的相关寄存器的定义

寄存器定义

先来认识下几个相关的寄存器

SHPR-System Handler Priority Registers

对应系统中断的优先级设置,有三个寄存器



此处的优先级值越小,优先级越高,需要注意的是,如果只有0-15个优先级,则取的是高4位,低四位一直为0且写值是无效的

BASEPRI-Base Priority Mask Register


该寄存器用来屏蔽优先级等于或低于设置值的中断

例如,配置为0x30时,则0x30-0xff优先级的中断会被屏蔽

如果只用了高4位 ,则屏蔽优先级0x3-0xf的中断

PRIMASK-Priority Mask Register

当设置为1时,屏蔽所有可配置中断(除了NMI和Hardfault

FAULTMASK-Fault Mask Register

当设置为1时,屏蔽除了NMI之外的所有中断

总结

在ARM汇编语言中,经常会看到cpsid和cpsie,其实cpsid对应的就是关中断 ,cpsie对应的是开中断 ,其后一般会跟i或者f或者if,i表示的就是PRIMASK ,f表示的是FAULTMASK ,cpsid if实际就是将PRIMASK和FAULTMASK都置1,cpsie if则是将他俩都置0,不过这两种方式都是比较粗暴的,OS中一般不这么使用

相关推荐
ShiMetaPi2 小时前
GM-3568JHF丨ARM+FPGA异构开发板系列教程:外设教程 04 WIFI
网络·arm开发·fpga开发·智能路由器·fpga
切糕师学AI3 小时前
ARM 架构中的浮点寄存器(Floating-Point Registers)
arm开发·寄存器·浮点寄存器
再遇当年5 小时前
因为研究平台arm,RK3588交叉编译误把我笔记本X86平台的/x86_64-linux-gnu文件删除,导致联想拯救者笔记本中的ubuntu系统损坏
linux·arm开发·ros·gnu·交叉编译·x86
切糕师学AI15 小时前
ARM 架构中的 CONTROL 寄存器
arm开发·硬件架构·嵌入式·芯片·寄存器
richxu202510011 天前
嵌入式学习之路>单片机核心原理篇>(14) ARM 架构
arm开发·单片机·学习
切糕师学AI1 天前
ARM 汇编指令:LDR
汇编·arm开发
亿道电子Emdoor2 天前
【Arm】解决Keil MDK报错提示找不到编译器路径的问题
arm开发
cooldream20092 天前
RISC-V 全景解析:在 x86 与 ARM 之间,理解开放指令集的真正价值
arm开发·risc-v
赞哥哥s3 天前
Autosar Xcp配置-支持CANFD 64byte标定更改-基于ETAS软件
can·autosar·xcp
切糕师学AI3 天前
ARM 架构中的数据内存屏障指令 DMB
arm开发·架构·指令·内存屏障