Android系统电源管理及省电机制

Android系统电源管理及省电机制

移动设备因为其有限的电池,省电技巧成为Android开发者的一项必备知识。本文不探讨怎样从应用层面省电,因为这些内容已经有很成熟的总结。本文拟介绍Android系统的电源管理机制。因为笔者对于Linux的浅薄知识,如有错漏,请不吝指出。

一、常见电源管理机制(休眠)

在x86机器中,存在两种电源管理方法:

  • APM(Advanced Power Management,高级电源管理)
  • ACPI(Advanced Configuration and Power Interface ,高级配置和电源接口)

这两个标准不能同时允许在Linux上面,默认情况下,Linux运行ACPI.需要注意,apm和acpi是互相冲突的两个模块,用户在同一时间内只能加载其中之一

APM基本已经淘汰

ACPI主要执行者是操作系统,可以单独控制外设。

ACPI主要分成6种状态,分别是S0到S5,它们代表的含义分别是:

  • S0:实际上这就是我们平常的工作状态,所有设备全开,功耗一般会超过80W;

  • S1:也称为POS(Power on Suspend),这时除了通过CPU时钟控制器将CPU关闭之外,其他的部件仍然正常工作,这时的功耗一般在30W以下;(其实有些CPU降温软件就是利用这种工作原理)

  • S2:这时CPU处于停止运作状态,总线时钟也被关闭,但其余的设备仍然运转;

  • S3:这就是我们熟悉的STR(Suspend to RAM),这时的功耗不超过10W;

  • S4:也称为STD(Suspend to Disk),这时系统主电源关闭,硬盘存储S4前数据信息,所以S4是比S3更省电状态.

  • S5:这种状态是最干脆的,就是连电源在内的所有设备全部关闭,即关机(shutdown),功耗为0。

ACPI的省电主要就是依靠 S3,S4,S5状态。

二、Android系统的休眠机制

Android系统是基于Linux的,但是其因为移动设备的独特性又有所不同,Android在kernel中支持的休眠模式有S0,S1,S3,S4,但是这个是需要硬件配合来实现的,标准的手机Android系统,只支持S0,S3。

即休眠状态实质上就是挂起到内存。

1. 两个处理器芯片

Android手机有两个处理器:

  • Application Processor(AP):AP是ARM架构的处理器,用于运行Linux+Android系统;
  • Baseband Processor(BP):BP用于运行实时操作系统(RTOS),通讯协议栈运行于BP的RTOS之上。

在休眠状态下,BP仍旧会收取数据,如有必要会唤醒AP。

2. Android的休眠流程

Android 在Linux的基础上引进了新的状态:预挂起(earlysuspend),同时引进了唤醒锁机制。

其流程如下:

(1)一段时间内无活动,系统发起挂起检查。

(2)进入earlysuspend状态(关闭屏幕、背光、重力感应)

(3)检查wake lock是否全部释放。

(4)如果全部释放,冻结进程挂起外设。

(5)进入深度睡眠,等待外终端唤醒。

注:Android4.4以后和Linux保持统一,实现了AutoSleep机制,本质区别不大,算是Linux和Android的一种相互妥协。

3. 颇有争议的Opportunistic suspend

Android的休眠机制简单粗暴,主要遵守两条原则:

  • 系统没有事情的时候就睡。
  • 不管三七二十一,休眠的时候休眠所有外设。

这种机制Linux社区是饱受争议的,主要有以下几项质疑:

  1. 系统没有事情做事很不好判断的,可能会频繁的触发休眠流程。
  2. 只有一个设备在做事的时候,其他设备也得陪着工作吗?

注:Linux社区是有一套“多样的系统组件单独控制”的电源管理方案(如Linux kernel的Dynamic PM)

4. 在休眠状态下保持被唤醒的机会:AlarmManager

AlarmManager 是Android 系统封装的用于管理 RTC 的模块,RTC (Real Time Clock) 是一个独立的硬件时钟,可以在 CPU 休眠时正常运行,在预设的时间到达时,通过中断唤醒 CPU。

(注:用Timer保持消息推送长连接是非常2B的)

三、Android在省电机制上做的努力

1. 传感器批处理(Sensor batching)

Android 4.4 为了省电引入了一项新的技术: Sensor batching。这不是一项独特的技术,实际上很多其他OS也引入了该项技术,它是什么意思呢?

该项技术允许设备积累一段时间的数据,而后一次性“上报”,引入这种技术后,设备不必频繁的唤醒CPU,从而节省了电量。

2. JobScheduler

为了更有效率的利用电池,Android 5.0 引入了 JobScheduler API。 应用可以将一些实时性不强的任务(如)采用JobScheduler来做,Android系统会根据系统情况在合适的时机进行调度执行。

3. Doze机制

随着时间流逝,Google渐渐意识到,无良的开发者是不可靠的,依靠他们遵守可有可无的“规范”是不可能的。

于是Google在Android 6.0 引入了一种新的省电机制,即Doze机制,中文可以翻译成“对齐唤醒机制”。

当设备处于未充电状态、屏幕熄灭一段时间后就会进入Doze状态。在这种状态下,Android系统会限制使用访问网络和CPU。

每过一段时间,Android系统会退出Doze状态,让应用执行之前被延迟的活动。在这个执行窗口,Android系统会执行所有的异步操作,时钟(Alarm),同时允许APP访问网络。

在执行窗口的末期,Android系统又把所有的时钟、网络请求、异步任务给挂起。再次进入Doze状态。

随着时间进行,Doze的状态时间会逐渐延长。



作者:Mr云台
链接:https://www.jianshu.com/p/96ada6d1546a
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值