本文转载自:http://www.wowotech.net/pm_subsystem/generic_pm_architecture.htmlhtml
这里的Generic PM,是蜗蜗本身起的名字,指Linux系统中那些常规的电源管理手段,包括关机(Power off)、待机(Standby or Hibernate)、重启(Reboot)等。这些手段是在嵌入式Linux普及以前的PC或者服务器时代使用的。在那个计算机科学的蛮荒时代,人类在摩尔定律的刺激下,孜孜追求的是计算机的计算能力、处理性能,所以并不特别关心Power消耗。ubuntu
在这种背景下发展出来的Linux电源管理机制,都是粗放的、静态的、被动的,具体请参考下面的介绍。服务器
Linux操做系统中,和Generic PM有关的操做以下面图片:架构
该图片截取自蜗蜗使用的“Linux ubuntu 2.6.32-38”系统,共有3部分组成:框架
第1部分是系统关机、重启等操做的界面,共包含Hibernate、Restart、Shutdown三个操做选项;性能
二、3部分是“电源管理属性”设置,所谓的电源管理属性,能够配置系统在不一样供电模式下(如AC Power、Battery等,因为蜗蜗的机器是PC机,所以就没有电池供电的选项),处于Inactive状态多久后,系统关闭Display,或者进入Sleep状态。字体
本文将会围绕上面提到的各个名词,讲述它们的意义、在内核中的实现方式。开始以前,先解释一下这些词汇的意义。操作系统
Shutdown,很好理解,就是关机的意思。同时意味着再也不使用计算机。.net
Restart,也很好理解,就是重启系统的意思。重启的过程,再也不使用计算机。翻译
Hibernate,可翻译为冬眠。
听到“冬眠”这个词,您是否眼前一亮?蜗蜗在“Linux电源管理(1)_总体架构”中解释电源管理的概念的时候,提到过,动物冬眠就是大天然所设计的电源管理方式的一种。在动物界,冬眠是指动物们(一般针对温血动物)经过下降体温的方式而进入的相似昏睡的生理状态,在这种状态下,须要消耗的能量较少,从而能够达到省电(能量)的目的。
而在计算机界,设计师们也借用了“冬眠”的概念,在不须要使用计算机时,将它当前的全部现场(执行的程序、显示器显示的图像、正在播放的声音等)保存到一些断电不会丢失的存储器中(如硬盘中),而后将计算机关闭。从新开启后,系统会从存储器中将关闭前的现场读取出来并恢复,此时从使用者的角度看,计算机就像没有关闭过同样。
若是把计算机界的“冬眠”搬到动物界,会是这样的场景:一只恐龙,迈着八字步,吃着香蕉,晃晃悠悠的走在树林中。而后,无聊的孙猴子来了,喊了一声“定!”,恐龙就定在那里了。再而后,一万年过去了,无聊的孙猴子又来了,喊了一声“动!”,恐龙继续迈着八字步,吃着香蕉,就像什么事情都没有发生同样。
Sleep,睡眠。这个词也是从生物界学来的。想象一下“睡眠”和“冬眠”的区别?“睡眠”睡的轻,随时均可以醒来。在计算机中,Hibernate须要把现场保存到断电不丢失的存储器中,并在醒来的时候读回来,这些可能须要较长的时间(由于断电不丢失存储器的访问速度都比较慢)。若是想快点,就把现场保存在内存中就能够了,这就是Sleep。不过这是要付出代价的,内存要保持供电,这就要消耗能量,鱼与熊掌不可兼得啊!
Auto Sleep,查看上面图片第3个部分,能够设置系统“处于Inactive状态多久后,自动进入Sleep状态”。好比我正在写这篇文章,而后被老婆喊去跪搓衣板了,一跪两个小时。这两个小时内,计算机再也不被使用,若是不进入Sleep状态,将会消耗不少能量。为了不这无谓的消耗,可让系统在符合条件时(如20分钟不使用),自动睡下去。
Auto put display to Sleep,原理相似,只是操做的对象是Display(显示器等)。
注:
不知读者有没有注意到,蜗蜗在解释上面的词汇时,一直在用红色字体强调“计算机再也不使用”。这就是Generic PM和Runtime PM的本质区别,即,在使用者的主观意愿上,是否须要暂停使用计算机(哪怕短短的一段时间)。
这也是Generic PM在传统的计算机操做系统中被普遍使用的缘由,由于那个时候对计算机的使用大可能是主动方式。而对当前的移动互联来讲,就很是不合时宜了,由于人们须要移动设备实时在线、实时接收被动事件(如来电),也就不可能主观地暂停使用(哪怕短短的一段时间)。这种最终需求的差别,会致使在软件设计上有很大的差异,正由于如此,Runtime PM的出现和尽快成熟,才显得格外重要。
在介绍完Generic PM的基本概念后,咱们来看一下它在Linux内核中的总体实现,并抽象出简单的软件架构,以便再后续的文章中,对Generic PM的主要组成部分进行更为细致的分析。具体以下:
根据上面的描述可知,Generic PM主要处理关机、重启、冬眠(Hibernate)、睡眠(Sleep,在Kernel中也称做Suspend)。在内核中,大体能够分为三个软件层次:
API Layer,用于向用户空间提供接口,其中关机和重启的接口形式是系统调用(在新的内核中,关机接口还有一种新方式,具体讲到的时候再说),Hibernate和Suspend的接口形式是sysfs。
PM Core,位于kernel/power/目录下,主要处理和硬件无关的核心逻辑。
PM Driver,分为两个部分,一是体系结构无关的Driver,提供Driver框架(Framework)。另外一部分是具体的体系结构相关的Driver,这也是电源管理驱动开发须要涉及到的内容(图中红色边框的模块)。
另外,电源管理是一个系统级的模块,于是会涉及到设备模型、进程管理等等方方面面的内容,咱们能够在后续具体的分析过程当中,细细品味。