| APM(4) | Device Drivers Manual (i386) | APM(4) |
apm — advanced
power management device interface
apm0 at bios0 flags 0x0000
The apm driver provides an interface to
the Advanced Power Management (APM) BIOS functions. The driver supports
versions 1.0, 1.1, and 1.2 interface specifications.
This driver also provides an interface to acpi(4) on some machines.
The low two bytes of the flags specify the version of the specification driver should conform to in binary decimal notation. The value of 0x0101 would specify version 1.1 of the interface specification to be used.
The value of 0x10000 specifies whether to leave interrupts enabled when calling APM BIOS routines. This is needed for some IBM laptops, the symptoms are hangs and freezes on suspend, stand by, and hibernation activities.
The value of 0x20000 specifies to swap the bytes of the battery life estimation (the DX register) as given from the APM BIOS. This is needed for some SONY VAIO laptops, such as some 505 models.
Configuration options:
APMDEBUGDIAGNOSTICDEBUGThe apm driver implements the following
ioctl(2) calls. They are defined
in <machine/apmvar.h>.
APM_IOC_REJECTAPM_IOC_STANDBYno parameters) Request “standby”
mode.APM_IOC_SUSPENDno parameters) Request “suspend”
mode.APM_IOC_HIBERNATEno parameters) Request “hibernate”
mode.APM_IOC_GETPOWERstruct apm_power_info) Request the current power
state. The argument structure is as follows:
struct apm_power_info {
u_char battery_state;
u_char ac_state;
u_char battery_life;
u_char spare1;
u_int minutes_left;
u_int spare2[6];
};
The following values are defined for battery_state:
APM_BATT_HIGHAPM_BATT_LOWAPM_BATT_CRITICALAPM_BATT_CHARGINGAPM_BATT_UNKNOWNAPM_BATTERY_ABSENTThe following values are defined for ac_state:
APM_AC_OFFAPM_AC_ONAPM_AC_BACKUPAPM_AC_UNKNOWNThe battery_life value contains the estimated percentage of battery life available. 100% indicates a full charge.
The minutes_left value contains the estimated number of minutes of battery life remaining.
APM_IOC_DEV_CTLstruct apm_ctl) Allows an application to directly
set the APM operating mode. The argument structure is as follows:
struct apm_ctl {
u_int dev;
u_int mode;
};
dev indicates the device, typically
APM_DEV_ALLDEVS.
mode indicates the desired operating mode. Possible values are
APM_IOC_PRN_CTLint) This
ioctl(2) controls message output
by the APM driver when a power change event is detected. The integer
parameter is one of:
APM_PRINT_ONAPM_PRINT_OFFAPM_PRINT_PCTEBUSY.The apm driver source code contains these
copyrights:
Copyright
(c) 1995 John T. Kohl. All rights reserved.Copyright
(C) 1994 by HOSOKAWA Tatsumi
<hosokawa@mt.cs.keio.ac.jp>...and has been hacked on by many others since.
Not all the BIOSes support power down the way we are attempting to execute it.
Not all BIOS vendors even read the specification.
| January 30, 2023 | openbsd |