1/*
2 * Copyright (C) 2017 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 *      http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17syntax = "proto3";
18
19package android.service.power;
20
21option java_multiple_files = true;
22option java_outer_classname = "PowerServiceProto";
23
24import "frameworks/base/core/proto/android/os/looper.proto";
25import "frameworks/base/core/proto/android/os/worksource.proto";
26import "frameworks/base/core/proto/android/service/wirelesschargerdetector.proto";
27
28message PowerServiceDumpProto {
29    message ConstantsProto {
30        bool is_no_cached_wake_locks = 1;
31    }
32    message ActiveWakeLocksProto {
33        bool is_cpu = 1;
34        bool is_screen_bright = 2;
35        bool is_screen_dim = 3;
36        bool is_button_bright = 4;
37        bool is_proximity_screen_off = 5;
38        // only set if already awake
39        bool is_stay_awake = 6;
40        bool is_doze = 7;
41        bool is_draw = 8;
42    }
43    message UserActivityProto {
44        bool is_screen_bright = 1;
45        bool is_screen_dim = 2;
46        bool is_screen_dream = 3;
47    }
48    message UidProto {
49        // Enum values gotten from ActivityManager.java
50        enum ProcessState {
51            // Process is a persistent system process.
52            PROCESS_STATE_PERSISTENT = 0;
53            // Process is a persistent system process and is doing UI.
54            PROCESS_STATE_PERSISTENT_UI = 1;
55            // Process is hosting the current top activities. Note that this
56            // covers all activities that are visible to the user.
57            PROCESS_STATE_TOP = 2;
58            // Process is hosting a foreground service due to a system binding.
59            PROCESS_STATE_BOUND_FOREGROUND_SERVICE = 3;
60            // Process is hosting a foreground service.
61            PROCESS_STATE_FOREGROUND_SERVICE = 4;
62            // Same as {@link #PROCESS_STATE_TOP} but while device is sleeping.
63            PROCESS_STATE_TOP_SLEEPING = 5;
64            // Process is important to the user, and something they are aware of.
65            PROCESS_STATE_IMPORTANT_FOREGROUND = 6;
66            // Process is important to the user, but not something they are aware of.
67            PROCESS_STATE_IMPORTANT_BACKGROUND = 7;
68            // Process is in the background running a backup/restore operation.
69            PROCESS_STATE_BACKUP = 8;
70            // Process is in the background, but it can't restore its state so
71            // we want to try to avoid killing it.
72            PROCESS_STATE_HEAVY_WEIGHT = 9;
73            // Process is in the background running a service.
74            PROCESS_STATE_SERVICE = 10;
75            // Process is in the background running a receiver.
76            PROCESS_STATE_RECEIVER = 11;
77            // Process is in the background but hosts the home activity.
78            PROCESS_STATE_HOME = 12;
79            // Process is in the background but hosts the last shown activity.
80            PROCESS_STATE_LAST_ACTIVITY = 13;
81            // Process is being cached for later use and contains activities.
82            PROCESS_STATE_CACHED_ACTIVITY = 14;
83            // Process is being cached for later use and is a client of another
84            // cached process that contains activities.
85            PROCESS_STATE_CACHED_ACTIVITY_CLIENT = 15;
86            // Process is being cached for later use and is empty.
87            PROCESS_STATE_CACHED_EMPTY = 16;
88            // Process does not exist.
89            PROCESS_STATE_NONEXISTENT = 17;
90        }
91        int32 uid = 1;
92        string uid_string = 2;
93        bool is_active = 3;
94        int32 num_wake_locks = 4;
95        bool is_process_state_unknown = 5;
96        ProcessState process_state = 6;
97    }
98
99    // Enum values gotten from PowerManagerInternal.java
100    enum Wakefulness {
101        WAKEFULNESS_ASLEEP = 0;
102        WAKEFULNESS_AWAKE = 1;
103        WAKEFULNESS_DREAMING = 2;
104        WAKEFULNESS_DOZING = 3;
105        WAKEFULNESS_UNKNOWN = 4;
106    }
107    // Enum values gotten from BatteryManager.java
108    enum PlugType {
109        PLUG_TYPE_NONE = 0;
110        PLUG_TYPE_PLUGGED_AC = 1;
111        PLUG_TYPE_PLUGGED_USB = 2;
112        PLUG_TYPE_PLUGGED_WIRELESS = 4;
113    }
114    // Enum values gotten from Intent.java
115    enum DockState {
116        DOCK_STATE_UNDOCKED = 0;
117        DOCK_STATE_DESK = 1;
118        DOCK_STATE_CAR = 2;
119        DOCK_STATE_LE_DESK = 3;
120        DOCK_STATE_HE_DESK = 4;
121    }
122
123    ConstantsProto constants = 1;
124    // A bitfield that indicates what parts of the power state have
125    // changed and need to be recalculated.
126    int32 dirty = 2;
127    // Indicates whether the device is awake or asleep or somewhere in between.
128    Wakefulness wakefulness = 3;
129    bool is_wakefulness_changing = 4;
130    // True if the device is plugged into a power source.
131    bool is_powered = 5;
132    // The current plug type
133    PlugType plug_type = 6;
134    // The current battery level percentage.
135    int32 battery_level = 7;
136    // The battery level percentage at the time the dream started.
137    int32 battery_level_when_dream_started = 8;
138    // The current dock state.
139    DockState dock_state = 9;
140    // True if the device should stay on.
141    bool is_stay_on = 10;
142    // True if the proximity sensor reads a positive result.
143    bool is_proximity_positive = 11;
144    // True if boot completed occurred.  We keep the screen on until this happens.
145    bool is_boot_completed = 12;
146    // True if systemReady() has been called.
147    bool is_system_ready = 13;
148    // True if auto-suspend mode is enabled.
149    bool is_hal_auto_suspend_mode_enabled = 14;
150    // True if interactive mode is enabled.
151    bool is_hal_auto_interactive_mode_enabled = 15;
152    // Summarizes the state of all active wakelocks.
153    ActiveWakeLocksProto active_wake_locks = 16;
154    // Have we scheduled a message to check for long wake locks?  This is when
155    // we will check. (In milliseconds timestamp)
156    int64 notify_long_scheduled_ms = 17;
157    // Last time we checked for long wake locks. (In milliseconds timestamp)
158    int64 notify_long_dispatched_ms = 18;
159    // The time we decided to do next long check. (In milliseconds timestamp)
160    int64 notify_long_next_check_ms = 19;
161    // Summarizes the effect of the user activity timer.
162    UserActivityProto user_activity = 20;
163    // If true, instructs the display controller to wait for the proximity
164    // sensor to go negative before turning the screen on.
165    bool is_request_wait_for_negative_proximity = 21;
166    // True if MSG_SANDMAN has been scheduled.
167    bool is_sandman_scheduled = 22;
168    // True if the sandman has just been summoned for the first time since entering
169    // the dreaming or dozing state.  Indicates whether a new dream should begin.
170    bool is_sandman_summoned = 23;
171    // If true, the device is in low power mode.
172    bool is_low_power_mode_enabled = 24;
173    // True if the battery level is currently considered low.
174    bool is_battery_level_low = 25;
175    // True if we are currently in light device idle mode.
176    bool is_light_device_idle_mode = 26;
177    // True if we are currently in device idle mode.
178    bool is_device_idle_mode = 27;
179    // Set of app ids that we will always respect the wake locks for.
180    repeated int32 device_idle_whitelist = 28;
181    // Set of app ids that are temporarily allowed to acquire wakelocks due to
182    // high-pri message
183    repeated int32 device_idle_temp_whitelist = 29;
184    // Timestamp of the last time the device was awoken.
185    int64 last_wake_time_ms = 30;
186    // Timestamp of the last time the device was put to sleep.
187    int64 last_sleep_time_ms = 31;
188    // Timestamp of the last call to user activity.
189    int64 last_user_activity_time_ms = 32;
190    int64 last_user_activity_time_no_change_lights_ms = 33;
191    // Timestamp of last interactive power hint.
192    int64 last_interactive_power_hint_time_ms = 34;
193    // Timestamp of the last screen brightness boost.
194    int64 last_screen_brightness_boost_time_ms = 35;
195    // True if screen brightness boost is in progress.
196    bool is_screen_brightness_boost_in_progress = 36;
197    // True if the display power state has been fully applied, which means the
198    // display is actually on or actually off or whatever was requested.
199    bool is_display_ready = 37;
200    // True if the wake lock suspend blocker has been acquired.
201    bool is_holding_wake_lock_suspend_blocker = 38;
202    // The suspend blocker used to keep the CPU alive when the display is on, the
203    // display is getting ready or there is user activity (in which case the
204    // display must be on).
205    bool is_holding_display_suspend_blocker = 39;
206    // Settings and configuration
207    PowerServiceSettingsAndConfigurationDumpProto settings_and_configuration = 40;
208    // Sleep timeout in ms
209    sint32 sleep_timeout_ms = 41;
210    // Screen off timeout in ms
211    int32 screen_off_timeout_ms = 42;
212    // Screen dim duration in ms
213    int32 screen_dim_duration_ms = 43;
214    // We are currently in the middle of a batch change of uids.
215    bool are_uids_changing = 44;
216    // Some uids have actually changed while mUidsChanging was true.
217    bool are_uids_changed = 45;
218    // List of UIDs and their states
219    repeated UidProto uids = 46;
220    android.os.LooperProto looper = 47;
221    // List of all wake locks acquired by applications.
222    repeated WakeLockProto wake_locks = 48;
223    // List of all suspend blockers.
224    repeated SuspendBlockerProto suspend_blockers = 49;
225    WirelessChargerDetectorProto wireless_charger_detector = 50;
226}
227
228message SuspendBlockerProto {
229    string name = 1;
230    int32 reference_count = 2;
231}
232
233message WakeLockProto {
234    message WakeLockFlagsProto {
235        // Turn the screen on when the wake lock is acquired.
236        bool is_acquire_causes_wakeup = 1;
237        // When this wake lock is released, poke the user activity timer
238        // so the screen stays on for a little longer.
239        bool is_on_after_release = 2;
240    }
241
242    // Enum values gotten from PowerManager.java
243    enum LockLevel {
244        WAKE_LOCK_INVALID = 0;
245        // Ensures that the CPU is running.
246        PARTIAL_WAKE_LOCK = 1;
247        // Ensures that the screen is on (but may be dimmed).
248        SCREEN_DIM_WAKE_LOCK = 6;
249        // Ensures that the screen is on at full brightness.
250        SCREEN_BRIGHT_WAKE_LOCK = 10;
251        // Ensures that the screen and keyboard backlight are on at full brightness.
252        FULL_WAKE_LOCK = 26;
253        // Turns the screen off when the proximity sensor activates.
254        PROXIMITY_SCREEN_OFF_WAKE_LOCK = 32;
255        // Put the screen in a low power state and allow the CPU to suspend
256        // if no other wake locks are held.
257        DOZE_WAKE_LOCK = 64;
258        // Keep the device awake enough to allow drawing to occur.
259        DRAW_WAKE_LOCK = 128;
260    }
261
262    LockLevel lock_level = 1;
263    string tag = 2;
264    WakeLockFlagsProto flags = 3;
265    bool is_disabled = 4;
266    // Acquire time in ms
267    int64 acq_ms = 5;
268    bool is_notified_long = 6;
269    // Owner UID
270    int32 uid = 7;
271    // Owner PID
272    int32 pid = 8;
273    android.os.WorkSourceProto work_source = 9;
274}
275
276message PowerServiceSettingsAndConfigurationDumpProto {
277    message StayOnWhilePluggedInProto {
278        bool is_stay_on_while_plugged_in_ac = 1;
279        bool is_stay_on_while_plugged_in_usb = 2;
280        bool is_stay_on_while_plugged_in_wireless = 3;
281    }
282    message ScreenBrightnessSettingLimitsProto {
283        int32 setting_minimum = 1;
284        int32 setting_maximum = 2;
285        int32 setting_default = 3;
286        int32 setting_for_vr_default = 4;
287    }
288
289    // Enum values gotten from Settings.java
290    enum ScreenBrightnessMode {
291        SCREEN_BRIGHTNESS_MODE_MANUAL = 0;
292        SCREEN_BRIGHTNESS_MODE_AUTOMATIC = 1;
293    }
294    // Enum values gotten from Display.java
295    enum DisplayState {
296        DISPLAY_STATE_UNKNOWN = 0;
297        DISPLAY_STATE_OFF = 1;
298        DISPLAY_STATE_ON = 2;
299        DISPLAY_STATE_DOZE = 3;
300        DISPLAY_STATE_DOZE_SUSPEND = 4;
301        DISPLAY_STATE_VR = 5;
302    }
303
304
305    // True to decouple auto-suspend mode from the display state.
306    bool is_decouple_hal_auto_suspend_mode_from_display_config = 1;
307    // True to decouple interactive mode from the display state.
308    bool is_decouple_hal_interactive_mode_from_display_config = 2;
309    // True if the device should wake up when plugged or unplugged.
310    bool is_wake_up_when_plugged_or_unplugged_config = 3;
311    // True if the device should wake up when plugged or unplugged in theater mode.
312    bool is_wake_up_when_plugged_or_unplugged_in_theater_mode_config = 4;
313    // True if theater mode is enabled
314    bool is_theater_mode_enabled = 5;
315    // True if the device should suspend when the screen is off due to proximity.
316    bool is_suspend_when_screen_off_due_to_proximity_config = 6;
317    // True if dreams are supported on this device.
318    bool are_dreams_supported_config = 7;
319    // Default value for dreams enabled
320    bool are_dreams_enabled_by_default_config = 8;
321    // Default value for dreams activate-on-sleep
322    bool are_dreams_activated_on_sleep_by_default_config = 9;
323    // Default value for dreams activate-on-dock
324    bool are_dreams_activated_on_dock_by_default_config = 10;
325    // True if dreams can run while not plugged in.
326    bool are_dreams_enabled_on_battery_config = 11;
327    // Minimum battery level to allow dreaming when powered.
328    // Use -1 to disable this safety feature.
329    sint32 dreams_battery_level_minimum_when_powered_config = 12;
330    // Minimum battery level to allow dreaming when not powered.
331    // Use -1 to disable this safety feature.
332    sint32 dreams_battery_level_minimum_when_not_powered_config = 13;
333    // If the battery level drops by this percentage and the user activity
334    // timeout has expired, then assume the device is receiving insufficient
335    // current to charge effectively and terminate the dream.  Use -1 to disable
336    // this safety feature.
337    sint32 dreams_battery_level_drain_cutoff_config = 14;
338    // True if dreams are enabled by the user.
339    bool are_dreams_enabled_setting = 15;
340    // True if dreams should be activated on sleep.
341    bool are_dreams_activate_on_sleep_setting = 16;
342    // True if dreams should be activated on dock.
343    bool are_dreams_activate_on_dock_setting = 17;
344    // True if doze should not be started until after the screen off transition.
345    bool is_doze_after_screen_off_config = 18;
346    // If true, the device is in low power mode.
347    bool is_low_power_mode_setting = 19;
348    // Current state of whether the settings are allowing auto low power mode.
349    bool is_auto_low_power_mode_configured = 20;
350    // The user turned off low power mode below the trigger level
351    bool is_auto_low_power_mode_snoozing = 21;
352    // The minimum screen off timeout, in milliseconds.
353    int32 minimum_screen_off_timeout_config_ms = 22;
354    // The screen dim duration, in milliseconds.
355    int32 maximum_screen_dim_duration_config_ms = 23;
356    // The maximum screen dim time expressed as a ratio relative to the screen off timeout.
357    float maximum_screen_dim_ratio_config = 24;
358    // The screen off timeout setting value in milliseconds.
359    int32 screen_off_timeout_setting_ms = 25;
360    // The sleep timeout setting value in milliseconds.
361    sint32 sleep_timeout_setting_ms = 26;
362    // The maximum allowable screen off timeout according to the device administration policy.
363    int32 maximum_screen_off_timeout_from_device_admin_ms = 27;
364    bool is_maximum_screen_off_timeout_from_device_admin_enforced_locked = 28;
365    // The stay on while plugged in setting.
366    // A set of battery conditions under which to make the screen stay on.
367    StayOnWhilePluggedInProto stay_on_while_plugged_in = 29;
368    // The screen brightness setting, from 0 to 255.
369    // Use -1 if no value has been set.
370    sint32 screen_brightness_setting = 30;
371    // The screen auto-brightness adjustment setting, from -1 to 1.
372    // Use 0 if there is no adjustment.
373    float screen_auto_brightness_adjustment_setting = 31;
374    // The screen brightness mode.
375    ScreenBrightnessMode screen_brightness_mode_setting = 32;
376    // The screen brightness setting override from the window manager
377    // to allow the current foreground activity to override the brightness.
378    // Use -1 to disable.
379    sint32 screen_brightness_override_from_window_manager = 33;
380    // The user activity timeout override from the window manager
381    // to allow the current foreground activity to override the user activity
382    // timeout. Use -1 to disable.
383    sint64 user_activity_timeout_override_from_window_manager_ms = 34;
384    // The window manager has determined the user to be inactive via other means.
385    // Set this to false to disable.
386    bool is_user_inactive_override_from_window_manager = 35;
387    // The screen brightness setting override from the settings application
388    // to temporarily adjust the brightness until next updated,
389    // Use -1 to disable.
390    sint32 temporary_screen_brightness_setting_override = 36;
391    // The screen brightness adjustment setting override from the settings
392    // application to temporarily adjust the auto-brightness adjustment factor
393    // until next updated, in the range -1..1.
394    // Use NaN to disable.
395    float temporary_screen_auto_brightness_adjustment_setting_override = 37;
396    // The screen state to use while dozing.
397    DisplayState doze_screen_state_override_from_dream_manager = 38;
398    // The screen brightness to use while dozing.
399    float dozed_screen_brightness_override_from_dream_manager = 39;
400    // Screen brightness settings limits.
401    ScreenBrightnessSettingLimitsProto screen_brightness_setting_limits = 40;
402    // The screen brightness setting, from 0 to 255, to be used while in VR Mode.
403    int32 screen_brightness_for_vr_setting = 41;
404    // True if double tap to wake is enabled
405    bool is_double_tap_wake_enabled = 42;
406    // True if we are currently in VR Mode.
407    bool is_vr_mode_enabled = 43;
408}
409