/* * Copyright (C) 2018 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. */ syntax = "proto2"; package android.os; option java_outer_classname = "OsProtoEnums"; option java_multiple_files = true; // These constants are defined in hardware/interfaces/health/1.0/types.hal // They are primarily used by android/os/BatteryManager.java. enum BatteryHealthEnum { BATTERY_HEALTH_INVALID = 0; BATTERY_HEALTH_UNKNOWN = 1; BATTERY_HEALTH_GOOD = 2; BATTERY_HEALTH_OVERHEAT = 3; BATTERY_HEALTH_DEAD = 4; BATTERY_HEALTH_OVER_VOLTAGE = 5; BATTERY_HEALTH_UNSPECIFIED_FAILURE = 6; BATTERY_HEALTH_COLD = 7; } // Plug states, primarily used by android/os/BatteryManager.java. enum BatteryPluggedStateEnum { // Note that NONE is not in BatteryManager.java's constants. BATTERY_PLUGGED_NONE = 0; // Power source is an AC charger. BATTERY_PLUGGED_AC = 1; // Power source is a USB port. BATTERY_PLUGGED_USB = 2; // Power source is wireless. BATTERY_PLUGGED_WIRELESS = 4; // Power source is dock. BATTERY_PLUGGED_DOCK = 8; } // These constants are defined in hardware/interfaces/health/1.0/types.hal // They are primarily used by android/os/BatteryManager.java. enum BatteryStatusEnum { BATTERY_STATUS_INVALID = 0; BATTERY_STATUS_UNKNOWN = 1; BATTERY_STATUS_CHARGING = 2; BATTERY_STATUS_DISCHARGING = 3; BATTERY_STATUS_NOT_CHARGING = 4; BATTERY_STATUS_FULL = 5; } enum PowerComponentEnum { POWER_COMPONENT_SCREEN = 0; POWER_COMPONENT_CPU = 1; POWER_COMPONENT_BLUETOOTH = 2; POWER_COMPONENT_CAMERA = 3; POWER_COMPONENT_AUDIO = 4; POWER_COMPONENT_VIDEO = 5; POWER_COMPONENT_FLASHLIGHT = 6; POWER_COMPONENT_SYSTEM_SERVICES = 7; POWER_COMPONENT_MOBILE_RADIO = 8; POWER_COMPONENT_SENSORS = 9; POWER_COMPONENT_GNSS = 10; POWER_COMPONENT_WIFI = 11; POWER_COMPONENT_WAKELOCK = 12; POWER_COMPONENT_MEMORY = 13; POWER_COMPONENT_PHONE = 14; POWER_COMPONENT_AMBIENT_DISPLAY = 15; POWER_COMPONENT_IDLE = 16; // Power that is re-attributed to other battery consumers. For example, for System Server // this represents the power attributed to apps requesting system services. // The value should be negative or zero. POWER_COMPONENT_REATTRIBUTED_TO_OTHER_CONSUMERS = 17; } // These constants are defined in hardware/interfaces/thermal/1.0/types.hal // and in hardware/interfaces/thermal/2.0/types.hal // They are primarily used by android/os/HardwarePropertiesManager.java. // Any change to the types in the thermal hal should be made here as well. enum TemperatureTypeEnum { TEMPERATURE_TYPE_UNKNOWN = -1; TEMPERATURE_TYPE_CPU = 0; TEMPERATURE_TYPE_GPU = 1; TEMPERATURE_TYPE_BATTERY = 2; TEMPERATURE_TYPE_SKIN = 3; TEMPERATURE_TYPE_USB_PORT = 4; TEMPERATURE_TYPE_POWER_AMPLIFIER = 5; // Battery Charge Limit - virtual thermal sensors. TEMPERATURE_TYPE_BCL_VOLTAGE = 6; TEMPERATURE_TYPE_BCL_CURRENT = 7; TEMPERATURE_TYPE_BCL_PERCENTAGE = 8; // Neural Processing Unit. TEMPERATURE_TYPE_NPU = 9; } // Device throttling severity // These constants are defined in hardware/interfaces/thermal/2.0/types.hal. // Any change to the types in the thermal hal should be made here as well. enum ThrottlingSeverityEnum { // Not under throttling. NONE = 0; // Light throttling where UX is not impacted. LIGHT = 1; // Moderate throttling where UX is not largely impacted. MODERATE = 2; // Severe throttling where UX is largely impacted. // Similar to 1.0 throttlingThreshold. SEVERE = 3; // Platform has done everything to reduce power. CRITICAL = 4; // Key components in platform are shutting down due to thermal condition. // Device functionalities will be limited. EMERGENCY = 5; // Need shutdown immediately. SHUTDOWN = 6; }; // Device cooling device types. // These constants are defined in hardware/interfaces/thermal/2.0/types.hal. // Any change to the types in the thermal hal should be made here as well. enum CoolingTypeEnum { FAN = 0; BATTERY = 1; CPU = 2; GPU = 3; MODEM = 4; NPU = 5; COMPONENT = 6; }; // Wakelock types, primarily used by android/os/PowerManager.java. enum WakeLockLevelEnum { // NOTE: Wake lock levels were previously defined as a bit field, except // that only a few combinations were actually supported so the bit field // was removed. This explains why the numbering scheme is so odd. If // adding a new wake lock level, any unused value can be used. // Ensures that the CPU is running; the screen and keyboard backlight // will be allowed to go off. PARTIAL_WAKE_LOCK = 1; // Ensures that the screen is on (but may be dimmed); the keyboard // backlight will be allowed to go off. If the user presses the power // button, then the SCREEN_DIM_WAKE_LOCK will be implicitly released by // the system, causing both the screen and the CPU to be turned off. SCREEN_DIM_WAKE_LOCK = 6 [deprecated = true]; // Ensures that the screen is on at full brightness; the keyboard // backlight will be allowed to go off. If the user presses the power // button, then the SCREEN_BRIGHT_WAKE_LOCK will be implicitly released // by the system, causing both the screen and the CPU to be turned off. SCREEN_BRIGHT_WAKE_LOCK = 10 [deprecated = true]; // Ensures that the screen and keyboard backlight are on at full // brightness. If the user presses the power button, then the // FULL_WAKE_LOCK will be implicitly released by the system, causing // both the screen and the CPU to be turned off. FULL_WAKE_LOCK = 26 [deprecated = true]; // Turns the screen off when the proximity sensor activates. If the // proximity sensor detects that an object is nearby, the screen turns // off immediately. Shortly after the object moves away, the screen // turns on again. // A proximity wake lock does not prevent the device from falling asleep // unlike FULL_WAKE_LOCK, SCREEN_BRIGHT_WAKE_LOCK and // SCREEN_DIM_WAKE_LOCK. If there is no user activity and no other wake // locks are held, then the device will fall asleep (and lock) as usual. // However, the device will not fall asleep while the screen has been // turned off by the proximity sensor because it effectively counts as // ongoing user activity. PROXIMITY_SCREEN_OFF_WAKE_LOCK = 32; // Put the screen in a low power state and allow the CPU to suspend if // no other wake locks are held. This is used by the dream manager to // implement doze mode. It currently has no effect unless the power // manager is in the dozing state. DOZE_WAKE_LOCK = 64; // Keep the device awake enough to allow drawing to occur. This is used // by the window manager to allow applications to draw while the system // is dozing. It currently has no effect unless the power manager is in // the dozing state. DRAW_WAKE_LOCK = 128; }