diff options
author | phk <phk@FreeBSD.org> | 1994-11-01 22:46:40 +0000 |
---|---|---|
committer | phk <phk@FreeBSD.org> | 1994-11-01 22:46:40 +0000 |
commit | 78746675615710e5ad559354cce31bf7f7e3dba1 (patch) | |
tree | 9b7973e6dace2096f3258a313ca64dba0ee4c4ca /usr.sbin | |
parent | dcf7506baaa555db6bb633aacabb8788461d51f5 (diff) | |
download | FreeBSD-src-78746675615710e5ad559354cce31bf7f7e3dba1.zip FreeBSD-src-78746675615710e5ad559354cce31bf7f7e3dba1.tar.gz |
The latest user-land changes from the author. I added a big warning to the
apm.4 man-page. I also hope the Makefiles make sense now.
Submitted by: HOSOKAWA Tatsumi
Diffstat (limited to 'usr.sbin')
-rw-r--r-- | usr.sbin/apm/Makefile | 12 | ||||
-rw-r--r-- | usr.sbin/apm/apm.8 | 88 | ||||
-rw-r--r-- | usr.sbin/apm/apm.c | 10 | ||||
-rw-r--r-- | usr.sbin/apmconf/Makefile | 5 | ||||
-rw-r--r-- | usr.sbin/apmconf/apmconf.8 | 60 | ||||
-rw-r--r-- | usr.sbin/apmconf/apmconf.c | 52 |
6 files changed, 169 insertions, 58 deletions
diff --git a/usr.sbin/apm/Makefile b/usr.sbin/apm/Makefile index 1198407..ffcd5cf 100644 --- a/usr.sbin/apm/Makefile +++ b/usr.sbin/apm/Makefile @@ -1,10 +1,6 @@ -# $Id: Makefile,v 1.1 1994/10/01 03:23:23 davidg Exp $ - PROG= apm -# CFLAGS+= -I/sys/i386/include -# BINGRP= apm -# BINMODE= 550 -# LINKS= ${DESTDIR}/usr/sbin/apm ${DESTDIR}/usr/sbin/zzz -NOMAN= 1 - +LINKS= ${BINDIR}apm /usr/sbin/zzz +MANDIR= /usr/share/man/man +MAN8= apm.8 +MLINKS= apm.8 zzz.8 .include <bsd.prog.mk> diff --git a/usr.sbin/apm/apm.8 b/usr.sbin/apm/apm.8 new file mode 100644 index 0000000..6e975ac --- /dev/null +++ b/usr.sbin/apm/apm.8 @@ -0,0 +1,88 @@ +.\" LP (Laptop Package) +.\" +.\" Copyright (c) 1994 by HOSOKAWA, Tatsumi <hosokawa@mt.cs.keio.ac.jp> +.\" +.\" This software may be used, modified, copied, and distributed, in +.\" both source and binary form provided that the above copyright and +.\" these terms are retained. Under no circumstances is the author +.\" responsible for the proper functioning of this software, nor does +.\" the author assume any responsibility for damages incurred with its +.\" use. +.Dd November 1, 1994 +.Dt APM 8 +.Os +.Sh NAME +.Nm apm, zzz +.Nd control the APM BIOS and display its information +.Sh SYNOPSIS +.Nm apm +.Op Fl z +.Op Fl b +.Op Fl a +.Op Fl l +.Pp +.Nm zzz +.Sh DESCRIPTION +.Nm apm +controls the Intel / Microsoft APM (Advanced Power Management) BIOS and +displays the current status of APM on laptop PCs. +.Nm zzz +suspends the system by controlling APM. +.Pp +The following options are available for +.Nm apm +(no options are available for +.Nm zzz. +) +If no options are specified, +.Nm apm +displays information and current status of APM in verbose mode. +.Bl -tag -width indent +.It Fl z +Suspend the system. It is equivalent to +.Nm zzz. +.Pp +.It Fl b +Display an integer value reflecting the current battery status. +The values 0, 1, 2, 3, correspond to the +.Dq high +status, +.Dq low +status, +.Dq critical +status, +.Dq charging +status respectively. +.Pp +.It Fl a +Display the current AC-line status as an integer value. The values +0 and 1 correspond to the +.Dq off-line +state and +.Dq on-line +state, respectively. +.Pp +.It Fl l +Display the remaining battery percentage. If your laptop does not +support this function, 255 is displayed. +.Sh BUGS +Some APM implementations do not support parameters needed by +.Nm apm. +On such systems, +.Nm apm +displays them as unknown. +.Pp +Some APM implementations cannot handle events such as pushing the +power button or closing the cover. On such implementations, the system +.Ar must +be suspended +.Ar only +by using +.Nm apm +or +.Nm zzz. +.Sh SEE ALSO +.Xr apm 4 , +.Xr apmconf 8 +.Sh AUTHOR +HOSOKAWA, Tatsumi <hosokawa@mt.cs.keio.ac.jp> (Keio Univ., Japan) diff --git a/usr.sbin/apm/apm.c b/usr.sbin/apm/apm.c index e2e1224..224bc4e 100644 --- a/usr.sbin/apm/apm.c +++ b/usr.sbin/apm/apm.c @@ -17,9 +17,9 @@ #include <string.h> #include <sys/file.h> #include <sys/ioctl.h> -#include <machine/apm_bios.h> +#include <apm_bios.h> -#define APMDEV "/dev/apm" +#define APMDEV "/dev/apm0" int main_argc; char **main_argv; @@ -103,7 +103,8 @@ int main(int argc, char *argv[]) for (i = argc - 1; i >= 1; i--) { if (argv[i][0] != '-') { - fprintf(stderr, "%s: Unknown option '%s'.", argv[0], argv[i]); + fprintf(stderr, "%s: Unknown option '%s'.\n", argv[0], argv[i]); + exit(1); } for (j = 1; argv[i][j]; j++) { switch (argv[i][j]) { @@ -123,6 +124,9 @@ int main(int argc, char *argv[]) batt_life = 1; all_info = 0; break; + default: + fprintf(stderr, "%s Unknown option '%s'.\n", argv[0], argv[i]); + exit(1); } } } diff --git a/usr.sbin/apmconf/Makefile b/usr.sbin/apmconf/Makefile index 9cdb007..b451367 100644 --- a/usr.sbin/apmconf/Makefile +++ b/usr.sbin/apmconf/Makefile @@ -1,8 +1,5 @@ -# $Id$ PROG= apmconf -# BINMODE= 550 -# BINOWN= root -NOMAN= 1 +MAN8= apmconf.8 .include <bsd.prog.mk> diff --git a/usr.sbin/apmconf/apmconf.8 b/usr.sbin/apmconf/apmconf.8 new file mode 100644 index 0000000..d49e6de --- /dev/null +++ b/usr.sbin/apmconf/apmconf.8 @@ -0,0 +1,60 @@ +.\" LP (Laptop Package) +.\" +.\" Copyright (c) 1994 by HOSOKAWA, Tatsumi <hosokawa@mt.cs.keio.ac.jp> +.\" +.\" This software may be used, modified, copied, and distributed, in +.\" both source and binary form provided that the above copyright and +.\" these terms are retained. Under no circumstances is the author +.\" responsible for the proper functioning of this software, nor does +.\" the author assume any responsibility for damages incurred with its +.\" use. +.Dd November 1, 1994 +.Dt APMCONF 8 +.Os +.Sh NAME +.Nm apmconf +.Nd configure APM BIOS driver +.Sh SYNOPSIS +.Nm apmconf +.Op Fl e +.Op Fl d +.Op Fl h +.Op Fl t +.Sh DESCRIPTION +.Nm apmconf +is used to configure the APM (Advanced Power Management) BIOS driver +.Xr apm 4 +on laptop PCs. +.Pp +The following options are available. +.Bl -tag -width indent +.It Fl e +Enable power management. +.It Fl d +Disable power management. +.El +.Pp +These options enable/disable power management functions provided by +.Xr apm 4 . +.Bl -tag -width indent +.It Fl h +Enable HLT instruction in kernel context switch routine. +.It Fl t +Disable HLT instruction in kernel context switch routine. +.El +.Pp +These options are not necessary for almost all APM implementations, +but for some implementations whose +.Dq Pa Idle CPU +call executes both CPU clock slowdown and HLT instruction, +.Fl t +is necessary to prevent the system from reducing its peak performance. +See +.Xr apm 4 +for details. +.Sh SEE ALSO +.Xr apm 4 , +.Xr apm 8 , +.Xr zzz 8 +.Sh AUTHOR +HOSOKAWA, Tatsumi <hosokawa@mt.cs.keio.ac.jp> (Keio Univ., Japan) diff --git a/usr.sbin/apmconf/apmconf.c b/usr.sbin/apmconf/apmconf.c index de1aea2..f8886d4 100644 --- a/usr.sbin/apmconf/apmconf.c +++ b/usr.sbin/apmconf/apmconf.c @@ -20,10 +20,8 @@ #include <sys/ioctl.h> #include <machine/apm_bios.h> -#define CONFIGFILE "/etc/apm.conf" -#define APMDEV "/dev/apm" +#define APMDEV "/dev/apm0" -static int verbose = 0; static int enable = 0, disable = 0; static int haltcpu = 0, nothaltcpu = 0; static int main_argc; @@ -34,18 +32,13 @@ parse_option(void) { int i, option; char *optarg; - enum {OPT_NONE, OPT_VERBOSE, - OPT_ENABLE, OPT_DISABLE, OPT_HALTCPU, OPT_NOTHALTCPU} mode; + enum {OPT_NONE, OPT_ENABLE, OPT_DISABLE, OPT_HALTCPU, OPT_NOTHALTCPU} mode; for (i = 1; i < main_argc; i++) { option = 0; mode = OPT_NONE; if (main_argv[i][0] == '-') { switch (main_argv[i][1]) { - case 'v': - mode = OPT_VERBOSE; - option = 0; - break; case 'e': mode = OPT_ENABLE; option = 0; @@ -76,9 +69,6 @@ parse_option(void) } switch (mode) { - case OPT_VERBOSE: - verbose = 1; - break; case OPT_ENABLE: enable = 1; break; @@ -95,44 +85,20 @@ parse_option(void) } } +static struct apm_eqv_event eqv_event[APM_MAX_EQUIV_EVENTS]; static int eqv_num = 0; - -#define PMEV_SYMBOL(name) {#name, name} -#define ARRAY_SIZEOF(array) (sizeof(array) / sizeof(array[0])) - -typedef struct pmev_symbol { - char *name; - int id; -} *pmev_symbol_t; - -static struct pmev_symbol pmev_symbols[] = { - PMEV_SYMBOL(PMEV_NOEVENT), - PMEV_SYMBOL(PMEV_STANDBYREQ), - PMEV_SYMBOL(PMEV_SUSPENDREQ), - PMEV_SYMBOL(PMEV_NORMRESUME), - PMEV_SYMBOL(PMEV_CRITRESUME), - PMEV_SYMBOL(PMEV_BATTERYLOW), - PMEV_SYMBOL(PMEV_POWERSTATECHANGE), - PMEV_SYMBOL(PMEV_UPDATETIME), - PMEV_SYMBOL(PMEV_CRITSUSPEND), - PMEV_SYMBOL(PMEV_USERSTANDBYREQ), - PMEV_SYMBOL(PMEV_USERSUSPENDREQ), - PMEV_SYMBOL(PMEV_STANDBYRESUME), -}; - -static int -pmev(char *name, int *id) +static apm_eqv_event_t +get_eqv_event(int id) { int i; - for (i = 0; i < ARRAY_SIZEOF(pmev_symbols); i++) { - if (strcasecmp(pmev_symbols[i].name, name) == 0) { - *id = pmev_symbols[i].id; - return 0; + for (i = 0; i < eqv_num; i++) { + if (id == eqv_event[i].aee_event) { + return &eqv_event[i]; } } - return 1; + return NULL; } static void |