xref: /openbsd-src/sys/arch/amd64/include/apmvar.h (revision cd56ea097150e82cade6656d44978184e018e288)
1f5df1827Smickey /* XXX - DSR */
2*cd56ea09Sphessler /*	$OpenBSD: apmvar.h,v 1.8 2019/01/22 02:36:30 phessler Exp $	*/
3f5df1827Smickey 
4f5df1827Smickey /*
5f5df1827Smickey  *  Copyright (c) 1995 John T. Kohl
6f5df1827Smickey  *  All rights reserved.
7f5df1827Smickey  *
8f5df1827Smickey  *  Redistribution and use in source and binary forms, with or without
9f5df1827Smickey  *  modification, are permitted provided that the following conditions
10f5df1827Smickey  *  are met:
11f5df1827Smickey  *  1. Redistributions of source code must retain the above copyright
12f5df1827Smickey  *     notice, this list of conditions and the following disclaimer.
13f5df1827Smickey  *  2. Redistributions in binary form must reproduce the above copyright
14f5df1827Smickey  *     notice, this list of conditions and the following disclaimer in the
15f5df1827Smickey  *     documentation and/or other materials provided with the distribution.
16f5df1827Smickey  *  3. The name of the author may not be used to endorse or promote products
17f5df1827Smickey  *     derived from this software without specific prior written permission.
18f5df1827Smickey  *
19f5df1827Smickey  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR `AS IS'' AND ANY EXPRESS OR
20f5df1827Smickey  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
21f5df1827Smickey  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22f5df1827Smickey  * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
23f5df1827Smickey  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
24f5df1827Smickey  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
25f5df1827Smickey  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26f5df1827Smickey  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
27f5df1827Smickey  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
28f5df1827Smickey  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29f5df1827Smickey  * POSSIBILITY OF SUCH DAMAGE.
30f5df1827Smickey  *
31f5df1827Smickey  */
322fa72412Spirofti #ifndef _MACHINE_APMVAR_H_
332fa72412Spirofti #define _MACHINE_APMVAR_H_
34f5df1827Smickey 
35f5df1827Smickey #include <sys/ioccom.h>
36f5df1827Smickey 
37f5df1827Smickey /* Advanced Power Management (v1.0 and v1.1 specification)
38f5df1827Smickey  * functions/defines/etc.
39f5df1827Smickey  */
40f5df1827Smickey 
41f5df1827Smickey #define	APM_VERSION	0x0102
42f5df1827Smickey 
43f5df1827Smickey /*
44f5df1827Smickey  * APM info word from boot loader
45f5df1827Smickey  */
46f5df1827Smickey #define APM_16BIT_SUPPORTED	0x00010000
47f5df1827Smickey #define APM_32BIT_SUPPORTED	0x00020000
48f5df1827Smickey #define APM_IDLE_SLOWS		0x00040000
49f5df1827Smickey #define APM_BIOS_PM_DISABLED	0x00080000
50f5df1827Smickey #define APM_BIOS_PM_DISENGAGED	0x00100000
51f5df1827Smickey #define	APM_MAJOR(f)		(((f) >> 8) & 0xff)
52f5df1827Smickey #define	APM_MINOR(f)		((f) & 0xff)
53f5df1827Smickey #define	APM_VERMASK		0x0000ffff
54f5df1827Smickey #define	APM_NOCLI		0x00010000
55f5df1827Smickey #define	APM_BEBATT		0x00020000
56f5df1827Smickey 
57f5df1827Smickey /* APM error codes */
58f5df1827Smickey #define	APM_ERR_CODE(regs)	(((regs)->ax & 0xff00) >> 8)
59f5df1827Smickey #define	APM_ERR_PM_DISABLED	0x01
60f5df1827Smickey #define	APM_ERR_REALALREADY	0x02
61f5df1827Smickey #define	APM_ERR_NOTCONN		0x03
62f5df1827Smickey #define	APM_ERR_16ALREADY	0x05
63f5df1827Smickey #define	APM_ERR_16NOTSUPP	0x06
64f5df1827Smickey #define	APM_ERR_32ALREADY	0x07
65f5df1827Smickey #define	APM_ERR_32NOTSUPP	0x08
66f5df1827Smickey #define	APM_ERR_UNRECOG_DEV	0x09
67f5df1827Smickey #define	APM_ERR_ERANGE		0x0A
68f5df1827Smickey #define	APM_ERR_NOTENGAGED	0x0B
69f5df1827Smickey #define	APM_ERR_EOPNOSUPP	0x0C
70f5df1827Smickey #define	APM_ERR_RTIMER_DISABLED	0x0D
71f5df1827Smickey #define APM_ERR_UNABLE		0x60
72f5df1827Smickey #define APM_ERR_NOEVENTS	0x80
73f5df1827Smickey #define	APM_ERR_NOT_PRESENT	0x86
74f5df1827Smickey 
75f5df1827Smickey #define APM_DEV_APM_BIOS	0x0000
76f5df1827Smickey #define APM_DEV_ALLDEVS		0x0001
77f5df1827Smickey /* device classes are high byte; device IDs go in low byte */
78f5df1827Smickey #define		APM_DEV_DISPLAY(x)	(0x0100|((x)&0xff))
79f5df1827Smickey #define		APM_DEV_DISK(x)		(0x0200|((x)&0xff))
80f5df1827Smickey #define		APM_DEV_PARALLEL(x)	(0x0300|((x)&0xff))
81f5df1827Smickey #define		APM_DEV_SERIAL(x)	(0x0400|((x)&0xff))
82f5df1827Smickey #define		APM_DEV_NETWORK(x)	(0x0500|((x)&0xff))
83f5df1827Smickey #define		APM_DEV_PCMCIA(x)	(0x0600|((x)&0xff))
84f5df1827Smickey #define		APM_DEV_BATTERIES(x)	(0x8000|((x)&0xff))
85f5df1827Smickey #define		APM_DEV_ALLUNITS	0xff
86f5df1827Smickey /* 0x8100-0xDFFF - reserved	*/
87f5df1827Smickey /* 0xE000-0xEFFF - OEM-defined	*/
88f5df1827Smickey /* 0xF000-0xFFFF - reserved	*/
89f5df1827Smickey 
90f5df1827Smickey #define	APM_INSTCHECK		0x5300	/* int15 only */
91f5df1827Smickey #define		APM_16BIT_SUPPORT	0x01
92f5df1827Smickey #define		APM_32BIT_SUPPORT	0x02
93f5df1827Smickey #define		APM_CPUIDLE_SLOW	0x04
94f5df1827Smickey #define		APM_DISABLED		0x08
95f5df1827Smickey #define		APM_DISENGAGED		0x10
96f5df1827Smickey 
97f5df1827Smickey #define	APM_REAL_CONNECT	0x5301	/* int15 only */
98f5df1827Smickey #define	APM_PROT16_CONNECT	0x5302	/* int15 only */
99f5df1827Smickey #define	APM_PROT32_CONNECT	0x5303	/* int15 only */
100f5df1827Smickey #define APM_DISCONNECT		0x5304	/* %bx = APM_DEV_APM_BIOS */
101f5df1827Smickey 
102f5df1827Smickey #define APM_CPU_IDLE		0x5305
103f5df1827Smickey #define APM_CPU_BUSY		0x5306
104f5df1827Smickey 
105f5df1827Smickey #define APM_SET_PWR_STATE	0x5307
106f5df1827Smickey #define		APM_SYS_READY		0x0000	/* %cx */
107f5df1827Smickey #define		APM_SYS_STANDBY		0x0001
108f5df1827Smickey #define		APM_SYS_SUSPEND		0x0002
109f5df1827Smickey #define		APM_SYS_OFF		0x0003
110f5df1827Smickey #define		APM_LASTREQ_INPROG	0x0004
111f5df1827Smickey #define		APM_LASTREQ_REJECTED	0x0005
112f5df1827Smickey /* 0x0006 - 0x001f	Reserved system states    */
113f5df1827Smickey /* 0x0020 - 0x003f	OEM-defined system states */
114f5df1827Smickey /* 0x0040 - 0x007f	OEM-defined device states */
115f5df1827Smickey /* 0x0080 - 0xffff	Reserved device states    */
116f5df1827Smickey 
117f5df1827Smickey /* system standby is device ID (%bx) 0x0001, APM_SYS_STANDBY */
118f5df1827Smickey /* system suspend is device ID (%bx) 0x0001, APM_SYS_SUSPEND */
119f5df1827Smickey 
120f5df1827Smickey #define APM_PWR_MGT_ENABLE	0x5308
121f5df1827Smickey #define		APM_MGT_ALL	0xffff	/* %bx */
122f5df1827Smickey #define		APM_MGT_DISABLE	0x0	/* %cx */
123f5df1827Smickey #define		APM_MGT_ENABLE	0x1
124f5df1827Smickey 
125f5df1827Smickey #define APM_SYSTEM_DEFAULTS	0x5309
126f5df1827Smickey #define		APM_DEFAULTS_ALL	0xffff	/* %bx */
127f5df1827Smickey 
128f5df1827Smickey #define APM_POWER_STATUS	0x530a
129f5df1827Smickey #define		APM_AC_OFF		0x00
130f5df1827Smickey #define		APM_AC_ON		0x01
131f5df1827Smickey #define		APM_AC_BACKUP		0x02
132f5df1827Smickey #define		APM_AC_UNKNOWN		0xff
133f5df1827Smickey #define		APM_BATT_HIGH		0x00
134f5df1827Smickey #define		APM_BATT_LOW		0x01
135f5df1827Smickey #define		APM_BATT_CRITICAL	0x02
136f5df1827Smickey #define		APM_BATT_CHARGING	0x03
137f5df1827Smickey #define		APM_BATT_UNKNOWN	0xff
138f5df1827Smickey #define		APM_BATT_FLAG_HIGH	0x01
139f5df1827Smickey #define		APM_BATT_FLAG_LOW	0x02
140f5df1827Smickey #define		APM_BATT_FLAG_CRITICAL	0x04
141f5df1827Smickey #define		APM_BATT_FLAG_CHARGING	0x08
142f5df1827Smickey #define		APM_BATT_FLAG_NOBATTERY	0x10
143f5df1827Smickey #define		APM_BATT_FLAG_NOSYSBATT	0x80
144f5df1827Smickey #define		APM_BATT_LIFE_UNKNOWN	0xff
145f5df1827Smickey #define		BATT_STATE(regp) ((regp)->bx & 0xff)
146f5df1827Smickey #define		BATT_FLAGS(regp) (((regp)->cx & 0xff00) >> 8)
147f5df1827Smickey #define		AC_STATE(regp) (((regp)->bx & 0xff00) >> 8)
148f5df1827Smickey #define		BATT_LIFE(regp) ((regp)->cx & 0xff) /* in % */
149f5df1827Smickey /* Return time in minutes. According to the APM 1.2 spec:
150f5df1827Smickey 	DX = Remaining battery life -- time units
151f5df1827Smickey 		Bit 15 = 0	Time units are seconds
152f5df1827Smickey 		       = 1 	Time units are minutes
153f5df1827Smickey 		Bits 14-0 =	Number of seconds or minutes */
154f5df1827Smickey #define		BATT_REMAINING(regp) (((regp)->dx & 0x8000) ? \
155f5df1827Smickey 				      ((regp)->dx & 0x7fff) : \
156f5df1827Smickey 				      ((regp)->dx & 0x7fff)/60)
157f5df1827Smickey #define		BATT_REM_VALID(regp) (((regp)->dx & 0xffff) != 0xffff)
158f5df1827Smickey #define		BATT_COUNT(regp)	((regp)->si)
159f5df1827Smickey 
160f5df1827Smickey #define	APM_GET_PM_EVENT	0x530b
161f5df1827Smickey #define		APM_NOEVENT		0x0000
162f5df1827Smickey #define		APM_STANDBY_REQ		0x0001 /* %bx on return */
163f5df1827Smickey #define		APM_SUSPEND_REQ		0x0002
164f5df1827Smickey #define		APM_NORMAL_RESUME	0x0003
165f5df1827Smickey #define		APM_CRIT_RESUME		0x0004 /* suspend/resume happened
166f5df1827Smickey 						  without us */
167f5df1827Smickey #define		APM_BATTERY_LOW		0x0005
168f5df1827Smickey #define		APM_POWER_CHANGE	0x0006
169f5df1827Smickey #define		APM_UPDATE_TIME		0x0007
170f5df1827Smickey #define		APM_CRIT_SUSPEND_REQ	0x0008
171f5df1827Smickey #define		APM_USER_STANDBY_REQ	0x0009
172f5df1827Smickey #define		APM_USER_SUSPEND_REQ	0x000A
173f5df1827Smickey #define		APM_SYS_STANDBY_RESUME	0x000B
174f5df1827Smickey #define		APM_CAPABILITY_CHANGE	0x000C	/* apm v1.2 */
175f5df1827Smickey /* 0x000d - 0x00ff	Reserved system events */
1768d4bc9d5Sdcoppa #define		APM_USER_HIBERNATE_REQ	0x000D
177f5df1827Smickey /* 0x0100 - 0x01ff	Reserved device events */
178f5df1827Smickey /* 0x0200 - 0x02ff	OEM-defined APM events */
179f5df1827Smickey /* 0x0300 - 0xffff	Reserved */
180f5df1827Smickey #define		APM_EVENT_MASK		0xffff
181f5df1827Smickey 
182f5df1827Smickey #define	APM_EVENT_COMPOSE(t,i)	((((i) & 0x7fff) << 16)|((t) & APM_EVENT_MASK))
183f5df1827Smickey #define	APM_EVENT_TYPE(e)	((e) & APM_EVENT_MASK)
184f5df1827Smickey #define	APM_EVENT_INDEX(e)	((e) >> 16)
185f5df1827Smickey 
186f5df1827Smickey #define	APM_GET_POWER_STATE	0x530c
187f5df1827Smickey #define	APM_DEVICE_MGMT_ENABLE	0x530d
188f5df1827Smickey 
189f5df1827Smickey #define	APM_DRIVER_VERSION	0x530e
190f5df1827Smickey /* %bx should be DEV value (APM_DEV_APM_BIOS)
191f5df1827Smickey    %ch = driver major vno
192f5df1827Smickey    %cl = driver minor vno
193f5df1827Smickey    return: %ah = conn major; %al = conn minor
194f5df1827Smickey    */
195f5df1827Smickey #define		APM_CONN_MINOR(regp) ((regp)->ax & 0xff)
196f5df1827Smickey #define		APM_CONN_MAJOR(regp) (((regp)->ax & 0xff00) >> 8)
197f5df1827Smickey 
198f5df1827Smickey #define APM_PWR_MGT_ENGAGE	0x530F
199f5df1827Smickey #define		APM_MGT_DISENGAGE	0x0	/* %cx */
200f5df1827Smickey #define		APM_MGT_ENGAGE		0x1
201f5df1827Smickey 
202f5df1827Smickey /* %bx - APM_DEV_APM_BIOS
203f5df1827Smickey  * %bl - number of batteries
204f5df1827Smickey  * %cx - capabilities
205f5df1827Smickey  */
206f5df1827Smickey #define	APM_GET_CAPABILITIES	0x5310
207f5df1827Smickey #define		APM_NBATTERIES(regp)	((regp)->bx)
208f5df1827Smickey #define		APM_GLOBAL_STANDBY	0x0001
209f5df1827Smickey #define		APM_GLOBAL_SUSPEND	0x0002
210f5df1827Smickey #define		APM_RTIMER_STANDBY	0x0004	/* resume time wakes up */
211f5df1827Smickey #define		APM_RTIMER_SUSPEND	0x0008
212f5df1827Smickey #define		APM_IRRING_STANDBY	0x0010	/* internal ring wakes up */
213f5df1827Smickey #define		APM_IRRING_SUSPEND	0x0020
214f5df1827Smickey #define		APM_PCCARD_STANDBY	0x0040	/* pccard wakes up */
215f5df1827Smickey #define		APM_PCCARD_SUSPEND	0x0080
216f5df1827Smickey 
217f5df1827Smickey /* %bx - APM_DEV_APM_BIOS
218f5df1827Smickey  * %cl - function
219f5df1827Smickey  *	for %cl=2 (set resume timer)
220f5df1827Smickey  * %ch - seconds in BCD
221f5df1827Smickey  * %dh - hours in BCD
222f5df1827Smickey  * %dl - minutes in BCD
223f5df1827Smickey  * %si - month in BCD (high), day in BCD (low)
224f5df1827Smickey  * %di - year in BCD
225f5df1827Smickey  */
226f5df1827Smickey #define	APM_RESUME_TIMER	0x5311
227f5df1827Smickey #define		APM_RT_DISABLE	0x0
228f5df1827Smickey #define		APM_RT_GET	0x1
229f5df1827Smickey #define		APM_RT_SET	0x2
230f5df1827Smickey 
231f5df1827Smickey /* %bx - APM_DEV_APM_BIOS
232f5df1827Smickey  * %cx - function
233f5df1827Smickey  */
234f5df1827Smickey #define	APM_RESUME_ON_RING	0x5312
235f5df1827Smickey #define		APM_ROR_DISABLE	0x0
236f5df1827Smickey #define		APM_ROR_ENABLE	0x1
237f5df1827Smickey #define		APM_ROR_STATUS	0x2
238f5df1827Smickey 
239f5df1827Smickey /* %bx - APM_EDV_APM_BIOS
240f5df1827Smickey  * %cx - function
241f5df1827Smickey  */
242f5df1827Smickey #define	APM_INACTIVITY_TIMER	0x5313
243f5df1827Smickey #define		APM_IT_DISABLE	0x0
244f5df1827Smickey #define		APM_IT_ENABLE	0x1
245f5df1827Smickey #define		APM_IT_STATUS	0x2
246f5df1827Smickey 
247f5df1827Smickey /* %bh - function */
248f5df1827Smickey #define APM_OEM			0x5380
249f5df1827Smickey #define		APM_OEM_INSTCHECK	0x7f	/* %bx - OEM ID */
250f5df1827Smickey 
251f5df1827Smickey /*
252f5df1827Smickey  * LP (Laptop Package)
253f5df1827Smickey  *
254f5df1827Smickey  * Copyright (C) 1994 by HOSOKAWA Tatsumi <hosokawa@mt.cs.keio.ac.jp>
255f5df1827Smickey  *
256f5df1827Smickey  * This software may be used, modified, copied, and distributed, in
257f5df1827Smickey  * both source and binary form provided that the above copyright and
258f5df1827Smickey  * these terms are retained. Under no circumstances is the author
259f5df1827Smickey  * responsible for the proper functioning of this software, nor does
260f5df1827Smickey  * the author assume any responsibility for damages incurred with its
261f5df1827Smickey  * use.
262f5df1827Smickey  *
263f5df1827Smickey  * Sep., 1994	Implemented on FreeBSD 1.1.5.1R (Toshiba AVS001WD)
264f5df1827Smickey  */
265f5df1827Smickey 
266f5df1827Smickey #define APM_BATTERY_ABSENT 4
267f5df1827Smickey 
268f5df1827Smickey struct apm_power_info {
269f5df1827Smickey 	u_char battery_state;
270f5df1827Smickey 	u_char ac_state;
271f5df1827Smickey 	u_char battery_life;
272f5df1827Smickey 	u_char spare1;
273f5df1827Smickey 	u_int minutes_left;		/* estimate */
274f5df1827Smickey 	u_int spare2[6];
275f5df1827Smickey };
276f5df1827Smickey 
277f5df1827Smickey struct apm_ctl {
278f5df1827Smickey 	u_int dev;
279f5df1827Smickey 	u_int mode;
280f5df1827Smickey };
281f5df1827Smickey 
282f5df1827Smickey #define	APM_IOC_REJECT	_IOW('A', 0, struct apm_event_info) /* reject request # */
283f5df1827Smickey #define	APM_IOC_STANDBY	_IO('A', 1)	/* put system into standby */
284f5df1827Smickey #define	APM_IOC_SUSPEND	_IO('A', 2)	/* put system into suspend */
285f5df1827Smickey #define	APM_IOC_GETPOWER _IOR('A', 3, struct apm_power_info) /* fetch battery state */
286f5df1827Smickey #define	APM_IOC_DEV_CTL	_IOW('A', 5, struct apm_ctl) /* put device into mode */
287f5df1827Smickey #define APM_IOC_PRN_CTL _IOW('A', 6, int ) /* driver power status msg */
288f5df1827Smickey #define		APM_PRINT_ON	0	/* driver power status displayed */
289f5df1827Smickey #define		APM_PRINT_OFF	1	/* driver power status not displayed */
290f5df1827Smickey #define		APM_PRINT_PCT	2	/* driver power status only displayed
291f5df1827Smickey 					   if the percentage changes */
2927939ba9cSoga #define	APM_IOC_STANDBY_REQ	_IO('A', 7)	/* request standby */
2937939ba9cSoga #define	APM_IOC_SUSPEND_REQ	_IO('A', 8)	/* request suspend */
2943d908d29Sderaadt #define	APM_IOC_HIBERNATE	_IO('A', 9)	/* put system into hibernate */
295f5df1827Smickey 
296f5df1827Smickey #ifdef _KERNEL
297f5df1827Smickey extern void apm_cpu_busy(void);
298f5df1827Smickey extern void apm_cpu_idle(void);
299f5df1827Smickey extern void apminit(void);
300f5df1827Smickey int apm_set_powstate(u_int devid, u_int powstate);
301f5df1827Smickey #endif /* _KERNEL */
302f5df1827Smickey 
3032fa72412Spirofti #endif /* _MACHINE_APMVAR_H_ */
304