Android Power Management

Overview

The above picture shows the overall architecture design of Android power management module. Android implements a very simple power management mechanism. Currently it only supports set screen on/off, screen backlight on/off, keyboard backlight on/off, button backlight on/off and adjust screen brightness. It does not support Sleep or Standby mode to fully use CPU’s capability.

The power management module has three channels to receive input: RPC call, Batter state change event and Power Setting change event. It communicated with other modules through either broadcasting intent or directly API call. The module also provide reboot and shutdown service. When battery is lower than thredshold, it will automatically shutdown the device.

The module will automatically set screen dim and off according to whether any user activity happens or not. The full state machine is shown as follows:

Detail

PowerManagerService.java(./frameworks/base/services/java/com/android/server/PowerManagerService.java) is the core service. It calls Power.java(./frameworks/base/core/java/android/os/Power.java) to do the real work.

PowerManager.java is the proxy(代理人) to RPC call PowerManagerService.java.

Power.java communicates with the low level through JNI.

android_os_Power.cpp(./frameworks/base/core/jni/android_os_Power.cpp) is the JNI native implementation for Power.java. It calls Power.c(./hardware/libhardware_legacy/power/power.c) to do the real work.

Power.c controls the power device driver through read/write the following sys files.

"/sys/android_power/acquire_partial_wake_lock",

"/sys/android_power/acquire_full_wake_lock",

"/sys/android_power/release_wake_lock",

"/sys/android_power/request_state"

"/sys/android_power/auto_off_timeout",

"/sys/class/leds/lcd-backlight/brightness",

"/sys/class/leds/button-backlight/brightness",

"/sys/class/leds/keyboard-backlight/brightness"

BatteryService.java registers itself as a UEvent observer for the path “/sys/class/power_supply”. If anything is changed in this path, it gets current state through JNI and then broadcasts ACTION_BATTERY_CHANGED intent.

com_android_server_BatteryService.cpp is the JNI native implementation for BatteryService.java. It gets current battery state through reading from the following files:

"/sys/class/power_supply/ac/online"

"/sys/class/power_supply/usb/online"

"/sys/class/power_supply/battery/status"

"/sys/class/power_supply/battery/health"

"/sys/class/power_supply/battery/present"

"/sys/class/power_supply/battery/capacity"

"/sys/class/power_supply/battery/batt_vol"

"/sys/class/power_supply/battery/batt_temp"

"/sys/class/power_supply/battery/technology"

How to use

To call power module in app, the following is the sample code:

PowerManager pm = (PowerManager)mContext.getSystemService(Context.POWER_SERVICE);

PowerManager.WakeLock wl = pm.newWakeLock(

PowerManager.SCREEN_DIM_WAKE_LOCK

| PowerManager.ON_AFTER_RELEASE,

TAG);

wl.acquire();

// ...

wl.release();

更多相关文章

  1. Talking about Android(安卓)Message Queue
  2. android远程绑定与本地绑定区别
  3. Talking about Android Message Queue

随机推荐

  1. Android之activity跳转显示桌面及切换黑
  2. Android(安卓)删除指定文件代码
  3. Android(安卓)安卓使用MediaPlayer播放列
  4. Android支持展开/收缩功能的列表控件
  5. Android(安卓)CheckBox example
  6. Android实现DES对字符串加密
  7. Android之拖拉功能
  8. Android安装使用过程
  9. Android(安卓)SDK 历史版本
  10. android ndk 常用宏定义