0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

具有固定优先级调度程序RTOS的优先级倒置

星星科技指导员 来源:嵌入式计算设计 作者:Johan Kraft 2022-06-22 15:45 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

具有固定优先级调度程序的 RTOS 的核心思想是高优先级任务应该在低优先级任务之前调度。如有必要,RTOS 甚至可以抢占正在运行的任务,迫使它让 CPU 执行更高优先级的任务。然而,作为开发人员,您必须注意可能导致较高优先级任务必须等待较低优先级任务的编程缺陷——这种情况称为优先级倒置。

优先级反转可以与互斥体、消息队列或其他类型的同步对象一起发生。描述问题的最佳方式可能是通过一个示例来逐步说明。

在下面的时间线图中,使用 Tracealyzer 捕获,我们有一个低优先级任务(绿色)正在执行。它需要一个二进制信号量来保护某些临界区并继续在临界区内执行代码。当高优先级任务(红色)进入就绪状态时,RTOS 抢占绿色任务并让红色运行。红色任务尝试获取相同的二进制信号量,但由于低优先级绿色任务持有它而被阻止。

到目前为止,一切都很好——这是预期的行为。一般来说,绿色任务现在会运行并快速释放信号量,此时它再次被抢占,红色任务可以获取信号量并继续。然而,这一次发生了反转。出于某种原因,可能是定时等待已过期,中等优先级(橙色)任务已进入就绪状态并被允许在绿色任务之前执行。由于橙色任务不知道有争议的信号量,它很高兴地运行完成。只有这样,绿色任务才会最终运行,以便它可以释放信号量并将执行权交给红色的高优先级任务。

pYYBAGKyyLGAOwYtAAI9Uvf_ze8142.png

因此,高优先级任务被阻塞,必须等待不确定的时间,而中等优先级任务运行完成。这就是工作中的优先级倒置。

重要的是要意识到这里涉及的三项任务基本上是无能为力的。他们没有人可以做任何事情来避免倒置,至少在没有 RTOS 的支持的情况下是这样。幸运的是,这种支持在许多 RTOS 中以具有优先级继承的互斥锁的形式提供。互斥量(互斥的缩写)是一种用于保护共享资源的信号量。优先级继承意味着如果一个高优先级的任务在试图获得一个低优先级任务当前持有的互斥锁时阻塞,那么持有该互斥锁的任务的优先级会暂时提高到被阻塞任务的优先级。在我们的场景中,当红色任务被阻塞时,绿色任务将被提升为红色优先级,从而有效地阻止了橙色任务的运行。

优先级继承并不能真正治愈优先级倒置,它只是在某些情况下将其影响最小化。硬实时应用程序仍应仔细设计,以便一开始就不会发生优先级反转。

通常,尽可能避免阻塞共享资源。例如,如果您的任务将数据写入消息队列(可能已满),您可以改为使用足够大但未满的队列,作为额外的预防措施,以非阻塞方式写入并检查任何失败写入的返回值。而不是使用分散在代码中的多个关键部分(共享互斥锁),您可以创建一个“服务器”任务,该任务执行对资源的所有直接操作,并使用消息队列从“客户端”任务中获取请求,在非-阻塞方式。服务器可以通过请求中指定的其他消息队列发送任何回复,这些消息队列由客户端任务拥有。

审核编辑:郭婷

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • cpu
    cpu
    +关注

    关注

    68

    文章

    11221

    浏览量

    222997
  • 服务器
    +关注

    关注

    13

    文章

    10096

    浏览量

    90904
  • RTOS
    +关注

    关注

    25

    文章

    863

    浏览量

    122619
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    CS32L010系列能否支持串口的发送和接收中断单独配置?不同中断的中断优先级如何设置?

    1、串口能否配置成阻塞式发送和中断式接收。 2、不同中断的中断优先级如何设置?我在开启中断函数代码中看到说中断优先级配置需要先调用NVIC_PriorityGroupConfig()函数,但此函数无定义,全局搜索不到。
    发表于 12-10 18:46

    抢占优先级和子优先级

    关于抢占优先级和子优先级: 1)具有高抢占式优先级的中断可以在具有低抢占式优先级的中断服务
    发表于 12-03 07:11

    电能质量在线监测装置的暂态数据补传的优先级如何在实际应用中进行动态调整?

    电能质量在线监测装置的暂态数据补传优先级在实际应用中通过 事件驱动、主站指令、资源状态感知和动态策略调整 等多层机制实现灵活调控,确保关键数据的实时性与可靠性。以下是具体实现方式和典型场景的动态调整
    的头像 发表于 11-06 14:10 103次阅读

    电能质量在线监测装置的暂态数据补传的优先级是怎样的?

    电能质量在线监测装置的暂态数据补传优先级设计遵循 事件驱动、主站指令优先、资源动态分配 的原则,结合行业标准和设备机制,形成以下多层级优先级体系: 一、最高优先级:紧急事件驱动补传 1
    的头像 发表于 11-06 14:02 97次阅读

    FreeRTOS任务调度优先级问题

    都有容错,但是心里没底,想向大家了解一下实际工作中有没有遇到到类似的问题,如果有又是怎么解决的呢? 另外有前辈可以分享一下任务的优先级在实际项目中该基于什么原则来划分呢?
    发表于 11-06 02:18

    优先级线程无法调度怎么解决?

    1,设置了3,5,6,8几个优先级,设备在现场正常运行了一年多后,显示、前端、后端这3个低优先级线程异常了,表现为屏幕不动,前端采集数据没有变化等,其他高优先级的线程如通讯,按键都能正常运行,通讯有喂狗操作,停止通讯,会看门狗复
    发表于 09-25 07:33

    什么是RTOS中的优先级反转

    当一个高优先级任务正在等待一个资源,但一个低优先级任务正在持有它,一个中等优先级任务继续在中间运行时,就会发生优先级反转——阻止低优先级任务
    的头像 发表于 09-09 14:50 781次阅读

    求助,关于MS51设置中断优先级问题求解

    我确实发现在库代码和 TRM 之间设置中断优先级有一些差异,如下图所示。 Could you check what's wrong with me?
    发表于 08-25 07:01

    揭秘!基于RT-Thread探究“优先级反转”下的任务调度究竟是什么样的?| 技术集结

    本文将基于RT-Thread,结合RT-Trace调试器细化到实际任务调度的粒度,来调试并逐步讲解“优先级反转”的调度和运行逻辑。如果对RT-Trace感兴趣的可以看这篇文章:国产嵌入式调试器之光
    的头像 发表于 08-17 10:07 2820次阅读
    揭秘!基于RT-Thread探究“<b class='flag-5'>优先级</b>反转”下的任务<b class='flag-5'>调度</b>究竟是什么样的?| 技术集结

    请问STM32的内部Flash操作是不是优先级最高?

    STM32的内部Flash操作是不是优先级最高?目前在内部Flash的单独一页存储了数据,发现在进行页擦除的时候正常工作的定时器中断无法进入了
    发表于 08-13 07:03

    TLe9893怎么调整外设的中断优先级

    你好林工,我该怎么调整外设的中断优先级?是否可以通过工具调整?默认设置下,是不是Brdv的在中断优先级高于T20和can?
    发表于 08-01 06:20

    请问C0系列单片机中断优先级只有4吗?

    C0系列单片机中断优先级只有4?C071在配置的时候只能配置0-3
    发表于 07-23 08:00

    ADL5308可以通过软件和硬件配置的参数,配置的优先级是什么?

    你好,麻烦问一下ADL5308可以通过软件和硬件配置的参数,配置的优先级是什么?有没有更详细的寄存器配置手册,截距配置的步进是多少?
    发表于 06-10 06:39

    CyU3PDebugPrint的最高优先级和最低优先级是什么?

    [i]CyU3PDebugPrint的最高优先级和最低优先级是什么?
    发表于 05-13 08:22

    配电柜—断电危机?配电柜故障排查优先级指南

    在排查配电柜故障过程中,合理安排排查优先级至关重要。下面聊一下如何科学合理安排配电柜故障排查优先级顺序。
    的头像 发表于 03-06 18:55 826次阅读
    配电柜—断电危机?配电柜故障排查<b class='flag-5'>优先级</b>指南