summaryrefslogtreecommitdiffstats
path: root/usr.sbin
diff options
context:
space:
mode:
authorphk <phk@FreeBSD.org>1994-11-01 22:46:40 +0000
committerphk <phk@FreeBSD.org>1994-11-01 22:46:40 +0000
commit78746675615710e5ad559354cce31bf7f7e3dba1 (patch)
tree9b7973e6dace2096f3258a313ca64dba0ee4c4ca /usr.sbin
parentdcf7506baaa555db6bb633aacabb8788461d51f5 (diff)
downloadFreeBSD-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/Makefile12
-rw-r--r--usr.sbin/apm/apm.888
-rw-r--r--usr.sbin/apm/apm.c10
-rw-r--r--usr.sbin/apmconf/Makefile5
-rw-r--r--usr.sbin/apmconf/apmconf.860
-rw-r--r--usr.sbin/apmconf/apmconf.c52
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
OpenPOWER on IntegriCloud