summaryrefslogtreecommitdiff
path: root/sys/arch/sparc64/dev
diff options
context:
space:
mode:
authorJason Wright <jason@cvs.openbsd.org>2002-02-01 21:48:24 +0000
committerJason Wright <jason@cvs.openbsd.org>2002-02-01 21:48:24 +0000
commit3e1b9f4bfaf7e368b07e31c7ea2af2d663fa6c83 (patch)
treeafeb8523620c6fa2455f0901bf6d2507e5c639c6 /sys/arch/sparc64/dev
parentc6e798b53d04b34233a34e564b5dba6a0d500e0d (diff)
Clean up auxio a bit and add machdep.led_blink sysctl (like sparc),
portions from NetBSD.
Diffstat (limited to 'sys/arch/sparc64/dev')
-rw-r--r--sys/arch/sparc64/dev/auxio.c96
-rw-r--r--sys/arch/sparc64/dev/auxioreg.h5
-rw-r--r--sys/arch/sparc64/dev/auxiovar.h24
3 files changed, 82 insertions, 43 deletions
diff --git a/sys/arch/sparc64/dev/auxio.c b/sys/arch/sparc64/dev/auxio.c
index 40752a8aba1..d37d0d4dd41 100644
--- a/sys/arch/sparc64/dev/auxio.c
+++ b/sys/arch/sparc64/dev/auxio.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: auxio.c,v 1.2 2001/08/29 02:47:58 jason Exp $ */
+/* $OpenBSD: auxio.c,v 1.3 2002/02/01 21:48:23 jason Exp $ */
/* $NetBSD: auxio.c,v 1.1 2000/04/15 03:08:13 mrg Exp $ */
/*
@@ -37,7 +37,8 @@
#include <sys/systm.h>
#include <sys/errno.h>
#include <sys/device.h>
-#include <sys/malloc.h>
+#include <sys/timeout.h>
+#include <sys/kernel.h>
#include <machine/autoconf.h>
#include <machine/cpu.h>
@@ -57,6 +58,7 @@ int auxio_ebus_match __P((struct device *, void *, void *));
void auxio_ebus_attach __P((struct device *, struct device *, void *));
int auxio_sbus_match __P((struct device *, void *, void *));
void auxio_sbus_attach __P((struct device *, struct device *, void *));
+void auxio_attach_common __P((struct auxio_softc *));
struct cfattach auxio_ebus_ca = {
sizeof(struct auxio_softc), auxio_ebus_match, auxio_ebus_attach
@@ -70,6 +72,8 @@ struct cfdriver auxio_cd = {
NULL, "auxio", DV_DULL
};
+extern int sparc_led_blink;
+
int
auxio_ebus_match(parent, cf, aux)
struct device *parent;
@@ -89,6 +93,8 @@ auxio_ebus_attach(parent, self, aux)
struct auxio_softc *sc = (struct auxio_softc *)self;
struct ebus_attach_args *ea = aux;
+ timeout_set(&sc->sc_to, auxio_led_blink, sc);
+
if (ea->ea_nregs < 1 || ea->ea_nvaddrs < 1) {
printf(": no registers??\n");
return;
@@ -100,17 +106,15 @@ auxio_ebus_attach(parent, self, aux)
sc->sc_flags = AUXIO_LEDONLY|AUXIO_EBUS;
} else {
sc->sc_flags = AUXIO_EBUS;
- sc->sc_registers.auxio_pci = (u_int32_t *)(u_long)ea->ea_vaddrs[1];
- sc->sc_registers.auxio_freq = (u_int32_t *)(u_long)ea->ea_vaddrs[2];
- sc->sc_registers.auxio_scsi = (u_int32_t *)(u_long)ea->ea_vaddrs[3];
- sc->sc_registers.auxio_temp = (u_int32_t *)(u_long)ea->ea_vaddrs[4];
+ sc->sc_pci = (bus_space_handle_t)(u_long)ea->ea_vaddrs[1];
+ sc->sc_freq = (bus_space_handle_t)(u_long)ea->ea_vaddrs[1];
+ sc->sc_scsi = (bus_space_handle_t)(u_long)ea->ea_vaddrs[1];
+ sc->sc_temp = (bus_space_handle_t)(u_long)ea->ea_vaddrs[1];
}
- sc->sc_registers.auxio_led = (u_int32_t *)(u_long)ea->ea_vaddrs[0];
-
- if (!auxio_reg)
- auxio_reg = (u_char *)(u_long)ea->ea_vaddrs[0];
+ sc->sc_led = (bus_space_handle_t)(u_long)ea->ea_vaddrs[0];
+ sc->sc_tag = ea->ea_bustag;
- printf("\n");
+ auxio_attach_common(sc);
}
int
@@ -132,6 +136,8 @@ auxio_sbus_attach(parent, self, aux)
struct auxio_softc *sc = (struct auxio_softc *)self;
struct sbus_attach_args *sa = aux;
+ timeout_set(&sc->sc_to, auxio_led_blink, sc);
+
if (sa->sa_nreg < 1 || sa->sa_npromvaddrs < 1) {
printf(": no registers??\n");
return;
@@ -144,25 +150,67 @@ auxio_sbus_attach(parent, self, aux)
/* sbus auxio only has one set of registers */
sc->sc_flags = AUXIO_LEDONLY|AUXIO_SBUS;
- sc->sc_registers.auxio_led = (u_int32_t *)(u_long)sa->sa_promvaddr;
+ sc->sc_led = (bus_space_handle_t)(u_long)sa->sa_promvaddr;
+ sc->sc_tag = sa->sa_bustag;
- if (!auxio_reg)
- auxio_reg = (u_char *)(u_long)sa->sa_promvaddr;
+ auxio_attach_common(sc);
+}
+void
+auxio_attach_common(sc)
+ struct auxio_softc *sc;
+{
+ if (sparc_led_blink)
+ auxio_led_blink(sc);
printf("\n");
}
-/*
- * old interface; used by fd driver for now
- */
-unsigned int
-auxregbisc(bis, bic)
- int bis, bic;
+void
+auxio_led_blink(vsc)
+ void *vsc;
{
- register int v, s = splhigh();
+ struct auxio_softc *sc = vsc;
+ u_int32_t led;
+ int i, s;
+
+ if (sc == NULL) {
+ for (i = 0; i < auxio_cd.cd_ndevs; i++) {
+ sc = auxio_cd.cd_devs[i];
+ if (sc != NULL)
+ auxio_led_blink(sc);
+ }
+ return;
+ }
+
+ s = splhigh();
+
+ if (sc->sc_flags & AUXIO_EBUS)
+ led = letoh32(bus_space_read_4(sc->sc_tag, sc->sc_led, 0));
+ else
+ led = bus_space_read_1(sc->sc_tag, sc->sc_led, 0);
+
+ if (!sparc_led_blink)
+ led |= AUXIO_LED_LED;
+ else
+ led ^= AUXIO_LED_LED;
+
+ if (sc->sc_flags & AUXIO_EBUS)
+ bus_space_write_4(sc->sc_tag, sc->sc_led, 0, htole32(led));
+ else
+ bus_space_write_1(sc->sc_tag, sc->sc_led, 0, led);
- v = *auxio_reg;
- *auxio_reg = ((v | bis) & ~bic) | AUXIO_LED_MB1;
splx(s);
- return v;
+
+ if (!sparc_led_blink)
+ return;
+
+ /*
+ * Blink rate is:
+ * full cycle every second if completely idle (loadav = 0)
+ * full cycle every 2 seconds if loadav = 1
+ * full cycle every 3 seconds if loadav = 2
+ * etc.
+ */
+ s = (((averunnable.ldavg[0] + FSCALE) * hz) >> (FSHIFT + 1));
+ timeout_add(&sc->sc_to, s);
}
diff --git a/sys/arch/sparc64/dev/auxioreg.h b/sys/arch/sparc64/dev/auxioreg.h
index 6beec3e03cb..d69858f6759 100644
--- a/sys/arch/sparc64/dev/auxioreg.h
+++ b/sys/arch/sparc64/dev/auxioreg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: auxioreg.h,v 1.2 2001/08/29 02:47:58 jason Exp $ */
+/* $OpenBSD: auxioreg.h,v 1.3 2002/02/01 21:48:23 jason Exp $ */
/* $NetBSD: auxioreg.h,v 1.3 2000/04/15 03:08:13 mrg Exp $ */
/*
@@ -47,7 +47,6 @@
#define AUXIO_POWER_COURTESY_OFF 0x1
#define AUXIO_LED 0x00726000
-#define AUXIO_LED_LED 0x0
#define AUXIO_LED_MB1 0xf0 /* must be set on write */
/* XXX: these may be useless on Ebus2 auxio! find out! */
#define AUXIO_LED_FHD 0x20 /* floppy: high density (unreliable?)*/
@@ -55,9 +54,7 @@
#define AUXIO_LED_FDS 0x08 /* floppy: drive select */
#define AUXIO_LED_FTC 0x04 /* floppy: drives Terminal Count pin */
#define AUXIO_LED_FEJ 0x02 /* floppy: eject disk */
-#if 0
#define AUXIO_LED_LED 0x01 /* front panel LED */
-#endif
#define AUXIO_PCI 0x00728000
#define AUXIO_PCI_SLOT0 0x0 /* two bits each */
diff --git a/sys/arch/sparc64/dev/auxiovar.h b/sys/arch/sparc64/dev/auxiovar.h
index 95a59b506cf..58f5ef4ca6d 100644
--- a/sys/arch/sparc64/dev/auxiovar.h
+++ b/sys/arch/sparc64/dev/auxiovar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: auxiovar.h,v 1.2 2001/08/29 02:47:58 jason Exp $ */
+/* $OpenBSD: auxiovar.h,v 1.3 2002/02/01 21:48:23 jason Exp $ */
/* $NetBSD: auxiovar.h,v 1.4 2000/04/15 03:08:13 mrg Exp $ */
/*
@@ -39,26 +39,19 @@
* (to deal with multiple auxio's that may appear.)
*/
-struct auxio_registers {
-#if 0 /* these do not exist on the Ebus2 */
- volatile u_int32_t *auxio_fd;
- volatile u_int32_t *auxio_audio;
- volatile u_int32_t *auxio_power;
-#endif
- volatile u_int32_t *auxio_led;
- volatile u_int32_t *auxio_pci;
- volatile u_int32_t *auxio_freq;
- volatile u_int32_t *auxio_scsi;
- volatile u_int32_t *auxio_temp;
-};
-
struct auxio_softc {
struct device sc_dev;
- struct auxio_registers sc_registers;
+ bus_space_tag_t sc_tag;
+ bus_space_handle_t sc_led;
+ bus_space_handle_t sc_pci;
+ bus_space_handle_t sc_scsi;
+ bus_space_handle_t sc_freq;
+ bus_space_handle_t sc_temp;
int sc_flags;
#define AUXIO_LEDONLY 0x1
#define AUXIO_EBUS 0x2
#define AUXIO_SBUS 0x4
+ struct timeout sc_to;
};
/*
@@ -71,4 +64,5 @@ struct auxio_softc {
*/
volatile u_char *auxio_reg;
unsigned int auxregbisc __P((int, int));
+void auxio_led_blink __P((void *));
#endif