diff options
author | Jason Wright <jason@cvs.openbsd.org> | 2001-10-01 04:10:50 +0000 |
---|---|---|
committer | Jason Wright <jason@cvs.openbsd.org> | 2001-10-01 04:10:50 +0000 |
commit | 9ef829f673b1e6d6cdca5a4efeb5d93da21c7d4c (patch) | |
tree | daeee45bf6b4c1693064ced467b4a6c8b47ceb1c /sys/dev/sbus | |
parent | 686d07c3dfb9832b9a8c61f95a2abb0f9e721938 (diff) |
simplification:
don't need to mute the monitor when changing modes (cs4231 mutes it
automatically when entering MODE_CHANGE_ENABLE is set).
Remember the last format/xtal/speed selection and avoid resetting it if
we're using the same one again.
Also, simplify the volume/mute setup.
Diffstat (limited to 'sys/dev/sbus')
-rw-r--r-- | sys/dev/sbus/cs4231.c | 110 | ||||
-rw-r--r-- | sys/dev/sbus/cs4231var.h | 3 |
2 files changed, 46 insertions, 67 deletions
diff --git a/sys/dev/sbus/cs4231.c b/sys/dev/sbus/cs4231.c index 0eb460fb2f1..0ed771946a8 100644 --- a/sys/dev/sbus/cs4231.c +++ b/sys/dev/sbus/cs4231.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cs4231.c,v 1.6 2001/10/01 03:31:03 jason Exp $ */ +/* $OpenBSD: cs4231.c,v 1.7 2001/10/01 04:10:49 jason Exp $ */ /* * Copyright (c) 1999 Jason L. Wright (jason@thought.net) @@ -123,7 +123,6 @@ void cs4231_attach __P((struct device *, struct device *, void *)); int cs4231_intr __P((void *)); int cs4231_set_speed __P((struct cs4231_softc *, u_long *)); -void cs4231_mute_monitor __P((struct cs4231_softc *, int)); void cs4231_setup_output __P((struct cs4231_softc *sc)); void cs4231_write __P((struct cs4231_softc *, u_int8_t, u_int8_t)); @@ -217,6 +216,8 @@ cs4231_attach(parent, self, aux) node = sa->sa_node; + sc->sc_last_format = 0xffffffff; + /* Pass on the bus tags */ sc->sc_bustag = sa->sa_bustag; sc->sc_dmatag = sa->sa_dmatag; @@ -266,6 +267,7 @@ cs4231_attach(parent, self, aux) /* Default to speaker, unmuted, reasonable volume */ sc->sc_out_port = CSPORT_SPEAKER; sc->sc_mute[CSPORT_SPEAKER] = 1; + sc->sc_mute[CSPORT_MONITOR] = 1; sc->sc_volume[CSPORT_SPEAKER].left = 192; sc->sc_volume[CSPORT_SPEAKER].right = 192; } @@ -294,26 +296,6 @@ cs4231_read(sc, r) return (CS_READ(sc, AD1848_IDATA)); } -void -cs4231_mute_monitor(sc, mute) - struct cs4231_softc *sc; - int mute; -{ - u_int8_t lv, rv; - - lv = cs4231_read(sc, SP_LEFT_OUTPUT_CONTROL); - rv = cs4231_read(sc, SP_RIGHT_OUTPUT_CONTROL); - if (mute) { - lv |= OUTPUT_MUTE; - rv |= OUTPUT_MUTE; - } else { - lv &= ~OUTPUT_MUTE; - rv &= ~OUTPUT_MUTE; - } - cs4231_write(sc, SP_LEFT_OUTPUT_CONTROL, lv); - cs4231_write(sc, SP_RIGHT_OUTPUT_CONTROL, rv); -} - int cs4231_set_speed(sc, argp) struct cs4231_softc *sc; @@ -432,51 +414,46 @@ void cs4231_setup_output(sc) struct cs4231_softc *sc; { - u_int8_t r; + u_int8_t pc, mi, rm, lm; + + pc = cs4231_read(sc, SP_PIN_CONTROL) | CS_PC_HDPHMUTE | CS_PC_LINEMUTE; - r = cs4231_read(sc, SP_PIN_CONTROL); - r |= CS_PC_HDPHMUTE | CS_PC_LINEMUTE; - cs4231_write(sc, SP_PIN_CONTROL, r); + mi = cs4231_read(sc, CS_MONO_IO_CONTROL) | MONO_OUTPUT_MUTE; - r = cs4231_read(sc, CS_MONO_IO_CONTROL); - r |= MONO_OUTPUT_MUTE; - cs4231_write(sc, CS_MONO_IO_CONTROL, r); + lm = cs4231_read(sc, SP_LEFT_OUTPUT_CONTROL); + lm &= ~OUTPUT_ATTEN_BITS; + lm |= ((~(sc->sc_volume[CSPORT_SPEAKER].left >> 2)) & + OUTPUT_ATTEN_BITS) | OUTPUT_MUTE; + + rm = cs4231_read(sc, SP_RIGHT_OUTPUT_CONTROL); + rm &= ~OUTPUT_ATTEN_BITS; + rm |= ((~(sc->sc_volume[CSPORT_SPEAKER].right >> 2)) & + OUTPUT_ATTEN_BITS) | OUTPUT_MUTE; + + if (sc->sc_mute[CSPORT_MONITOR]) { + lm &= ~OUTPUT_MUTE; + rm &= ~OUTPUT_MUTE; + } switch (sc->sc_out_port) { case CSPORT_HEADPHONE: - if (sc->sc_mute[CSPORT_SPEAKER]) { - r = cs4231_read(sc, SP_PIN_CONTROL); - r &= ~CS_PC_HDPHMUTE; - cs4231_write(sc, SP_PIN_CONTROL, r); - } + if (sc->sc_mute[CSPORT_SPEAKER]) + pc &= ~CS_PC_HDPHMUTE; break; case CSPORT_SPEAKER: - if (sc->sc_mute[CSPORT_SPEAKER]) { - r = cs4231_read(sc, CS_MONO_IO_CONTROL); - r &= ~MONO_OUTPUT_MUTE; - cs4231_write(sc, CS_MONO_IO_CONTROL, r); - } + if (sc->sc_mute[CSPORT_SPEAKER]) + mi &= ~MONO_OUTPUT_MUTE; break; case CSPORT_LINEOUT: - if (sc->sc_mute[CSPORT_SPEAKER]) { - r = cs4231_read(sc, SP_PIN_CONTROL); - r &= ~CS_PC_LINEMUTE; - cs4231_write(sc, SP_PIN_CONTROL, r); - } + if (sc->sc_mute[CSPORT_SPEAKER]) + pc &= ~CS_PC_LINEMUTE; break; } - r = cs4231_read(sc, SP_LEFT_OUTPUT_CONTROL); - r &= ~OUTPUT_ATTEN_BITS; - r |= (~(sc->sc_volume[CSPORT_SPEAKER].left >> 2)) & - OUTPUT_ATTEN_BITS; - cs4231_write(sc, SP_LEFT_OUTPUT_CONTROL, r); - - r = cs4231_read(sc, SP_RIGHT_OUTPUT_CONTROL); - r &= ~OUTPUT_ATTEN_BITS; - r |= (~(sc->sc_volume[CSPORT_SPEAKER].right >> 2)) & - OUTPUT_ATTEN_BITS; - cs4231_write(sc, SP_RIGHT_OUTPUT_CONTROL, r); + cs4231_write(sc, SP_LEFT_OUTPUT_CONTROL, lm); + cs4231_write(sc, SP_RIGHT_OUTPUT_CONTROL, rm); + cs4231_write(sc, SP_PIN_CONTROL, pc); + cs4231_write(sc, CS_MONO_IO_CONTROL, mi); } void @@ -655,26 +632,29 @@ cs4231_commit_settings(addr) { struct cs4231_softc *sc = (struct cs4231_softc *)addr; int s, tries; - u_int8_t r; + u_int8_t r, fs; if (sc->sc_need_commit == 0) return (0); - s = splaudio(); + fs = sc->sc_speed_bits | (sc->sc_format_bits << 5); + if (sc->sc_channels == 2) + fs |= FMT_STEREO; - cs4231_mute_monitor(sc, 1); + if (sc->sc_last_format == fs) { + sc->sc_need_commit = 0; + return (0); + } + + s = splaudio(); r = cs4231_read(sc, SP_INTERFACE_CONFIG) | AUTO_CAL_ENABLE; CS_WRITE(sc, AD1848_IADDR, MODE_CHANGE_ENABLE); CS_WRITE(sc, AD1848_IADDR, MODE_CHANGE_ENABLE | SP_INTERFACE_CONFIG); CS_WRITE(sc, AD1848_IDATA, r); - r = sc->sc_speed_bits | (sc->sc_format_bits << 5); - if (sc->sc_channels == 2) - r |= FMT_STEREO; - CS_WRITE(sc, AD1848_IADDR, MODE_CHANGE_ENABLE | SP_CLOCK_DATA_FORMAT); - CS_WRITE(sc, AD1848_IDATA, r); + CS_WRITE(sc, AD1848_IDATA, fs); CS_READ(sc, AD1848_IDATA); CS_READ(sc, AD1848_IDATA); tries = CS_TIMEOUT; @@ -685,7 +665,7 @@ cs4231_commit_settings(addr) printf("%s: timeout committing fspb\n", sc->sc_dev.dv_xname); CS_WRITE(sc, AD1848_IADDR, MODE_CHANGE_ENABLE | CS_REC_FORMAT); - CS_WRITE(sc, AD1848_IDATA, r); + CS_WRITE(sc, AD1848_IDATA, fs); CS_READ(sc, AD1848_IDATA); CS_READ(sc, AD1848_IDATA); for (tries = CS_TIMEOUT; @@ -709,8 +689,6 @@ cs4231_commit_settings(addr) printf("%s: timeout waiting for autocalibration\n", sc->sc_dev.dv_xname); - cs4231_mute_monitor(sc, 0); - splx(s); sc->sc_need_commit = 0; diff --git a/sys/dev/sbus/cs4231var.h b/sys/dev/sbus/cs4231var.h index f1d0cd54fa0..af365190b2f 100644 --- a/sys/dev/sbus/cs4231var.h +++ b/sys/dev/sbus/cs4231var.h @@ -1,4 +1,4 @@ -/* $OpenBSD: cs4231var.h,v 1.1 2001/09/30 00:45:17 jason Exp $ */ +/* $OpenBSD: cs4231var.h,v 1.2 2001/10/01 04:10:49 jason Exp $ */ /* * Copyright (c) 1999 Jason L. Wright (jason@thought.net) @@ -78,6 +78,7 @@ struct cs4231_softc { int sc_precision; int sc_need_commit; int sc_channels; + u_int sc_last_format; u_int32_t sc_blksz; u_int32_t sc_playcnt; u_int32_t sc_playsegsz; |