blob: 2c7ffeff81f0f6964524d47ba1b97020a362619b [file] [log] [blame]
Ben Cheng655a7c02013-10-16 16:09:24 -07001/****************************************************************************
2 ****************************************************************************
3 ***
4 *** This header was automatically generated from a Linux kernel header
5 *** of the same name, to make information necessary for userspace to
6 *** call into the kernel available to libc. It contains only constants,
7 *** structures, and macros generated from the original header, and thus,
8 *** contains no copyrightable information.
9 ***
10 *** To edit the content of this header, modify the corresponding
11 *** source file (e.g. under external/kernel-headers/original/) then
12 *** run bionic/libc/kernel/tools/update_all.py
13 ***
14 *** Any manual change here will be lost the next time this script will
15 *** be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef _UAPI_LINUX_PMU_H
20#define _UAPI_LINUX_PMU_H
21#define PMU_DRIVER_VERSION 2
22#define PMU_POWER_CTRL0 0x10
Ben Cheng655a7c02013-10-16 16:09:24 -070023#define PMU_POWER_CTRL 0x11
24#define PMU_ADB_CMD 0x20
25#define PMU_ADB_POLL_OFF 0x21
26#define PMU_WRITE_NVRAM 0x33
Ben Cheng655a7c02013-10-16 16:09:24 -070027#define PMU_READ_NVRAM 0x3b
28#define PMU_SET_RTC 0x30
29#define PMU_READ_RTC 0x38
30#define PMU_SET_VOLBUTTON 0x40
Ben Cheng655a7c02013-10-16 16:09:24 -070031#define PMU_BACKLIGHT_BRIGHT 0x41
32#define PMU_GET_VOLBUTTON 0x48
33#define PMU_PCEJECT 0x4c
34#define PMU_BATTERY_STATE 0x6b
Ben Cheng655a7c02013-10-16 16:09:24 -070035#define PMU_SMART_BATTERY_STATE 0x6f
36#define PMU_SET_INTR_MASK 0x70
37#define PMU_INT_ACK 0x78
38#define PMU_SHUTDOWN 0x7e
Ben Cheng655a7c02013-10-16 16:09:24 -070039#define PMU_CPU_SPEED 0x7d
40#define PMU_SLEEP 0x7f
41#define PMU_POWER_EVENTS 0x8f
42#define PMU_I2C_CMD 0x9a
Ben Cheng655a7c02013-10-16 16:09:24 -070043#define PMU_RESET 0xd0
44#define PMU_GET_BRIGHTBUTTON 0xd9
45#define PMU_GET_COVER 0xdc
46#define PMU_SYSTEM_READY 0xdf
Ben Cheng655a7c02013-10-16 16:09:24 -070047#define PMU_GET_VERSION 0xea
48#define PMU_POW0_ON 0x80
49#define PMU_POW0_OFF 0x00
50#define PMU_POW0_HARD_DRIVE 0x04
Ben Cheng655a7c02013-10-16 16:09:24 -070051#define PMU_POW_ON 0x80
52#define PMU_POW_OFF 0x00
53#define PMU_POW_BACKLIGHT 0x01
54#define PMU_POW_CHARGER 0x02
Ben Cheng655a7c02013-10-16 16:09:24 -070055#define PMU_POW_IRLED 0x04
56#define PMU_POW_MEDIABAY 0x08
57#define PMU_INT_PCEJECT 0x04
58#define PMU_INT_SNDBRT 0x08
Ben Cheng655a7c02013-10-16 16:09:24 -070059#define PMU_INT_ADB 0x10
60#define PMU_INT_BATTERY 0x20
61#define PMU_INT_ENVIRONMENT 0x40
62#define PMU_INT_TICK 0x80
Ben Cheng655a7c02013-10-16 16:09:24 -070063#define PMU_INT_ADB_AUTO 0x04
64#define PMU_INT_WAITING_CHARGER 0x01
65#define PMU_INT_AUTO_SRQ_POLL 0x02
66#define PMU_ENV_LID_CLOSED 0x01
Ben Cheng655a7c02013-10-16 16:09:24 -070067#define PMU_I2C_MODE_SIMPLE 0
68#define PMU_I2C_MODE_STDSUB 1
69#define PMU_I2C_MODE_COMBINED 2
70#define PMU_I2C_BUS_STATUS 0
Ben Cheng655a7c02013-10-16 16:09:24 -070071#define PMU_I2C_BUS_SYSCLK 1
72#define PMU_I2C_BUS_POWER 2
73#define PMU_I2C_STATUS_OK 0
74#define PMU_I2C_STATUS_DATAREAD 1
Ben Cheng655a7c02013-10-16 16:09:24 -070075#define PMU_I2C_STATUS_BUSY 0xfe
76enum {
Tao Baod7db5942015-01-28 10:07:51 -080077 PMU_UNKNOWN,
78 PMU_OHARE_BASED,
Tao Baod7db5942015-01-28 10:07:51 -080079 PMU_HEATHROW_BASED,
80 PMU_PADDINGTON_BASED,
81 PMU_KEYLARGO_BASED,
82 PMU_68K_V1,
Tao Baod7db5942015-01-28 10:07:51 -080083 PMU_68K_V2,
Ben Cheng655a7c02013-10-16 16:09:24 -070084};
85enum {
Tao Baod7db5942015-01-28 10:07:51 -080086 PMU_PWR_GET_POWERUP_EVENTS = 0x00,
Tao Baod7db5942015-01-28 10:07:51 -080087 PMU_PWR_SET_POWERUP_EVENTS = 0x01,
88 PMU_PWR_CLR_POWERUP_EVENTS = 0x02,
89 PMU_PWR_GET_WAKEUP_EVENTS = 0x03,
90 PMU_PWR_SET_WAKEUP_EVENTS = 0x04,
Tao Baod7db5942015-01-28 10:07:51 -080091 PMU_PWR_CLR_WAKEUP_EVENTS = 0x05,
Ben Cheng655a7c02013-10-16 16:09:24 -070092};
93enum {
Tao Baod7db5942015-01-28 10:07:51 -080094 PMU_PWR_WAKEUP_KEY = 0x01,
Tao Baod7db5942015-01-28 10:07:51 -080095 PMU_PWR_WAKEUP_AC_INSERT = 0x02,
96 PMU_PWR_WAKEUP_AC_CHANGE = 0x04,
97 PMU_PWR_WAKEUP_LID_OPEN = 0x08,
98 PMU_PWR_WAKEUP_RING = 0x10,
Ben Cheng655a7c02013-10-16 16:09:24 -070099};
100#include <linux/ioctl.h>
101#define PMU_IOC_SLEEP _IO('B', 0)
102#define PMU_IOC_GET_BACKLIGHT _IOR('B', 1, size_t)
Ben Cheng655a7c02013-10-16 16:09:24 -0700103#define PMU_IOC_SET_BACKLIGHT _IOW('B', 2, size_t)
104#define PMU_IOC_GET_MODEL _IOR('B', 3, size_t)
105#define PMU_IOC_HAS_ADB _IOR('B', 4, size_t)
106#define PMU_IOC_CAN_SLEEP _IOR('B', 5, size_t)
Ben Cheng655a7c02013-10-16 16:09:24 -0700107#define PMU_IOC_GRAB_BACKLIGHT _IOR('B', 6, size_t)
108#endif