APMD(8) - System Manager's Manual

APMD(8) - System Manager’s Manual #

APMD(8) - System Manager’s Manual

NAME #

apmd - Advanced Power Management daemon

SYNOPSIS #

apmd [-AadHLs] [-f devname] [-S sockname] [-t seconds] [-Z percent] [-z percent]

DESCRIPTION #

apmd monitors the advanced power management device, apm(4), acting on signaled events and upon user requests as sent by the apm(8) program.

For suspend and standby request events delivered by the BIOS, or via apm(8), apmd runs the appropriate configuration program (if one exists), syncs the buffer cache to disk and initiates the requested state. When resuming after suspend or standby, apmd runs the appropriate configuration program (if one exists).

When the power status changes (external power is connected or disconnected), apmd fetches the current status and reports it via syslog(3) with logging facility LOG_DAEMON.

The options are as follows:

-A

Start apmd in automatic performance adjustment mode (the default).

-a

BIOS-initiated suspend or standby requests are ignored if the system is connected to line current and not running from batteries (user requests are still honored).

-d

apmd enters debug mode, staying in the foreground. Logging output is printed to stderr.

-f devname

Specify an alternate device file name, devname.

-H

Start apmd in manual performance adjustment mode, initialising hw.setperf to 100.

-L

Start apmd in manual performance adjustment mode, initialising hw.setperf to 0.

-S sockname

Specify an alternate socket name, sockname. The socket is protected to mode 0660, UID 0, GID 0; this protects access to suspend requests to authorized users only.

-s

Current battery statistics are reported via syslog(3) and apmd exits without monitoring the APM status.

-t seconds

apmd periodically polls the APM driver for the current power state. If the battery charge level changes substantially or the external power status changes, the new status is logged. The polling rate defaults to once per 10 minutes, but may be specified using the -t command-line flag.

-Z percent

Automatically hibernate the system if no AC is connected and the estimated battery life is equal or below percent.

-z percent

Automatically suspend the system if no AC is connected and the estimated battery life is equal or below percent.

If both -Z and -z are specified, the last one will supersede the other. After a resume, the effect of those options is inhibited for 60 seconds.

When a client requests a suspend or stand-by state, apmd does not wait for positive confirmation that the requested state has been entered before replying to the client; to do so would mean the client does not get a reply until the system resumes from its sleep state. Rather, apmd replies with the intended state to the client and then places the system in the requested state after running the configuration script and flushing the buffer cache.

Actions can be configured for the following transitions: suspend, hibernate, standby, resume, powerup, and powerdown. The suspend, hibernate and standby actions are run prior to apmd performing any other actions (such as disk syncs) and entering the new state. The resume program is run after resuming from a stand-by or suspended state. The powerup and powerdown programs are run after the power status (AC connected or not) changes, as well as after a resume (if the power status changed in the mean time).

FILES #

/dev/apmctl

Default device used to control the APM kernel driver.

/etc/apm/suspend

/etc/apm/hibernate

/etc/apm/standby

/etc/apm/resume

/etc/apm/powerup

/etc/apm/powerdown

These files contain the host’s customized actions. Each file must be an executable binary or shell script. A single program or script can be used to control all transitions by examining the name by which it was called, which is one of suspend, hibernate, standby, resume, powerup, or powerdown.

/var/run/apmdev

Default UNIX-domain socket used for communication with apm(8).

SEE ALSO #

syslog(3), apm(4), apm(8), sysctl(8)

Advanced Power Management (APM) BIOS Interface Specification (revision 1.2), Intel Corporation and Microsoft Corporation.

HISTORY #

The apmd command first appeared in NetBSD 1.3. OpenBSD support was added in OpenBSD 1.2.

OpenBSD 7.5 - May 28, 2022