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

    文章

    1446

    浏览量

    83825
  • 中断
    +关注

    关注

    5

    文章

    884

    浏览量

    41029
  • TCP通信
    +关注

    关注

    0

    文章

    145

    浏览量

    4138

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

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

收藏 人收藏

    评论

    相关推荐

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

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

    labview的工程师在做什么

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

    如何知道进程运行在哪个 CPU 内核上?

    (名为"prog")目前在CPU 内核 10 上运行着。如果该过程没有被固定,PSR 列会根据内核可能调度进程到不同
    发表于 10-24 15:30

    kernel 26的进程调度

    2.4进程调度只设置了一个进程就绪队列,这样有的进程用完了自己时间片以后还要呆在就绪进程队列里面。这样这个
    发表于 08-05 07:14

    干货分享:基于嵌入式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

    鸿蒙内核源码分析(进程管理篇):进程内核的资源管理单元

    ,实现了进程之间的切换和通信,帮助用户管理业务程序流程。这样用户可以将更多的精力投入到业务功能的实现中。OpenHarmony内核中的进程采用抢占式调度机制,支持时间片轮转
    发表于 11-24 11:23

    嵌入式工程师必会的 Linux 进程调度所有知识点

    是面向服务器。此配置下,CPU 在计算时,输入键盘之后,因为没有抢占,可能需要一段时间等待键盘输入的进程才会被 CPU 调度。CONFIG_PREEMPT : 打开抢占,一般多用于手
    发表于 08-01 07:00

    内核态是如何对task进行调度

    调度器在runqueue里的算法是如何去实现的?内核态是如何对task进行调度
    发表于 12-24 07:59

    uClinux进程调度器的实现分析

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

    当 CPU 空闲时它都在做什么

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

    Linux进程调度时机概念分析

    Linux在众多进程中是怎么进行调度的,这个牵涉到Linux进程调度时机的概念,由Linux内核中Schedule()的函数来决定是否要进行
    的头像 发表于 01-23 17:14 2546次阅读
    Linux<b class='flag-5'>进程</b><b class='flag-5'>调度</b>时机概念分析

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

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