RTOS共享资源保护-优先级反转与解决策略

RTOS 中的优先级反转与解决策略

概述

上节讲述了可以使用二值信号量实现任务-任务之间的共享资源的保护。二值信号量的确完成了保护共享资源的任务,但在一些情况下,这种策略会带来副作用-即优先级反转。

优先级反转是如何产生的

理想情况下,按照我们的设计,优先级高的任务总是应该被优先地运行,也包括优先地获取各种资源。但很遗憾,优先级主要影响获取 CPU 这种关键资源的优先顺序,对于其他共享资源,优先级其实并不能按照我们想的那样,让优先级高的任务优先获得共享资源。

请考虑下述三个任务的一个运行过程:

1) 优先级为1的任务1先运行(即此时在占用CPU),其想获得“LED灯”这个资源,因此通过信号量发起了申请,得到了LED灯这个资源(*此时二值信号量的“当前消息数量”由1减为0*)。

2)优先级为2的任务2在某个时刻进入就绪态,因为其优先级比1高,因此抢占了任务1的CPU资源,进入运行态,同时任务1将暂存在就绪列表等待获取CPU资源再次执行。

3)优先级为3的任务3在某个时刻进入就绪态了,因为其优先级比2高,因此抢占了任务2的CPU资源,进入运行态,同时任务2将暂存在就绪列表等待获取CPU资源再次执行。

4)在任务3执行过程中,其也想获得“LED灯”这个资源,因此它也向管理LED灯资源的信号量发起获取请求,但很遗憾,此时二值信号量中的“****当前消息数量”为0,****因此任务3不得不因为申请失败

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
RTOS任务的优先级可以根据任务的重要性和紧急程度来确定。一般来说,优先级较高的任务会在优先级较低的任务之前执行。在FreeRTOS中,任务的优先级是通过一个整数值来表示的,数值越小表示优先级越高。任务的优先级可以在任务创建时指定,也可以在运行时动态改变。 确定任务的优先级时,需要考虑以下几个因素: 1. 任务的功能和重要性:根据任务的功能和对系统的贡献程度,可以给予较高的优先级。例如,对于实时性要求较高的任务,可以给予较高的优先级。 2. 任务的依赖关系:如果一个任务依赖于另一个任务的结果或资源,那么它的优先级应该高于被依赖任务的优先级,以确保依赖任务能够及时完成。 3. 任务的执行时间:如果一个任务需要较长的执行时间,那么它的优先级应该较低,以避免饥饿其他任务的执行时间。 在确定任务的优先级时,还需要考虑任务间的相互作用和竞争条件。例如,如果一个任务持有一个共享资源的锁,那么其他需要访问该资源的任务的优先级应该高于持有锁的任务,以避免资源竞争和死锁的发生。 总之,确定RTOS任务的优先级需要综合考虑任务的功能、重要性、依赖关系和执行时间等因素,以确保系统的实时性和稳定性。 #### 引用[.reference_title] - *1* *3* [RTOS介绍------一、任务的状态,优先级,调度](https://blog.csdn.net/cesare20/article/details/122526113)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [嵌入式技术栈之RTOS优先级翻转问题](https://blog.csdn.net/dop102/article/details/124121357)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

物联网老王

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值