summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2005-03-29 12:55:56 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2005-03-29 12:55:56 +0000
commite2bf008feddb6ffd09f495c88b9ebc10111ce64f (patch)
treec063e8f53411e78cd3d5a8fb16799e5b582d33fe
parentcbc833c680af9277bf2a7a6f8b533c9a2dbac477 (diff)
If a tctrl device is attached, run the keyboard bell through it, since the
keyboard on SPARCbooks lacks a speaker.
-rw-r--r--sys/arch/sparc/dev/tctrl.c84
-rw-r--r--sys/arch/sparc/dev/tctrlvar.h3
-rw-r--r--sys/arch/sparc/dev/z8530kbd.c12
3 files changed, 95 insertions, 4 deletions
diff --git a/sys/arch/sparc/dev/tctrl.c b/sys/arch/sparc/dev/tctrl.c
index 77872681422..6409aaca8c7 100644
--- a/sys/arch/sparc/dev/tctrl.c
+++ b/sys/arch/sparc/dev/tctrl.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: tctrl.c,v 1.8 2005/03/29 11:36:40 miod Exp $ */
+/* $OpenBSD: tctrl.c,v 1.9 2005/03/29 12:55:55 miod Exp $ */
/* $NetBSD: tctrl.c,v 1.2 1999/08/11 00:46:06 matt Exp $ */
/*-
@@ -92,6 +92,8 @@ struct tctrl_softc {
u_int sc_cmdlen;
u_int sc_rspoff;
u_int sc_rsplen;
+ u_int sc_bellfreq;
+ u_int sc_bellvol;
struct timeout sc_tmo;
};
@@ -99,6 +101,7 @@ struct tctrl_softc {
int tctrl_match(struct device *, void *, void *);
void tctrl_attach(struct device *, struct device *, void *);
+void tctrl_bell(struct tctrl_softc *, int, int);
void tctrl_brightness(struct tctrl_softc *, int, int);
void tctrl_init_lcd(struct tctrl_softc *);
int tctrl_intr(void *);
@@ -213,6 +216,7 @@ tctrl_attach(parent, self, aux)
}
/* Get a few status values */
+ tctrl_bell(sc, 0xff, 0);
tctrl_brightness(sc, 0xff, 0);
sc->sc_regs->intr = TS102_UCTRL_INT_RXNE_REQ|TS102_UCTRL_INT_RXNE_MSK;
@@ -476,6 +480,29 @@ tctrl_read_ext_status(struct tctrl_softc *sc)
}
void
+tctrl_bell(struct tctrl_softc *sc, int mask, int value)
+{
+ struct tctrl_req req;
+
+ req.cmdbuf[0] = TS102_OP_CTL_SPEAKER_VOLUME;
+ req.cmdbuf[1] = mask;
+ req.cmdbuf[2] = value;
+ req.cmdlen = 3;
+ req.rsplen = 2;
+
+ tctrl_request(sc, &req);
+
+ /*
+ * Note that rspbuf[0] returns the previous value, before any
+ * adjustment happened.
+ */
+ if (mask == 0)
+ sc->sc_bellvol = value;
+ else
+ sc->sc_bellvol = req.rspbuf[0];
+}
+
+void
tctrl_brightness(struct tctrl_softc *sc, int mask, int value)
{
struct tctrl_req req;
@@ -488,7 +515,14 @@ tctrl_brightness(struct tctrl_softc *sc, int mask, int value)
tctrl_request(sc, &req);
- sc->sc_brightness = req.rspbuf[0];
+ /*
+ * Note that rspbuf[0] returns the previous value, before any
+ * adjustment happened.
+ */
+ if (mask == 0)
+ sc->sc_brightness = value;
+ else
+ sc->sc_brightness = req.rspbuf[0];
}
void
@@ -708,3 +742,49 @@ tadpole_set_pcmcia(int slot, int enabled)
sc->sc_pcmcia_on ? TS102_LCD_PCMCIA_ACTIVE : 0);
}
}
+
+int
+tadpole_bell(u_int duration, u_int freq, u_int volume)
+{
+ struct tctrl_softc *sc;
+ struct tctrl_req req;
+
+ if (tctrl_cd.cd_devs == NULL
+ || tctrl_cd.cd_ndevs == 0
+ || tctrl_cd.cd_devs[0] == NULL) {
+ return (0);
+ }
+
+ sc = (struct tctrl_softc *)tctrl_cd.cd_devs[0];
+
+ /* Adjust frequency if necessary (first time or frequence change) */
+ if (freq > 0 && freq <= 0xffff && freq != sc->sc_bellfreq) {
+ req.cmdbuf[0] = TS102_OP_CMD_SET_BELL_FREQ;
+ req.cmdbuf[1] = (freq >> 8) & 0xff;
+ req.cmdbuf[2] = freq & 0xff;
+ req.cmdlen = 3;
+ req.rsplen = 1;
+
+ tctrl_request(sc, &req);
+
+ sc->sc_bellfreq = freq;
+ }
+
+ /* Adjust volume if necessary */
+ if (volume >= 0 && volume <= 100) {
+ volume = (volume * 255) / 100;
+ if (volume != sc->sc_bellvol)
+ tctrl_bell(sc, 0, volume);
+
+ }
+
+ req.cmdbuf[0] = TS102_OP_CMD_RING_BELL;
+ req.cmdbuf[1] = (duration >> 8) & 0xff;
+ req.cmdbuf[2] = duration & 0xff;
+ req.cmdlen = 3;
+ req.rsplen = 1;
+
+ tctrl_request(sc, &req);
+
+ return (1);
+}
diff --git a/sys/arch/sparc/dev/tctrlvar.h b/sys/arch/sparc/dev/tctrlvar.h
index dd742a6f127..6a42512d9d8 100644
--- a/sys/arch/sparc/dev/tctrlvar.h
+++ b/sys/arch/sparc/dev/tctrlvar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: tctrlvar.h,v 1.4 2005/03/29 11:36:41 miod Exp $ */
+/* $OpenBSD: tctrlvar.h,v 1.5 2005/03/29 12:55:55 miod Exp $ */
/* $NetBSD: tctrlvar.h,v 1.1 1999/08/09 18:39:58 matt Exp $ */
/*-
@@ -39,6 +39,7 @@
#ifndef _SPARC_DEV_TCTRLVAR_H
#define _SPARC_DEV_TCTRLVAR_H
+int tadpole_bell(u_int, u_int, u_int);
int tadpole_get_brightness(void);
u_int tadpole_get_video(void);
void tadpole_powerdown(void);
diff --git a/sys/arch/sparc/dev/z8530kbd.c b/sys/arch/sparc/dev/z8530kbd.c
index 4fdb08ce063..7ce16c28a66 100644
--- a/sys/arch/sparc/dev/z8530kbd.c
+++ b/sys/arch/sparc/dev/z8530kbd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: z8530kbd.c,v 1.5 2005/03/06 23:23:08 miod Exp $ */
+/* $OpenBSD: z8530kbd.c,v 1.6 2005/03/29 12:55:55 miod Exp $ */
/* $NetBSD: z8530tty.c,v 1.77 2001/05/30 15:24:24 lukem Exp $ */
/*-
@@ -124,6 +124,11 @@
#include <dev/cons.h>
+#include "tctrl.h"
+#if NTCTRL > 0
+#include <sparc/dev/tctrlvar.h>
+#endif
+
/*
* How many input characters we can buffer.
* The port-specific var.h may override this.
@@ -1229,6 +1234,11 @@ zskbd_bell(zst, period, pitch, volume)
if (ticks <= 0)
ticks = 1;
+#if NTCTRL > 0
+ if (tadpole_bell(period / 10, pitch, volume) != 0)
+ return;
+#endif
+
s = splzs();
if (zst->zst_bellactive) {
if (zst->zst_belltimeout == 0)