/* * Copyright (C) 2016 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package android.hardware.power@1.0; /** * Constructor for the interface performs power management setup actions at * runtime startup, such as to set default cpufreq parameters. */ interface IPower { /** * setInteractive() performs power management actions upon the * system entering interactive state (that is, the system is awake * and ready for interaction, often with UI devices such as * display and touchscreen enabled) or non-interactive state (the * system appears asleep, display usually turned off). The * non-interactive state may be entered after a period of * inactivity in order to conserve battery power during * such inactive periods. * * Typical actions are to turn on or off devices and adjust * cpufreq parameters. This function may also call the * appropriate interfaces to allow the kernel to suspend the * system to low-power sleep state when entering non-interactive * state, and to disallow low-power suspend when the system is in * interactive state. When low-power suspend state is allowed, the * kernel may suspend the system whenever no wakelocks are held. * * For example, * This function can be called to enter non-interactive state after * turning off the screen (if present) and called to enter * interactive state prior to turning on the screen. * * @param interactive is true when the system is transitioning to an * interactive state and false when transitioning to a * non-interactive state. */ setInteractive(bool interactive); /** * powerHint() is called to pass hints on power requirements which * may result in adjustment of power/performance parameters of the * cpufreq governor and other controls. * * A particular platform may choose to ignore any hint. * * @param hint PowerHint which is passed * @param data contains additional information about the hint * and is described along with the comments for each of the hints. */ powerHint(PowerHint hint, int32_t data); /** * setFeature() is called to turn on or off a particular feature * depending on the state parameter. * * @param feature Feature which needs to be set * @param activate true/false to enable/disable the feature */ setFeature(Feature feature, bool activate); /** * Platform-level sleep state stats: * Report cumulative info on the statistics on platform-level sleep states * since boot. * * Higher the index in the returned <states> vector deeper the state is * i.e. lesser steady-state power is consumed by the platform to be * resident in that state. * * @return states of power states the device supports * @return retval SUCCESS on success or FILESYSTEM_ERROR on filesystem * nodes access error. */ getPlatformLowPowerStats() generates (vec<PowerStatePlatformSleepState> states, Status retval); };