1996-08-26 03:38:57 +04:00
|
|
|
.\" Copyright (c) 1995,1996 John T. Kohl
|
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\" 3. The name of the author may not be used to endorse or promote products
|
|
|
|
.\" derived from this software without specific prior written permission.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR `AS IS'' AND ANY EXPRESS OR
|
|
|
|
.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
.\" WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
.\" DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
|
|
|
|
.\" INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
.\" (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
|
|
.\" SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
|
|
.\" STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
|
|
.\" ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
.\" POSSIBILITY OF SUCH DAMAGE.
|
2001-04-03 00:42:19 +04:00
|
|
|
.\"
|
2011-04-05 12:24:43 +04:00
|
|
|
.\" $NetBSD: apm.4,v 1.18 2011/04/05 08:24:43 wiz Exp $
|
1996-08-26 03:38:57 +04:00
|
|
|
.\"
|
|
|
|
.Dd May 18, 1996
|
|
|
|
.Dt APM 4 i386
|
2001-04-03 00:42:19 +04:00
|
|
|
.Os
|
1996-08-26 03:38:57 +04:00
|
|
|
.Sh NAME
|
|
|
|
.Nm apm
|
|
|
|
.Nd
|
|
|
|
Advanced Power Management pseudo-device driver
|
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Cd "apm0 at mainbus0"
|
2003-04-16 17:34:34 +04:00
|
|
|
.In machine/apmvar.h
|
1996-08-26 03:38:57 +04:00
|
|
|
.Pa /dev/apm
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
The
|
|
|
|
.Nm apm
|
2001-07-08 21:22:53 +04:00
|
|
|
driver provides support for the Advanced Power Management features of
|
2011-04-05 12:24:43 +04:00
|
|
|
some i386 system BIOSes.
|
|
|
|
The driver supports the Advanced Power
|
1999-12-21 14:27:55 +03:00
|
|
|
Management (APM) BIOS Interface Specification (revision 1.2), published
|
1996-08-26 03:38:57 +04:00
|
|
|
jointly by the Intel Corporation and the Microsoft Corporation.
|
|
|
|
.Pp
|
1998-09-03 01:23:52 +04:00
|
|
|
The APM driver's behavior may be adjusted by specifying any of the
|
|
|
|
following kernel configuration options:
|
1996-08-26 03:38:57 +04:00
|
|
|
.Bl -tag -width indent -compact
|
1997-03-23 22:20:30 +03:00
|
|
|
.It Dv APM_NO_IDLE
|
2011-04-05 12:24:43 +04:00
|
|
|
Do not call the BIOS CPU idle function from the system idle loop.
|
|
|
|
(Some systems will hang on certain device accesses, such as sound
|
|
|
|
cards or floppy diskette drives, without this option)
|
1996-08-26 03:38:57 +04:00
|
|
|
.It Dv APM_V10_ONLY
|
2011-04-05 12:24:43 +04:00
|
|
|
Use only the APM revision 1.0 specification calls.
|
|
|
|
(Some systems do not implement APM v1.1 very well, and generate
|
|
|
|
weird events instead of the expected events when the system suspend
|
|
|
|
key is pressed.)
|
1999-12-21 14:27:55 +03:00
|
|
|
.It Dv APM_NO_V12
|
|
|
|
Don't attach to the BIOS as APM v1.2 compliant device.
|
|
|
|
(In case there are problems with v1.2 support.)
|
|
|
|
.It Dv APM_NO_STANDBY
|
|
|
|
Do not attempt to put the system into standby mode.
|
1996-08-26 03:38:57 +04:00
|
|
|
.It Dv APM_NO_POWEROFF
|
|
|
|
Do not attempt to turn off power when halting the system.
|
2000-06-05 02:38:58 +04:00
|
|
|
.It Dv APM_FORCE_64K_SEGMENTS
|
1996-08-26 03:38:57 +04:00
|
|
|
Force the length of the APM BIOS code and data segments to 64KB.
|
2000-06-05 02:38:58 +04:00
|
|
|
.It Dv APM_ALLOW_BOGUS_SEGMENTS
|
|
|
|
Allow the use of data segments which are in unexpected locations.
|
1996-08-26 03:38:57 +04:00
|
|
|
.It Dv APMDEBUG
|
|
|
|
Enable kernel printout of events received from the APM BIOS.
|
|
|
|
.It Dv APMCALLDEBUG
|
|
|
|
Enable kernel printout of every call to the APM BIOS (this is very noisy).
|
2000-06-05 02:38:58 +04:00
|
|
|
.It Dv APM_POWER_PRINT
|
|
|
|
Print power state on console at
|
1999-09-09 07:52:21 +04:00
|
|
|
.Dv APM_POWER_CHANGE
|
2011-04-05 12:24:43 +04:00
|
|
|
events.
|
|
|
|
(Since it increases
|
2003-06-27 22:27:58 +04:00
|
|
|
.Xr syslogd 8 Ns 's
|
2011-04-05 12:24:43 +04:00
|
|
|
activity, it may consume increased battery power.
|
|
|
|
Some systems generate the events too frequently,
|
1999-09-09 07:52:21 +04:00
|
|
|
and printing the status may disturb single-user operations.)
|
1999-12-17 13:34:23 +03:00
|
|
|
.It Dv APM_DISABLE_INTERRUPTS
|
|
|
|
Set this to zero if you don't want the kernel to disable interrupts
|
2011-04-05 12:24:43 +04:00
|
|
|
before calling the BIOS.
|
|
|
|
This is required for most IBM ThinkPads, and some other newer laptops.
|
|
|
|
A good indication that you need this is that
|
|
|
|
the machine hangs just after resuming from suspended state.
|
|
|
|
It's unclear if doing this has negative effects on older BIOS, therefore it
|
1999-12-17 13:34:23 +03:00
|
|
|
defaults to one (i.e interrupts are disabled).
|
1996-08-26 03:38:57 +04:00
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
If no processes are holding open file descriptors to the APM device, the
|
2011-04-05 12:24:43 +04:00
|
|
|
driver will process the APM BIOS events itself.
|
|
|
|
If a process has the
|
1996-08-26 03:38:57 +04:00
|
|
|
device open for write, the driver defers all suspend and standby
|
|
|
|
processing to the user process as long as there is sufficient queue
|
2011-04-05 12:24:43 +04:00
|
|
|
space to store the event for the process.
|
|
|
|
If the device is only open
|
1996-08-26 03:38:57 +04:00
|
|
|
for read, the driver will report events but handle them itself.
|
|
|
|
.Pp
|
|
|
|
The APM device may be opened by multiple readers but only one
|
2011-04-05 12:24:43 +04:00
|
|
|
writer.
|
|
|
|
Multiple readers may fetch the status with
|
1996-08-26 03:38:57 +04:00
|
|
|
.Xr ioctl 2
|
|
|
|
without worrying about interference, but they must cooperate to share
|
2011-04-05 12:24:43 +04:00
|
|
|
events as only a single event queue is provided.
|
|
|
|
The device may only be
|
2003-06-27 22:27:58 +04:00
|
|
|
.Xr select 2 Ns ed
|
1996-08-26 03:38:57 +04:00
|
|
|
or manipulated with
|
|
|
|
.Xr ioctl 2 ;
|
|
|
|
.Xr read 2
|
|
|
|
and
|
|
|
|
.Xr write 2
|
|
|
|
are not supported.
|
2001-04-03 00:42:19 +04:00
|
|
|
The
|
1996-08-26 03:38:57 +04:00
|
|
|
.Xr ioctl 2
|
|
|
|
calls supported are:
|
|
|
|
.Bl -tag -width indent -compact
|
|
|
|
.It Dv APM_IOC_SUSPEND
|
2011-04-05 12:24:43 +04:00
|
|
|
Initiate an APM suspend mode.
|
|
|
|
This is a deep sleep mode which powers down most devices.
|
|
|
|
The device must be open for writing for this command to succeed.
|
1999-04-15 05:01:17 +04:00
|
|
|
.It Dv APM_IOC_STANDBY
|
2011-04-05 12:24:43 +04:00
|
|
|
Initiate an APM standby mode.
|
|
|
|
This is a light sleep mode from which the
|
|
|
|
system can quickly restore normal operation.
|
|
|
|
The device must be open for writing for this command to succeed.
|
1996-08-26 03:38:57 +04:00
|
|
|
.It Dv APM_IOC_GETPOWER
|
|
|
|
Fetch the current power status into an
|
|
|
|
.Va apm_power_info
|
|
|
|
structure.
|
|
|
|
.Bd -literal
|
|
|
|
struct apm_power_info {
|
2001-09-10 10:07:56 +04:00
|
|
|
u_char battery_state;
|
|
|
|
u_char ac_state;
|
|
|
|
u_char battery_life;
|
|
|
|
u_char spare1;
|
|
|
|
u_int minutes_left; /* estimate */
|
2001-09-12 02:52:52 +04:00
|
|
|
u_int nbattery;
|
2001-09-10 10:07:56 +04:00
|
|
|
u_int batteryid;
|
|
|
|
u_int spare2[4];
|
1996-08-26 03:38:57 +04:00
|
|
|
};
|
|
|
|
.Ed
|
2001-09-10 10:07:56 +04:00
|
|
|
.Pp
|
|
|
|
The structure should be zeroed (except for
|
|
|
|
.Va batteryid )
|
|
|
|
before
|
|
|
|
being passed.
|
|
|
|
.Pp
|
1996-08-26 03:38:57 +04:00
|
|
|
.Va battery_state
|
2001-04-03 00:42:19 +04:00
|
|
|
is one of
|
1996-08-26 03:38:57 +04:00
|
|
|
.Dv APM_BATT_HIGH ,
|
|
|
|
.Dv APM_BATT_LOW ,
|
|
|
|
.Dv APM_BATT_CRITICAL ,
|
|
|
|
.Dv APM_BATT_CHARGING ,
|
|
|
|
or
|
|
|
|
.Dv APM_BATT_UNKNOWN .
|
2001-09-10 10:07:56 +04:00
|
|
|
.Pp
|
1996-08-26 03:38:57 +04:00
|
|
|
.Va ac_state
|
2001-04-03 00:42:19 +04:00
|
|
|
is one of
|
1996-08-26 03:38:57 +04:00
|
|
|
.Dv APM_AC_OFF ,
|
|
|
|
.Dv APM_AC_ON ,
|
|
|
|
.Dv APM_AC_BACKUP ,
|
|
|
|
or
|
|
|
|
.Dv APM_AC_UNKNOWN .
|
2001-09-10 10:07:56 +04:00
|
|
|
.Pp
|
1996-08-26 03:38:57 +04:00
|
|
|
.Va battery_life
|
|
|
|
is the percentage estimated remaining normal battery life (or 0 if the
|
|
|
|
BIOS cannot provide an estimate).
|
2001-09-10 10:07:56 +04:00
|
|
|
.Pp
|
1996-08-26 03:38:57 +04:00
|
|
|
.Va minutes_left
|
|
|
|
is an estimated remaining lifetime (or 0 if the BIOS cannot provide an
|
|
|
|
estimate).
|
2001-09-10 10:07:56 +04:00
|
|
|
.Pp
|
|
|
|
.Va nbattery
|
2011-04-05 12:24:43 +04:00
|
|
|
is the number of batteries in the system.
|
|
|
|
If the system is using APM v1.1 or earlier, nbattery will always return 0.
|
2001-09-10 10:07:56 +04:00
|
|
|
.Pp
|
|
|
|
Batteries are numbered from a base of 1.
|
|
|
|
If the passed value of
|
|
|
|
.Va batteryid
|
|
|
|
is 0, the returned values will reflect the percentage remaining, minutes
|
|
|
|
left, etc. of all of the system's batteries taken together.
|
|
|
|
If the passed value of
|
|
|
|
.Va batteryid
|
|
|
|
is nonzero, the return values will reflect the indicated
|
|
|
|
battery's percentage remaining, minutes left, etc.
|
|
|
|
It is an error to set
|
|
|
|
.Va batteryid
|
2001-09-12 02:52:52 +04:00
|
|
|
to a value greater than that returned by
|
2001-09-10 10:07:56 +04:00
|
|
|
.Va nbattery .
|
|
|
|
If the system is using APM v1.1 or earlier, individual batteries
|
2001-09-12 02:52:52 +04:00
|
|
|
cannot be queried, and
|
2001-09-10 10:07:56 +04:00
|
|
|
.Va nbattery
|
|
|
|
will always return 0.
|
|
|
|
.Va batteryid
|
|
|
|
is always set to the passed value upon return.
|
1996-08-26 03:38:57 +04:00
|
|
|
.It Dv APM_IOC_NEXTEVENT
|
|
|
|
Fetch the next event from the APM BIOS into an
|
|
|
|
.Va apm_event_info
|
2011-04-05 12:24:43 +04:00
|
|
|
structure.
|
|
|
|
If no more events are ready, this will return
|
1996-08-26 03:38:57 +04:00
|
|
|
.Dv EAGAIN .
|
|
|
|
.Bd -literal
|
|
|
|
struct apm_event_info {
|
|
|
|
u_int type;
|
|
|
|
u_int index;
|
|
|
|
u_int spare[8];
|
|
|
|
};
|
|
|
|
.Ed
|
|
|
|
.Va type
|
|
|
|
is one of the APM event types (APM_STANDBY_REQ through
|
|
|
|
APM_SYS_STANDBY_RESUME).
|
|
|
|
.Va index
|
|
|
|
is the ordinal event sequence number.
|
|
|
|
.El
|
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr apmd 8
|
|
|
|
.Sh REFERENCES
|
|
|
|
Advanced Power Management (APM) BIOS Interface Specification (Revision
|
2011-04-05 12:24:43 +04:00
|
|
|
1.1), Intel Corporation and Microsoft Corporation.
|
|
|
|
Intel order number 241704-001; Microsoft part number 781-110-X01.
|
1996-08-26 03:38:57 +04:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Nm apm
|
1998-02-06 08:54:12 +03:00
|
|
|
pseudo-device driver appeared in
|
|
|
|
.Nx 1.3 .
|