news 2026/3/6 18:23:14

【计算机基础】-11-RT Thread:哪些临界资源需要通过关闭中断进行保护?举例说明

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【计算机基础】-11-RT Thread:哪些临界资源需要通过关闭中断进行保护?举例说明

RT-Thread 实时操作系统(RTOS)中,临界资源(Critical Resources)是指那些在多任务或中断环境下不能被并发访问的共享资源。若多个线程或中断同时修改这些资源,会导致数据不一致、系统崩溃等严重问题。

为了保护这些资源,RT-Thread 提供了多种同步机制(如信号量、互斥量、关中断等)。其中,关闭中断(Disable Interrupt)是最底层、最高效的保护手段,但仅适用于非常短的代码段,且通常用于内核内部或驱动开发


一、为什么需要“关中断”?

在 RT-Thread 中:

  • 线程切换可能由调度器中断(如 SysTick)触发;
  • 如果某段代码(包括内核代码)正在修改一个全局数据结构(如就绪队列),此时发生中断并触发调度,另一个线程可能访问该未完成修改的数据竞态条件(Race Condition)。

关中断 = 禁止所有可屏蔽中断 + 禁止线程切换,确保临界区原子执行。

备注:

内核中,有大量不同线程可以共享的全局数据结构,这些数据结构都不是线程安全的,线程切换或创建或删除线程时,需要操作这些数据结构!!!


二、哪些临界资源需要通过“关中断”保护?(典型例子)

✅ 1.线程就绪队列rt_thread_priority_table

  • 作用:按优先级组织所有就绪线程
  • 为什么需要关中断
    • 当一个线程被唤醒(如延时结束),需将其插入就绪队列;
    • 若此时发生中断并触发调度调度器可能读取到不完整或损坏的链表
  • 保护方式
    rt_base_t level = rt_hw_interrupt_disable(); rt_list_insert_after(&rt_thread_priority_table[prio], &thread->tlist); rt_hw_interrupt_enable(level);

✅ 2.系统节拍(OS Tick)相关变量

  • 变量示例rt_tick(系统时钟计数器)
  • 为什么需要关中断
    • rt_tickSysTick 中断中递增;
    • 用户线程也可能读取rt_tick(如rt_tick_get());
    • 读取过程中被中断打断,可能读到中间状态的值(尤其在32 位系统读 64 位变量时)。
  • 保护方式
    rt_base_t level = rt_hw_interrupt_disable(); tick = rt_tick; rt_hw_interrupt_enable(level);

✅ 3.内核对象链表(如设备列表、定时器列表)

  • 例子rt_object_information中的对象链表
  • 场景:注册/注销设备、创建/删除定时器时,需修改全局链表。
  • 风险:若在链表操作中途被中断打断,链表指针可能断裂。
  • 保护:关中断后操作链表。

✅ 4.调度器状态与当前线程指针rt_current_thread

  • 作用:指向当前正在运行的线程。
  • 为什么保护
    • 线程切换时会修改rt_current_thread
    • 若在修改过程中被更高优先级中断打断,可能导致调度混乱。
  • 实际实现:RT-Thread 的rt_schedule()内部会关中断。

✅ 5.硬件寄存器(在驱动中)

  • 场景:某些外设寄存器必须原子地写入多个寄存器的多个位,以保障硬件时序(如配置 UART 波特率 + 数据位 + 停止位)。
  • 风险若写入中途被中断打断,寄存器处于非法状态。
  • 保护
    rt_base_t level = rt_hw_interrupt_disable(); UART->CR1 = config1; UART->CR2 = config2; // 必须连续写入 rt_hw_interrupt_enable(level);

✅ 6.内核标志位或状态机

  • 例子rt_interrupt_nest中断嵌套计数)、rt_scheduler_lock_nest(调度器锁计数)
  • 特点:频繁被中断和线程访问,必须原子操作。
  • 保护:关中断。

三、关中断的 API(RT-Thread)

// 关闭中断,返回当前中断状态 rt_base_t rt_hw_interrupt_disable(void); // 恢复中断(传入之前保存的状态) void rt_hw_interrupt_enable(rt_base_t level);

⚠️注意

  • 关中断时间必须极短(通常 < 几微秒),否则影响实时性;
  • 不能用于用户应用层,仅限内核或驱动;
  • 用户应优先使用信号量rt_sem_take)或互斥量rt_mutex_take)。

四、为什么不总是用“关中断”?

方法优点缺点适用场景
关中断最快、最可靠阻塞所有中断,影响实时性内核关键路径、极短临界区
信号量/互斥量允许中断响应,支持优先级继承有调度开销用户线程间同步
调度器锁rt_enter_critical不关中断,只禁止调度不能防中断干扰仅需防线程切换的场景

📌 RT-Thread 内核大量使用“关中断” + “调度器锁”组合,实现高效安全的同步。


五、总结:需要关中断保护的临界资源

资源类型具体例子保护原因
调度相关就绪队列、rt_current_thread防止调度器看到不一致状态
时钟相关rt_tick防止读取/更新时被中断打断
内核对象设备列表、定时器链表链表操作非原子
硬件寄存器外设控制寄存器需原子写入多位
内核状态变量中断嵌套计数、调度锁计数高频并发访问

核心原则

凡是在“中断上下文”和“线程上下文”中都会被访问的全局变量或数据结构,且操作不可分割(非原子),就必须用关中断保护。

理解这一点,是编写稳定、可靠 RTOS 驱动和内核模块的关键!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/4 6:28:22

python微信小程序的高校自习室在线预约系统

目录高校自习室在线预约系统的摘要开发技术路线结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;高校自习室在线预约系统的摘要 该系统基于Python开发&#xff0c;结合微信小程序前端&#xff0c;旨在解决高校自习室资源分配不均、预约…

作者头像 李华
网站建设 2026/2/28 18:36:19

视频大文件在JAVA网页上传中怎么解决?

我&#xff0c;一个负责过30企业级文件传输项目的上海IT人&#xff0c;想和你聊聊这个100G大文件传输的落地方案 先抛结论&#xff1a;这事儿能成&#xff0c;但得用“定制化研发成熟组件适配”的组合拳。作为公司项目负责人&#xff0c;我刚带着团队啃完类似需求&#xff08;…

作者头像 李华
网站建设 2026/3/2 6:45:41

计算机毕业设计springboot博客系统的设计与实现 基于SpringBoot框架的个人内容发布平台的设计与实现 基于Java Web的在线日志分享系统的设计与开发

计算机毕业设计springboot博客系统的设计与实现12xosn18 &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。在信息爆炸的时代&#xff0c;博客作为个人表达和信息分享的重要平台&am…

作者头像 李华
网站建设 2026/3/6 8:58:50

政务CMS如何用TinyMCE实现PDF表单数据到Word的映射?

VUE后台管理中使用富文本编辑器导入word 文档进行编辑 前言 最近因业务需求在项目中嵌入了tinymce这个编辑器&#xff0c;用于满足平台给用户编辑各类新闻内容什么的业务需求&#xff0c;前后也花了不少时间体验和对比了市面上各类开源编辑器&#xff0c;直接将新闻部门的工作…

作者头像 李华
网站建设 2026/3/1 14:28:15

C# 实现与三菱 PLC 以太网通讯:打造功能强大的上位机程序

C#与三菱PLC以太网通讯程序上位机源码 通过3E帧SLMP /MC协议与三菱FX5U/Q系列PLC通讯 1.该程序可以与FX5U/Q系列PLC以太网通讯&#xff0c;根据3E帧报文写了一个类库&#xff0c;可以读写各种类型和区域变量。 2.支持单个变量读写和数组类型批量读写。 3.可以实时检测网络通断…

作者头像 李华
网站建设 2026/3/3 9:03:18

好写作AI:开题答辩前夜,如何用AI把“还行”变成“必过”

导语&#xff1a;当导师说出“题目再想想”时&#xff0c;你的开题进度条就卡在了99%每个研究生都经历过选题的“死亡循环”&#xff1a;第一版题目&#xff1a;宏大如国家社科基金&#xff08;导师批&#xff1a;太空泛&#xff09;第二版题目&#xff1a;具体到某个县城案例&…

作者头像 李华