Elliott Hughes | 180edef | 2023-11-02 00:08:05 +0000 | [diff] [blame] | 1 | /* |
| 2 | * This file is auto-generated. Modifications will be lost. |
| 3 | * |
| 4 | * See https://android.googlesource.com/platform/bionic/+/master/libc/kernel/ |
| 5 | * for more information. |
| 6 | */ |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 7 | #ifndef _UAPI_LINUX_PMU_H |
| 8 | #define _UAPI_LINUX_PMU_H |
| 9 | #define PMU_DRIVER_VERSION 2 |
| 10 | #define PMU_POWER_CTRL0 0x10 |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 11 | #define PMU_POWER_CTRL 0x11 |
| 12 | #define PMU_ADB_CMD 0x20 |
| 13 | #define PMU_ADB_POLL_OFF 0x21 |
Christopher Ferris | 24f97eb | 2019-05-20 12:58:13 -0700 | [diff] [blame] | 14 | #define PMU_WRITE_XPRAM 0x32 |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 15 | #define PMU_WRITE_NVRAM 0x33 |
Christopher Ferris | 24f97eb | 2019-05-20 12:58:13 -0700 | [diff] [blame] | 16 | #define PMU_READ_XPRAM 0x3a |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 17 | #define PMU_READ_NVRAM 0x3b |
| 18 | #define PMU_SET_RTC 0x30 |
| 19 | #define PMU_READ_RTC 0x38 |
| 20 | #define PMU_SET_VOLBUTTON 0x40 |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 21 | #define PMU_BACKLIGHT_BRIGHT 0x41 |
| 22 | #define PMU_GET_VOLBUTTON 0x48 |
| 23 | #define PMU_PCEJECT 0x4c |
| 24 | #define PMU_BATTERY_STATE 0x6b |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 25 | #define PMU_SMART_BATTERY_STATE 0x6f |
| 26 | #define PMU_SET_INTR_MASK 0x70 |
| 27 | #define PMU_INT_ACK 0x78 |
| 28 | #define PMU_SHUTDOWN 0x7e |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 29 | #define PMU_CPU_SPEED 0x7d |
| 30 | #define PMU_SLEEP 0x7f |
| 31 | #define PMU_POWER_EVENTS 0x8f |
| 32 | #define PMU_I2C_CMD 0x9a |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 33 | #define PMU_RESET 0xd0 |
| 34 | #define PMU_GET_BRIGHTBUTTON 0xd9 |
| 35 | #define PMU_GET_COVER 0xdc |
| 36 | #define PMU_SYSTEM_READY 0xdf |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 37 | #define PMU_GET_VERSION 0xea |
| 38 | #define PMU_POW0_ON 0x80 |
| 39 | #define PMU_POW0_OFF 0x00 |
| 40 | #define PMU_POW0_HARD_DRIVE 0x04 |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 41 | #define PMU_POW_ON 0x80 |
| 42 | #define PMU_POW_OFF 0x00 |
| 43 | #define PMU_POW_BACKLIGHT 0x01 |
| 44 | #define PMU_POW_CHARGER 0x02 |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 45 | #define PMU_POW_IRLED 0x04 |
| 46 | #define PMU_POW_MEDIABAY 0x08 |
| 47 | #define PMU_INT_PCEJECT 0x04 |
| 48 | #define PMU_INT_SNDBRT 0x08 |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 49 | #define PMU_INT_ADB 0x10 |
| 50 | #define PMU_INT_BATTERY 0x20 |
| 51 | #define PMU_INT_ENVIRONMENT 0x40 |
| 52 | #define PMU_INT_TICK 0x80 |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 53 | #define PMU_INT_ADB_AUTO 0x04 |
| 54 | #define PMU_INT_WAITING_CHARGER 0x01 |
| 55 | #define PMU_INT_AUTO_SRQ_POLL 0x02 |
| 56 | #define PMU_ENV_LID_CLOSED 0x01 |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 57 | #define PMU_I2C_MODE_SIMPLE 0 |
| 58 | #define PMU_I2C_MODE_STDSUB 1 |
| 59 | #define PMU_I2C_MODE_COMBINED 2 |
| 60 | #define PMU_I2C_BUS_STATUS 0 |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 61 | #define PMU_I2C_BUS_SYSCLK 1 |
| 62 | #define PMU_I2C_BUS_POWER 2 |
| 63 | #define PMU_I2C_STATUS_OK 0 |
| 64 | #define PMU_I2C_STATUS_DATAREAD 1 |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 65 | #define PMU_I2C_STATUS_BUSY 0xfe |
| 66 | enum { |
Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 67 | PMU_UNKNOWN, |
| 68 | PMU_OHARE_BASED, |
Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 69 | PMU_HEATHROW_BASED, |
| 70 | PMU_PADDINGTON_BASED, |
| 71 | PMU_KEYLARGO_BASED, |
| 72 | PMU_68K_V1, |
Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 73 | PMU_68K_V2, |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 74 | }; |
| 75 | enum { |
Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 76 | PMU_PWR_GET_POWERUP_EVENTS = 0x00, |
Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 77 | PMU_PWR_SET_POWERUP_EVENTS = 0x01, |
| 78 | PMU_PWR_CLR_POWERUP_EVENTS = 0x02, |
| 79 | PMU_PWR_GET_WAKEUP_EVENTS = 0x03, |
| 80 | PMU_PWR_SET_WAKEUP_EVENTS = 0x04, |
Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 81 | PMU_PWR_CLR_WAKEUP_EVENTS = 0x05, |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 82 | }; |
| 83 | enum { |
Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 84 | PMU_PWR_WAKEUP_KEY = 0x01, |
Tao Bao | d7db594 | 2015-01-28 10:07:51 -0800 | [diff] [blame] | 85 | PMU_PWR_WAKEUP_AC_INSERT = 0x02, |
| 86 | PMU_PWR_WAKEUP_AC_CHANGE = 0x04, |
| 87 | PMU_PWR_WAKEUP_LID_OPEN = 0x08, |
| 88 | PMU_PWR_WAKEUP_RING = 0x10, |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 89 | }; |
| 90 | #include <linux/ioctl.h> |
| 91 | #define PMU_IOC_SLEEP _IO('B', 0) |
| 92 | #define PMU_IOC_GET_BACKLIGHT _IOR('B', 1, size_t) |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 93 | #define PMU_IOC_SET_BACKLIGHT _IOW('B', 2, size_t) |
| 94 | #define PMU_IOC_GET_MODEL _IOR('B', 3, size_t) |
| 95 | #define PMU_IOC_HAS_ADB _IOR('B', 4, size_t) |
| 96 | #define PMU_IOC_CAN_SLEEP _IOR('B', 5, size_t) |
Ben Cheng | 655a7c0 | 2013-10-16 16:09:24 -0700 | [diff] [blame] | 97 | #define PMU_IOC_GRAB_BACKLIGHT _IOR('B', 6, size_t) |
| 98 | #endif |