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

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

3天内不再提示

当 CPU 空闲时它都在做什么?

5RJg_mcuworld 来源:未知 作者:杨鑫 2018-03-06 15:43 次阅读

操作系统行为的基本原理是,在任何一个给定的时刻,在一个 CPU 上有且只有一个任务是活动的。但是,如果 CPU 无事可做的时候,又会是什么样的呢?

事实证明,这种情况是非常普遍的,对于绝大多数的个人电脑来说,这确实是一种常态:大量的睡眠进程,它们都在等待某种情况下被唤醒,差不多在 100% 的 CPU 时间中,都处于虚构的“空闲任务”中。事实上,如果一个普通用户的 CPU 处于持续的繁忙中,它可能意味着有一个错误、bug、或者运行了恶意软件。

因为我们不能违反我们的原理,一些任务需要在一个 CPU 上激活。首先是因为,这是一个良好的设计:持续很长时间去遍历内核,检查是否有一个活动任务,这种特殊情况是不明智的做法。最好的设计是没有任何例外的情况。无论何时,你写一个 if 语句,Nyan Cat 就会喵喵喵。其次,我们需要使用空闲的 CPU 去做一些事情,让它们充满活力,你懂得,就是创建天网计划呗。

因此,保持这种设计的连续性,并领先于那些邪恶计划一步,操作系统开发者创建了一个空闲任务,当没有其它任务可做时就调度它去运行。我们可以在 Linux 的 引导过程 中看到,这个空闲任务就是进程 0,它是由计算机打开电源时运行的第一个指令直接派生出来的。它在 rest_init 中初始化,在 init_idle_bootup_task 中初始化空闲调度类scheduling class。

简而言之,Linux 支持像实时进程、普通用户进程等等的不同调度类。当选择一个进程变成活动任务时,这些类按优先级进行查询。通过这种方式,核反应堆的控制代码总是优先于 web 浏览器运行。尽管在通常情况下,这些类返回 NULL,意味着它们没有合适的任务需要去运行 —— 它们总是处于睡眠状态。但是空闲调度类,它是持续运行的,从不会失败:它总是返回空闲任务。

好吧,我们来看一下这个空闲任务到底做了些什么。下面是 cpu_idle_loop,感谢开源能让我们看到它的代码:

cpu_idle_loop

我省略了很多的细节,稍后我们将去了解任务切换,但是,如果你阅读了这些源代码,你就会找到它的要点:由于这里不需要重新调度(即改变活动任务),它一直处于空闲状态。以所经历的时间来计算,这个循环和其它操作系统中它的“堂兄弟们”相比,在计算的历史上它是运行的最多的代码片段。对于 Intel 处理器来说,处于空闲状态意味着运行着一个 halt 指令:

native_halt

hlt 指令停止处理器中的代码执行,并将它置于 halt 的状态。奇怪的是,全世界各地数以百万计的 Intel 类的 CPU 们花费大量的时间让它们处于 halt 的状态,甚至它们在通电的时候也是如此。这并不是高效、节能的做法,这促使芯片制造商们去开发处理器的深度睡眠状态,以带来着更少的功耗和更长休眠时间。内核的 cpuidle 子系统 是这些节能模式能够产生好处的原因。

现在,一旦我们告诉 CPU 去 halt(睡眠)之后,我们需要以某种方式让它醒来。如果你读过 上篇文章《你的操作系统什么时候运行?》 ,你可能会猜到中断会参与其中,而事实确实如此。中断促使 CPU 离开 halt 状态返回到激活状态。因此,将这些拼到一起,下图是当你阅读一个完全呈现的 web 网页时,你的系统主要做的事情:

定时器中断外的其它中断也会使处理器再次发生变化。如果你再次点击一个 web 页面就会产生这种变化,例如:你的鼠标发出一个中断,它的驱动会处理它,并且因为它产生了一个新的输入,突然进程就可运行了。在那个时刻, need_resched() 返回 true,然后空闲任务因你的浏览器而被踢出而终止运行。

如果我们呆呆地看着这篇文章,而不做任何事情。那么随着时间的推移,这个空闲循环就像下图一样:

在这个示例中,由内核计划的定时器中断会每 4 毫秒发生一次。这就是滴答tick周期。也就是说每秒钟将有 250 个滴答,因此,这个滴答速率(频率)是 250 Hz。这是运行在 Intel 处理器上的 Linux 的典型值,而其它操作系统喜欢使用 100 Hz。这是由你构建内核时在 CONFIG_HZ 选项中定义的。

对于一个空闲 CPU 来说,它看起来似乎是个无意义的工作。如果外部世界没有新的输入,在你的笔记本电脑的电池耗尽之前,CPU 将始终处于这种每秒钟被唤醒 250 次的地狱般折磨的小憩中。如果它运行在一个虚拟机中,那我们正在消耗着宿主机 CPU 的性能和宝贵的时钟周期。

在这里的解决方案是 动态滴答,当 CPU 处于空闲状态时,定时器中断被 暂停或重计划,直到内核知道将有事情要做时(例如,一个进程的定时器可能要在 5 秒内过期,因此,我们不能再继续睡眠了),定时器中断才会重新发出。这也被称为无滴答模式。

最后,假设在一个系统中你有一个活动进程,例如,一个长时间运行的 CPU 密集型任务。那样几乎就和一个空闲系统是相同的:这些示意图仍然是相同的,只是将空闲任务替换为这个进程,并且相应的描述也是准确的。在那种情况下,每 4 毫秒去中断一次任务仍然是无意义的:它只是操作系统的性能抖动,甚至会使你的工作变得更慢而已。Linux 也可以在这种单一进程的场景中停止这种固定速率的滴答,这被称为 自适应滴答 模式。最终,这种固定速率的滴答可能会 完全消失。

对于阅读一篇文章来说,CPU 基本是无事可做的。内核的这种空闲行为是操作系统难题的一个重要部分,并且它与我们看到的其它情况非常相似,因此,这将帮助我们理解一个运行中的内核。

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

    关注

    68

    文章

    10854

    浏览量

    211585

原文标题:当 CPU 空闲时它都在做什么?

文章出处:【微信号:mcuworld,微信公众号:嵌入式资讯精选】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    MAX3590 RS422 芯片 RO输出 起初的空闲时刻为低电平 怎么检测起始位

    如下图串口助手发 55 55 66 55 从上到下波形 依次是 max3490 的 A端 B端 RO端 RO端 空闲为低电平 且起始位也没有了,送到fpga端的RX引脚,无法检测起始位,数据接收都是
    发表于 12-14 17:58

    AMC7836的SDO在空闲时为高阻,请问是否建议作上拉或者下拉?

    问题1:AMC7836的SDO在空闲时为高阻,请问是否建议作上拉或者下拉?(我看手册中典型电路好像没有上拉)然后,请问如果不作上下拉对芯片正常SPI通信是否存在较大风险? 问题2:请问
    发表于 12-05 08:20

    为什么蓝色通道的SDO空闲时会有1V左右的跟随CLK的波形?

    》, 自己用示波器测试到的时序如下; 模拟输入口的电压是固定的2.46V, 但是每次读到的值都不同; 程序如下: 问题: 1. 为什么蓝色通道的SDO空闲时会有1V左右的跟随CLK的波形? 2. 软件读不到值
    发表于 12-04 08:16

    JAVA应用CPU跳点自动DUMP工具

    背景 在做系统监控时,CPU的使用率是一个关键的指标,反映了系统的性能稳定性以及是否存在异常情况,能帮助我们了解系统的负载情况。通过监控CPU使用率,可以判断系统是否正常运行或者是否
    的头像 发表于 08-05 17:48 523次阅读

    ESP8266 UART0交换到GPIO13/15后,重启进不去系统怎么解决?

    目前使用一个 8266 的 GPIO 13 和 15 连接到另外一个芯片的 TX 和 RX 由于另外一个芯片的 RX 和 TX 在空闲时是高电平的状态 8266 重启的时候,就会检测到 15
    发表于 07-12 06:26

    如何将tc275的cpu0设置为空闲模式?

    如何将 tc275 的 cpu0 设置为空闲模式? 我试过英飞凌示例,但不起作用。
    发表于 07-04 07:12

    请问如何实现ESP32 uart的接收空闲中断?

    我当前使用的是ESP-IDF.uart接收不定长的数据时,希望通过空闲中断或者事件的方式来结束一帧uart数据的接收。我看了
    发表于 06-05 07:55

    串口的空闲字符是用来激活空闲中断的吗?

    网上搜到的内容也比较少,这个东西不知道怎么用,最近学串口,所以想要了解一下, 在手册中是这么写的: \" 空闲字符可理解为整个帧周期内电平均为“ 1”(停止位的电平也是“ 1”),该字符
    发表于 05-11 07:28

    I2C组成原理及通讯模式

    SDA与SCL都外接了上拉电阻,所以SDA空闲时刻输出的永远是高电平,它对外设也有一定要求,要求外设的输出模式也是开漏输出,因为这跟它本身的电路实现有关,若两个电路接口模式不一则是无法完成正常通讯的。
    发表于 04-28 17:33 5924次阅读
    I2C组成原理及通讯模式

    Linux是做什么用的?

    Linux是做什么用的?Linux是一种开源的操作系统,广泛用于服务器、嵌入式设备和个人电脑等领域。具有以下特点和用途: Linux是做什么用的? 1、服务器操作系统:Linux在服务器领域非常
    发表于 04-28 15:40

    请问ucos libMicrium.a文件是做什么的?

    目前在做ucos cyclone上移植,发现官方例子里面用到了libgen目录下libMicrium.a文件。请问这个文件是做什么的? 这部分有源代码吗?
    发表于 04-15 08:07

    深入探索芯片内部电路结构

    SDA和SCL都是双向线路,都通过一个电流源或上拉电阻连接到正的电源电压。总线空闲时,这两条线路都是高电平,连接到总线的器件输出级必须是漏极开路或集电极开路才能执行线与的功能。
    发表于 04-10 10:13 367次阅读
    深入探索芯片内部电路结构

    STM32G0空闲中断异常,且DMA接收不到数据是怎么回事?

    板子:STM32G0B1 方式:UART2空闲中断+DMA接收 问题:烧写程序后,板子一上电就自动进入空闲中断,但此时没有数据发送,采用上位机发送数据时,可以进入空闲中断,但DMA接
    发表于 03-26 07:03

    如何在Aurix TC399控制器中测量空闲时间?

    我想测量一下微控制器的空闲时间(Aurix TC399)。 你能帮我解决这个问题吗? 我们需要监控任何寄存器吗?或者该怎么做? 期待你的回复。
    发表于 01-25 07:31

    边缘AI到底是什么?能做什么

    边缘AI到底是什么?能做什么? 边缘人工智能是一种新兴的人工智能技术,它将人工智能的计算和决策能力移动到离数据生成源和终端设备更近的边缘节点上。与传统的云计算方式相比,边缘AI将计算和决策推向网络
    的头像 发表于 01-11 14:44 1290次阅读