FreeRTOS学习笔记--临界段代码处关闭中断

一、临界段代码

大家在学习FreeRTOS时对临界段代码都不陌生,引用野火实战指南的一句话:“临界段代码是指不能被中断的代码”。实际上,不只在进行全局操作的代码需要对中断进行管控,在某些严格时序上也需要对中断进行管控。例如A任务需要利用IIC、SPI、并口等协议进行数据交互时,往往一个中断的到来就会使得时序紊乱,而导致通信失败。所以我们在执行这类代码时,需要将不必要的中断进行屏蔽,这就涉及到部分M4内核的中断管理。

二、Cortex-M4中断管理

ARM公司在设计M4内核时就配置了255个异常,其中又分为异常和中断。M4异常相关结构框图
实际上,区分异常和中断比较简单,MCU提出的中断申请叫做异常(系统异常),若是外部端口或者芯片设计商挂载的外设提出的中断申请则成为中断。
为了方便管理,ARM固化了部分异常。而芯片设计商根据已有的嵌套中断向量表(NVIC)并结合芯片使用的实际情况对中断进行裁剪后固化嵌套中断向量表(NVIC)。STM32F4xx部分中断向量表
ARM在设计NVIC时,也配套了优先级屏蔽寄存器(PRIMASK),该寄存器存放在内核寄存器中在这里插入图片描述
PRIMASK寄存器介绍
该寄存器用于关闭除了NMI和HardFulat异常以外的所有中断,也可以使用错误屏蔽寄存器(FAULTMASK)来屏蔽除了NMI以外的所有中断。但这样的代价比较大,若在任务中出现异常时,系统将无法进行补救,那么系统会出现跑飞等异常现象。

在FreeRTOS中,经常使用基本优先级屏蔽寄存器,该寄存器用于定义可屏蔽的最高的优先级。BASEPRI寄存器介绍
这是由于在Cortex-M4中定义优先级越小优先级越高,这与优先级分组管理是相关的。于是在使用中,当我们需要屏蔽优先级不高于5的中断时,可以向该寄存器写入5。
实际上芯片生产商在拿到内核后,会对优先级组(NVIC_IPRx)进行裁剪,又由于上述说的优先级规则,所以优先级组是先裁剪低位,例如STM32F4xx系列单片机是裁剪掉了低4位,只用高4位来配置抢占、次要优先级。所以我们在屏蔽优先级为5以下的中断时需要进行位移操作。

#ifdef __NVIC_PRIO_BITS
	#define configPRIO_BITS       		__NVIC_PRIO_BITS
#else
	#define configPRIO_BITS       		4                  
#endif

#define configLIBRARY_LOWEST_INTERRUPT_PRIORITY				15                      //中断最低优先级
#define configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY		5                       //系统可管理的最高中断优先级
#defin
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值