summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGordon Willem Klok <gwk@cvs.openbsd.org>2007-04-22 20:17:04 +0000
committerGordon Willem Klok <gwk@cvs.openbsd.org>2007-04-22 20:17:04 +0000
commitef87ec7354a7ae7113394a2113b2577f6b76d24c (patch)
treec5cb8be0fb8fad920a91b53ccf2c3197761c870f
parent9f391c7371f8b4356529103026371297ea800551 (diff)
Add sysbutton a driver for the 'System identifier' button found on the
fornt panel of the xserve (the button with the triangle on it). This driver will dump you into ddb at the press of a button if the ddb.console sysctl is set. The bug still has one unresolved issue if ddb.console is not set and you press and hold the button you will cause a interrupt storm that will slow the system down. So if you keep your xserve near a toddler or you yourself are a toddler you might want to consider disabling this device remember buttons arn't toys. ok deraadt.
-rw-r--r--sys/arch/macppc/conf/GENERIC3
-rw-r--r--sys/arch/macppc/conf/files.macppc6
-rw-r--r--sys/arch/macppc/dev/sysbutton.c91
3 files changed, 98 insertions, 2 deletions
diff --git a/sys/arch/macppc/conf/GENERIC b/sys/arch/macppc/conf/GENERIC
index b3e94db21e2..e928b1027ac 100644
--- a/sys/arch/macppc/conf/GENERIC
+++ b/sys/arch/macppc/conf/GENERIC
@@ -1,4 +1,4 @@
-# $OpenBSD: GENERIC,v 1.164 2007/04/22 18:04:24 deraadt Exp $g
+# $OpenBSD: GENERIC,v 1.165 2007/04/22 20:17:03 gwk Exp $g
#
# For further information on compiling OpenBSD kernels, see the config(8)
# man page.
@@ -150,6 +150,7 @@ pi2c0 at adb? # PMU I2C
wi* at macobio? # airport
macgpio* at macobio? # GPIO, PMU interrupt router.
macgpio* at macgpio? # GPIO, PMU interrupt router.
+sysbutton* at macgpio? # Xserve system id button.
akbd* at adb? # ADB keyboard
wskbd* at akbd? mux 1
ams* at adb? # ADB mouse
diff --git a/sys/arch/macppc/conf/files.macppc b/sys/arch/macppc/conf/files.macppc
index e022eeff41d..f23eab75a28 100644
--- a/sys/arch/macppc/conf/files.macppc
+++ b/sys/arch/macppc/conf/files.macppc
@@ -1,4 +1,4 @@
-# $OpenBSD: files.macppc,v 1.52 2007/04/22 18:04:24 deraadt Exp $
+# $OpenBSD: files.macppc,v 1.53 2007/04/22 20:17:03 gwk Exp $
#
# macppc-specific configuration info
@@ -232,6 +232,10 @@ attach macgpio at macobio with macgpio
attach macgpio at macgpio with macgpio_gpio
file arch/macppc/dev/macgpio.c macgpio
+device sysbutton {}
+attach sysbutton at macgpio
+file arch/macppc/dev/sysbutton.c
+
attach wdc at mediabay, macobio, kauaiata with wdc_obio
file arch/macppc/dev/wdc_obio.c wdc_obio
diff --git a/sys/arch/macppc/dev/sysbutton.c b/sys/arch/macppc/dev/sysbutton.c
new file mode 100644
index 00000000000..a8845a84c5d
--- /dev/null
+++ b/sys/arch/macppc/dev/sysbutton.c
@@ -0,0 +1,91 @@
+/*
+ * Copyright (c) 2007 Gordon Willem Klok <gwk@openbsd.org>
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#include <sys/types.h>
+#include <sys/param.h>
+#include <sys/systm.h>
+#include <sys/proc.h>
+#include <sys/device.h>
+
+#include <ddb/db_var.h>
+#include <dev/ofw/openfirm.h>
+
+#include <machine/bus.h>
+#include <machine/autoconf.h>
+
+struct sysbutton_softc {
+ struct device sc_dev;
+ int sc_node;
+ int sc_intr;
+};
+
+int sysbutton_match(struct device *, void *, void *);
+void sysbutton_attach(struct device *, struct device *, void *);
+int sysbutton_intr(void *);
+
+struct cfattach sysbutton_ca = {
+ sizeof(struct sysbutton_softc), sysbutton_match,
+ sysbutton_attach
+};
+
+struct cfdriver sysbutton_cd = {
+ NULL, "sysbutton", DV_DULL
+};
+
+int
+sysbutton_match(struct device *parent, void *arg, void *aux)
+{
+ struct confargs *ca = aux;
+
+ if (strcmp(ca->ca_name, "indicatorSwitch-gpio") == 0)
+ return 1;
+
+ return 0;
+}
+
+void
+sysbutton_attach(struct device *parent, struct device *self, void *aux)
+{
+ struct sysbutton_softc *sc = (struct sysbutton_softc *)self;
+ struct confargs *ca = aux;
+ int intr[2];
+
+ sc->sc_node = ca->ca_node;
+
+ OF_getprop(sc->sc_node, "interrupts", intr, sizeof(intr));
+ sc->sc_intr = intr[0];
+
+ printf(": irg %d\n", sc->sc_intr);
+
+ mac_intr_establish(parent, sc->sc_intr, IST_LEVEL,
+ IPL_NONE, sysbutton_intr, sc, sc->sc_dev.dv_xname);
+}
+
+int
+sysbutton_intr(void *v)
+{
+
+ /*
+ * XXX: Holding this button causes an interrupt storm if
+ * ddb.console=0.
+ */
+#ifdef DDB
+ if (db_console)
+ Debugger();
+#endif
+
+ return 1;
+}