2000-06-20 23:11:12 -04:00
|
|
|
--- xbatt.c.orig Wed Jun 21 18:58:25 2000
|
|
|
|
+++ xbatt.c Wed Jun 21 19:02:20 2000
|
|
|
|
@@ -65,6 +65,11 @@
|
1998-07-21 10:36:02 -04:00
|
|
|
# define APMDEV22 "/dev/apm"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
+#ifdef __OpenBSD__
|
|
|
|
+# include <machine/apmvar.h>
|
2000-06-20 23:11:12 -04:00
|
|
|
+# define APMDEV "/dev/apm"
|
1998-07-21 10:36:02 -04:00
|
|
|
+#endif /* __OpenBSD__ */
|
|
|
|
+
|
|
|
|
#include "pixmaps/battery.xpm"
|
|
|
|
#include "pixmaps/unknown.xpm"
|
|
|
|
#include "bitmaps/full.xbm"
|
2000-06-20 23:11:12 -04:00
|
|
|
@@ -195,6 +200,12 @@
|
1998-07-21 10:36:02 -04:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
+#ifdef __OpenBSD__
|
2000-06-20 23:11:12 -04:00
|
|
|
+ /* initialize APM Interface */
|
|
|
|
+ if ((apmfd = open(APMDEV, O_RDONLY)) == -1)
|
1998-07-21 10:36:02 -04:00
|
|
|
+ err(1, "cannot open apm device");
|
|
|
|
+#endif /* __OpenBSD__ */
|
|
|
|
+
|
|
|
|
/* start X-Window session */
|
|
|
|
XtSetLanguageProc( NULL, NULL, NULL );
|
|
|
|
toplevel = XtOpenApplication(&appContext, "XBatt",
|
2000-06-20 23:11:12 -04:00
|
|
|
@@ -371,6 +382,50 @@
|
1998-07-21 10:36:02 -04:00
|
|
|
/* chrging or not. */
|
|
|
|
}
|
|
|
|
#endif /* FreeBSD */
|
|
|
|
+
|
|
|
|
+#ifdef __OpenBSD__
|
|
|
|
+ struct apm_power_info info;
|
|
|
|
+
|
|
|
|
+ if (ioctl(apmfd, APM_IOC_GETPOWER, &info) == -1)
|
|
|
|
+ err(1, "ioctl APM_IOC_GETPOWER failed");
|
|
|
|
+
|
|
|
|
+ /* get current status */
|
|
|
|
+ if (info.battery_life == APM_BATT_LIFE_UNKNOWN) {
|
2000-06-20 23:11:12 -04:00
|
|
|
+ switch (info.battery_state) {
|
|
|
|
+ case APM_BATT_HIGH:
|
|
|
|
+ ret.remain = 100;
|
|
|
|
+ break;
|
|
|
|
+ case APM_BATT_LOW:
|
|
|
|
+ ret.remain = 40;
|
|
|
|
+ break;
|
|
|
|
+ case APM_BATT_CRITICAL:
|
|
|
|
+ ret.remain = 10;
|
|
|
|
+ break;
|
|
|
|
+ default: /* expected to be APM_STAT_UNKNOWN */
|
|
|
|
+ ret.remain = APM_STAT_UNKNOWN;
|
|
|
|
+ }
|
1998-07-21 10:36:02 -04:00
|
|
|
+ } else if (info.battery_life > 100) {
|
2000-06-20 23:11:12 -04:00
|
|
|
+ /* some APM BIOSes return values slightly > 100 */
|
|
|
|
+ ret.remain = 100;
|
1998-07-21 10:36:02 -04:00
|
|
|
+ } else {
|
2000-06-20 23:11:12 -04:00
|
|
|
+ ret.remain = info.battery_life;
|
1998-07-21 10:36:02 -04:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ /* get AC-line status */
|
|
|
|
+ if (info.ac_state == APM_AC_ON) {
|
2000-06-20 23:11:12 -04:00
|
|
|
+ ret.acline = APM_STAT_LINE_ON;
|
1998-07-21 10:36:02 -04:00
|
|
|
+ } else {
|
2000-06-20 23:11:12 -04:00
|
|
|
+ ret.acline = APM_STAT_LINE_OFF;
|
1998-07-21 10:36:02 -04:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ /* get charging status */
|
|
|
|
+ if (info.battery_state == APM_BATT_CHARGING) {
|
2000-06-20 23:11:12 -04:00
|
|
|
+ ret.charge = APM_STAT_BATT_CHARGING;
|
1998-07-21 10:36:02 -04:00
|
|
|
+ } else {
|
2000-06-20 23:11:12 -04:00
|
|
|
+ ret.charge = APM_STAT_BATT_HIGH; /* I only want to know, */
|
|
|
|
+ /* chrging or not. */
|
1998-07-21 10:36:02 -04:00
|
|
|
+ }
|
|
|
|
+#endif /* __OpenBSD__ */
|
|
|
|
|
|
|
|
#ifdef __linux__
|
|
|
|
char buffer[64];
|