diff options
author | agc <agc@pkgsrc.org> | 2003-10-19 09:25:02 +0000 |
---|---|---|
committer | agc <agc@pkgsrc.org> | 2003-10-19 09:25:02 +0000 |
commit | ab4f8839a0a28a721ad0970800560d646427212f (patch) | |
tree | 9942306d470a2b92538ba2b7ec21daeebca5a1d1 /sysutils/xbattbar/patches | |
parent | 787a70322caf6ec1c09022ce2c6e9574d55dbe97 (diff) | |
download | pkgsrc-ab4f8839a0a28a721ad0970800560d646427212f.tar.gz |
Update xbattbar to 1.4.2nb3 by adding support for ACPI - if APM
doesn't work, try to use ACPI to get the battery charge value, and AC
charging switch.
Known to work on my Sony VAIO (PCG-GRX315MP) with ACPI, and with thanks to:
Lubomir Sedlacik for testing on an IBM T22 with ACPI
Manuel Bouyer for testing on an IBM Thinkpad 600e with APM, and
Brian A. Seklecki for testing on a Sony PCG-R505
Diffstat (limited to 'sysutils/xbattbar/patches')
-rw-r--r-- | sysutils/xbattbar/patches/patch-ab | 203 |
1 files changed, 195 insertions, 8 deletions
diff --git a/sysutils/xbattbar/patches/patch-ab b/sysutils/xbattbar/patches/patch-ab index 2937fb2d890..83f6a5cd4dc 100644 --- a/sysutils/xbattbar/patches/patch-ab +++ b/sysutils/xbattbar/patches/patch-ab @@ -1,12 +1,199 @@ -$NetBSD: patch-ab,v 1.1 2001/11/26 20:07:35 wiz Exp $ +$NetBSD: patch-ab,v 1.2 2003/10/19 09:25:02 agc Exp $ ---- xbattbar.c.orig Fri Feb 2 06:25:29 2001 -+++ xbattbar.c -@@ -594,6 +594,7 @@ +--- xbattbar.c.orig 2001-02-02 05:25:29.000000000 +0000 ++++ xbattbar.c 2003-10-17 13:15:51.000000000 +0100 +@@ -27,6 +27,13 @@ + + #include <sys/types.h> + #include <sys/time.h> ++ ++#ifdef __NetBSD__ ++#define ENVSYSUNITNAMES ++#include <sys/envsys.h> ++#include <paths.h> ++#endif /* __NetBSD__ */ ++ + #include <signal.h> + #include <stdio.h> + #include <unistd.h> +@@ -583,46 +590,158 @@ + #define _PATH_APM_CTLDEV "/dev/apmctl" + #define _PATH_APM_NORMAL "/dev/apm" + ++/* ++ * pre: fd contains a valid file descriptor of an envsys(4) supporting device ++ * && ns is the number of sensors ++ * && etds and ebis are arrays of sufficient size ++ * post: returns 0 and etds and ebis arrays are filled with sensor info ++ * or returns -1 on failure ++ */ ++static int ++fillsensors(int fd, envsys_tre_data_t *etds, envsys_basic_info_t *ebis, ++ size_t ns) ++{ ++ int i; ++ ++ for (i = 0; i < ns; ++i) { ++ ebis[i].sensor = i; ++ if (ioctl(fd, ENVSYS_GTREINFO, &ebis[i]) == -1) { ++ warn("Can't get sensor info for sensor %d", i); ++ return 0; ++ } ++ ++ etds[i].sensor = i; ++ if (ioctl(fd, ENVSYS_GTREDATA, &etds[i]) == -1) { ++ warn("Can't get sensor data for sensor %d", i); ++ return 0; ++ } ++ } ++ return 1; ++} ++ ++/* ++ * pre: fd contains a valid file descriptor of an envsys(4) supporting device ++ * post: returns the number of valid sensors provided by the device ++ * or -1 on error ++ */ ++static size_t ++numsensors(int fd) ++{ ++ int count = 0, valid = 1; ++ envsys_tre_data_t etd; ++ etd.sensor = 0; ++ ++ while (valid) { ++ if (ioctl(fd, ENVSYS_GTREDATA, &etd) == -1) ++ err(1, "Can't get sensor data"); ++ ++ valid = etd.validflags & ENVSYS_FVALID; ++ if (valid) ++ ++count; ++ ++ ++etd.sensor; ++ } ++ ++ return count; ++} ++ ++static envsys_tre_data_t *etds; ++static envsys_basic_info_t *ebis; ++static int *cetds; ++ + int first = 1; + void battery_check(void) + { + int fd, r, p; + struct apm_power_info info; ++ int acpi; ++ size_t ns; ++ size_t cc; ++ int i; + ++ acpi = 0; + if ((fd = open(_PATH_APM_NORMAL, O_RDONLY)) == -1) { +- fprintf(stderr, "xbattbar: cannot open apm device\n"); ++ fd = open(_PATH_SYSMON, O_RDONLY); ++ acpi = 1; ++ } ++ if (fd < 0) { ++ fprintf(stderr, "xbattbar: cannot open %s device\n", (acpi) ? _PATH_SYSMON : _PATH_APM_NORMAL); exit(1); } -+ memset(&info, 0, sizeof(info)); - if (ioctl(fd, APM_IOC_GETPOWER, &info) != 0) { - fprintf(stderr, "xbattbar: ioctl APM_IOC_GETPOWER failed\n"); - exit(1); +- if (ioctl(fd, APM_IOC_GETPOWER, &info) != 0) { +- fprintf(stderr, "xbattbar: ioctl APM_IOC_GETPOWER failed\n"); +- exit(1); ++ if (acpi) { ++ if ((ns = numsensors(fd)) == 0) { ++ fprintf(stderr, "xbattbar: no sensors found\n"); ++ exit(1); ++ } ++ if (first) { ++ cetds = (int *)malloc(ns * sizeof(int)); ++ etds = (envsys_tre_data_t *)malloc(ns * sizeof(envsys_tre_data_t)); ++ ebis = (envsys_basic_info_t *)malloc(ns * sizeof(envsys_basic_info_t)); ++ ++ if ((cetds == NULL) || (etds == NULL) || (ebis == NULL)) { ++ err(1, "Out of memory"); ++ } ++ } ++ ++ fillsensors(fd, etds, ebis, ns); ++ ++ } else { ++ ++ memset(&info, 0, sizeof(info)); ++ if (ioctl(fd, APM_IOC_GETPOWER, &info) != 0) { ++ fprintf(stderr, "xbattbar: ioctl APM_IOC_GETPOWER failed\n"); ++ exit(1); ++ } + } + + close(fd); + + ++elapsed_time; + +- /* get current remoain */ +- if (info.battery_life > 100) { +- /* some APM BIOSes return values slightly > 100 */ +- r = 100; +- } else { +- r = info.battery_life; +- } ++ if (acpi) { ++ r = 0; ++ p = APM_AC_ON; ++ for (i = 0 ; i < ns ; i++) { ++ cc = strlen(ebis[i].desc); ++ if (strcmp(&ebis[i].desc[cc - 6], "energy") == 0) { ++ r = (etds[i].cur.data_s * 100.0) / etds[i].max.data_s; ++ } ++ if (ebis[i].units == ENVSYS_INDICATOR && ++ etds[i].cur.data_s && ++ strcmp(&ebis[i].desc[cc - 11], "discharging") == 0) { ++ p = APM_AC_OFF; ++ } ++ } ++ if (first || ac_line != p || battery_level != r) { ++ first = 0; ++ ac_line = p; ++ battery_level = r; ++ redraw(); ++ } + +- /* get AC-line status */ +- if (info.ac_state == APM_AC_ON) { +- p = APM_AC_ON; + } else { +- p = APM_AC_OFF; +- } +- +- if (first || ac_line != p || battery_level != r) { +- first = 0; +- ac_line = p; +- battery_level = r; +- redraw(); ++ /* get current remain */ ++ if (info.battery_life > 100) { ++ /* some APM BIOSes return values slightly > 100 */ ++ r = 100; ++ } else { ++ r = info.battery_life; ++ } ++ ++ /* get AC-line status */ ++ if (info.ac_state == APM_AC_ON) { ++ p = APM_AC_ON; ++ } else { ++ p = APM_AC_OFF; ++ } ++ ++ if (first || ac_line != p || battery_level != r) { ++ first = 0; ++ ac_line = p; ++ battery_level = r; ++ redraw(); ++ } + } + } + |