1284_FreeRTOS任务优先级获取实现分析

全部学习汇总: GreyZhang/g_FreeRTOS: learning notes about FreeRTOS. (github.com)

今天来分析一下FreeRTOS中的优先级获取函数的实现,涉及到2个接口,一个是uxTaskPriorityGet(),另一个是它的中断安全版本uxTaskPriorityGetFromISR()。

这一个接口的实现还是很简单的,在这个实现中直接是关掉了中断,然后去获取任务的优先级。为什么需要关中断呢,我觉得这里主要的原因是xTask可能是NULL,此时要求的是获取当前的任务优先级。如果是产生了中断,这个数据可能会被篡改。

类似的宏实现前面看过好几个了,如果传入的句柄为空的时候其实是处理当前任务的一个凭据。而任务句柄本身是可以转成TCB指针类型的,这样就可以直接获取到优先级的属性。

这个是中断安全的版本,跟前面的这个接口实现在主要的处理过程上差不多。不同点在于,既然是在ISR中,那么是已经有一个中断发生了。这个时候,首先进行了中断优先级的合理性确认,但是这个接口在我现在的配置中无效。接着,不是关中断,取而代之的是修改了中断的掩码防止意料之外的中断发生。在优先级属性数值的获取上跟前面没有大的差异。

这个是掩码修改的实现,修改的时候先做了原始掩码的备份,处理完之后保存原始的掩码。

上一步保存的掩码成了这里掩码恢复的一个依据。

再次复习一下这个basepri寄存器的作用,这个寄存器设置了系统中的最小优先级。ARM中的优先级数值越小优先级越高,因此这个这个数值设置为80的时候,数字上大于等于80的中断就不能够发生了。FreeRTOS能够管理的ISR的优先级应该是较低的一段,因此应该是设置上超过数值80的,或者至少是等于80的。

这样,任务优先级的获取基本就分析完了。后面的接口分析,改天继续。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值