关于RTC引起的待机功耗的问题

转载 2015年07月09日 16:49:20

平台:android4.0
场景:客户测试反应,机器开着wifi的情况下,待机一晚上后电量消耗的很多。
时间:2012.9.5

查看客户提供的log发现,每隔6分钟系统会被唤醒一次。通过dumpsys alarm查看:

ELAPSED_WAKEUP #0: Alarm{41189630 type 2 com.android.phone}
type=2 when=+2m50s514ms repeatInterval=0 count=0
operation=PendingIntent{4118b2f8: PendingIntentRecord{411cd028 com.android.phone broadcastIntent}}

这个ELAPSED_WAKEUP导致了6分钟一次的RTC唤醒。其是通过Phone.apk这个apk调用了frameworks\base\telephony下面的系统api来设置了唤醒的RTC。作用是当gsm或者是cdma的连接失败时,尝试重新去连接网络。
因为Phone.apk这个apk包含了与3G网络相关的调用,无法去除这个apk。

解决办法:
在AlarmManagerService.java中对其做了限制如下:

private int addAlarmLocked(Alarm alarm) {
+ //add by fox 2012.9.5
+ if(alarm.type == 2 && alarm.operation.getTargetPackage().equals(“com.android.phone”)){
+ alarm.type = 3;
+ }
+ //end

将能够唤醒cpu的alarm改成了只在cpu不停掉的情况下才能起作用的alarm。

附上Alarm类型的介绍,转载自:
http://blog.csdn.net/angle_birds/article/details/17301147

enum android_alarm_type {
ANDROID_ALARM_RTC_WAKEUP,
ANDROID_ALARM_RTC,
ANDROID_ALARM_ELAPSED_REALTIME_WAKEUP,
ANDROID_ALARM_ELAPSED_REALTIME,
ANDROID_ALARM_SYSTEMTIME,

ANDROID_ALARM_TYPE_COUNT,

};

用枚举的方式定义了五种类型的Alarm,分别自动赋值0~4,ANDROID_ALARM_TYPE_COUNT=5,表示alarm类型种类数。

_WAKEUP类型表示在触发Alarm时需要唤醒设备,反之则不需要唤醒设备;

ANDROID_ALARM_RTC类型表示在指定的某一时刻触发Alarm;

ANDROID_ALARM_ELAPSED_REALTIME表示在设备启动后,流逝的时间达到总时间之后触发Alarm;

ANDROID_ALARM_SYSTEMTIME类型则表示系统时间;

ANDROID_ALARM_ TYPE_COUNT则是Alram类型的计数。

注意 流逝的时间也包括设备睡眠的时间,流逝时间的计算点从它最后一次启动算起。

参考java代码可以更好的理解:

1、public static final int ELAPSED_REALTIME

当系统进入睡眠状态时,这种类型的闹铃不会唤醒系统。直到系统下次被唤醒才传递它,该闹铃所用的时间是相对时间,是从系统启动后开始计时的,包括睡眠时间,可以通过调用SystemClock.elapsedRealtime()获得。系统值是3 (0x00000003)。

2、 public static final int ELAPSED_REALTIME_WAKEUP

能唤醒系统,用法同ELAPSED_REALTIME,系统值是2 (0x00000002) 。

3、public static final int RTC

当系统进入睡眠状态时,这种类型的闹铃不会唤醒系统。直到系统下次被唤醒才传递它,该闹铃所用的时间是绝对时间,所用时间是UTC时间,可以通过调用 System.currentTimeMillis()获得。系统值是1 (0x00000001) 。

4、public static final int RTC_WAKEUP

能唤醒系统,用法同RTC类型,系统值为 0 (0x00000000) 。

Android中的AlarmManager的使用

1、AlarmManager,顾名思义,就是“提醒”,是Android中常用的一种系统级别的提示服务,在特定的时刻为我们广播一个指定的Intent。简单的说就是我们设定一个时间,然后在该时间到来时,A...

RTC闹钟和ELAPSED_REALTIME最大的差别

AlarmManager.RTC,硬件闹钟,不唤醒手机(也可能是其它设备)休眠;当手机休眠时不发射闹钟。 AlarmManager.RTC_WAKEUP,硬件闹钟,当闹钟发躰时唤醒手机休眠; Al...

RTC自动唤醒

stm8l152进入active halt模式后,可以通过RTC中断唤醒。首先切换为外部低速时钟源,然后对RTC进行一些配置。 void RTC_Config(void)//设置RTC中断 {  ...

Linux下防止用户查看他人的进程-hidepid

Linux kernel 3.2以上,root用户可以设置内核,让普通用户看不到其它用户的进程。适用于有多个用户使用的系统。该功能由内核提供,因此本教程适用于Debian/Ubuntu/RHEL/Ce...

Android系统/proc目录详解

/proc是一个虚拟文件系统,其下面的文件不是真实存在的,不占用实际存储空间。   /proc/cmdline:显示内核启动的命令行。 示例:     /proc/...
  • Anlegor
  • Anlegor
  • 2014年07月31日 14:56
  • 12170

stm32低功耗之待机模式

  • 2016年09月16日 11:22
  • 4.39MB
  • 下载

STM32F103VCT6低功耗测试(待机模式)

STM32F103待机模式测试

stm32低功耗实验之待机模式

一 待机模式简介   在stm32的低功耗模式中,待机模式可以实现系统的最低功耗,在这种模式下,只需要2uA左右的电流。 三 待机唤醒程序分析 实验现象:   将程序下载到开发板上后,...

[FAQ03519] [Power]关于待机平均功耗高的测试以及自行判断注意事项

Platform:MT6573MT6575MT6577MT6589 Branch:GB2ICSICS2JB FAQ Content ...

超低功耗 无线测温模块 无线测温系统, 待机数年无需更换电池

APC300与APC250S无线测温模块均提供了多个通讯频率通道可供选择,用户可以通过RFsensor设置软件自由选择串口速率、收发频率、发射功率、射频速率、发射间隔以及传感器类型等各种参数。...
  • sona69
  • sona69
  • 2015年01月21日 10:20
  • 1870
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:关于RTC引起的待机功耗的问题
举报原因:
原因补充:

(最多只允许输入30个字)