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

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

3天内不再提示

当没有进程可调度时内核在做什么呢?

dyquk4xk2p3d 来源:卯时卯刻 2023-05-08 10:02 次阅读

内核的主要职责是进程调度,比如当一个进程阻塞时,它会调度另外一个进程来执行。 那当没有进程可以调度时,内核在做什么呢? 此时,内核会进入到idle状态,其大致逻辑是:

while(1) {
while(!need_resched()) {// 判断是否有其他进程可执行
asm("hlt");// 如果没有,则执行hlt指令
}
schedule_idle();// 如果有,则转而执行其他进程
}
由上可见,当没有其他进程可执行时,idle循环里会一直执行hlt汇编指令,该指令的作用是暂停cpu的执行,直到有中断等情况发生时。

当有中断发生时,比如内核接收到了新的tcp包,此时某个进程会从阻塞状态转变为可执行状态。

当中断逻辑执行完毕后,上面的idle循环也会从halt状态退出,继续循环执行need_resched()函数,此时该函数返回true,表示有其他进程可执行,这样该逻辑会退出hlt循环,继续执行schedule_idle()函数,schedule_idle()函数的作用是从idle进程切换到目标进程,进而执行其对应的代码。

这样,内核就从idle状态,退回到了正常的进程调度状态。

当其他所有进程又都执行完毕,又都进入到了阻塞状态,导致内核没有进程可调度时,内核逻辑又会切换到上述idle循环代码,从schedule_idle()函数后继续执行,即进入下一次循环。

上面的idle循环在内核中也是以一个进程来表示的,它的pid是0,它的名字是swapper。






审核编辑:刘清

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

    关注

    35

    文章

    1471

    浏览量

    85289
  • 中断
    +关注

    关注

    5

    文章

    895

    浏览量

    41395
  • TCP通信
    +关注

    关注

    0

    文章

    146

    浏览量

    4217

原文标题:当没有进程可调度时,内核在做什么呢?

文章出处:【微信号:良许Linux,微信公众号:良许Linux】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    Linux内核进程管理与调度:策略优化与实践分析

    与之相关的优先级,如果有多个可执行的进程等待CPU资源,那么具有更高优先级的进程将优先被调度执行。今天就给大家讲解一下Linux内核中的进程
    发表于 05-08 09:42 1111次阅读
    Linux<b class='flag-5'>内核</b><b class='flag-5'>进程</b>管理与<b class='flag-5'>调度</b>:策略优化与实践分析

    深入探讨Linux的进程调度

    Linux操作系统作为一个开源且广泛应用的操作系统,其内核设计包含了许多核心功能,而进程调度器(Scheduler)就是其中一个至关重要的模块。进程
    的头像 发表于 08-13 13:36 895次阅读
    深入探讨Linux的<b class='flag-5'>进程</b><b class='flag-5'>调度</b>器

    labview的工程师在做什么

    会labview的工程师在做什么??要找工作了,想给自己一个定位,想问下大家,我本专业是机械的,硕士做了两年关于labview控制的数据采集系统,想了解下大家的现状!交流交流哈!
    发表于 03-30 09:39

    干货分享:基于嵌入式Linux中进程调度实现方法

    。处于该状态的进程通过其他进程的信号才能被唤醒。 2.2 调度方式Linux 中的每个进程都分配有一个相对独立的虚拟地址空间。该虚存空间分为两部分:用户空间包含了
    发表于 12-10 14:17

    【HarmonyOS】鸿蒙内核源码分析(调度机制篇)

    的不同,Task是调度层面的概念,线程是进程层面概念。比如 main() 函数中首个函数 OsSetMainTask(); 就是设置启动任务,但此时啥都还没开始,Kprocess 进程
    发表于 10-14 14:00

    鸿蒙内核源码分析(调度机制篇):Task是如何被调度执行的

    (); 就是设置启动任务,但此时啥都还没开始,Kprocess 进程都没创建,怎么会有大家一般意义上所理解的线程。狭义上的后续有 鸿蒙内核源码分析(启动过程篇) 来说明。不知道大家
    发表于 11-23 10:53

    鸿蒙内核源码分析(调度队列篇):进程和Task的就绪队列对调度的作用

    OsTaskPriQueueTop查最高优先级任务OsDequeEmptySchedMap进程出列[td]OsGetTopTask获取被调度选择的task鸿蒙内核进程和线程各有32个就
    发表于 11-23 11:09

    Linux进程调度的原理解析

    进程调度依据 调度程序运行时,要在所有可运行状态的进程中选择最值得运行的进程投入运行。选择进程
    发表于 11-02 11:01 1次下载

    uClinux进程调度器的实现分析

    分享到:标签:uClinux 调度策略 进程调度器 摘要:针对操作系统中进程调度机制,依次对其调度
    发表于 11-06 14:30 0次下载

    CPU 空闲时它都在做什么

    人在空闲的时候免不了昏昏欲睡那cpu空闲时在做什么
    的头像 发表于 03-06 15:43 4972次阅读
    <b class='flag-5'>当</b> CPU 空闲时它都<b class='flag-5'>在做什么</b>?

    Linux 进程调度浅析

    的优先级,如果有多个进程同时处于可执行状态,那么谁优先级高谁就去执行,没有什么好纠结的了。那么,进程的优先级该如何确定?有两种方式:由用户程序指定、由
    发表于 04-02 14:40 329次阅读

    linux进程调度浅析

    进程定义优先级。定义了进程的优先级,如果有多个进程同时处于可执行状态,那么谁优先级高谁就去执行,没有什么好纠结的了。那么,进程的优先级该如何
    发表于 04-02 14:45 336次阅读

    鸿蒙内核源码分析:task是内核调度的单元

    从系统的角度看,线程是竞争系统资源的最小运行单元。线程可以使用或等待CPU、使用内存空间等系统资源,并独立于其它线程运行。 鸿蒙内核每个进程内的线程独立运行、独立调度,当前进程内线程
    发表于 11-23 15:51 22次下载
    鸿蒙<b class='flag-5'>内核</b>源码分析:task是<b class='flag-5'>内核</b><b class='flag-5'>调度</b>的单元

    鸿蒙内核源码分析:进程和Task的就绪队列对调度的作用

    鸿蒙内核代码中有两个源文件是关于队列的,一个是用于调度的队列,另一个是用于线程间通讯的IPC队列。 鸿蒙内核进程和线程各有32个就绪队列,进程
    发表于 11-23 15:48 31次下载
    鸿蒙<b class='flag-5'>内核</b>源码分析:<b class='flag-5'>进程</b>和Task的就绪队列对<b class='flag-5'>调度</b>的作用

    带大家看看Linux内核如何调度进程

    部分,打开调度器的黑匣子,来看看Linux内核如何调度进程的。实际上,进程调度器主要做两件事:选
    的头像 发表于 07-26 15:14 1997次阅读