diff options
author | Artur Grabowski <art@cvs.openbsd.org> | 2000-07-12 18:45:18 +0000 |
---|---|---|
committer | Artur Grabowski <art@cvs.openbsd.org> | 2000-07-12 18:45:18 +0000 |
commit | b30135883c3b315be2cbf7b5999173bc5585fb96 (patch) | |
tree | eb1aac344468848af63464097dfc50284e168fd3 | |
parent | 82afd208a6e448ec1730b83222e1858c50bd007e (diff) |
Fix two bugs.
The return value from the interrupt handling was bogus. Now we return 1
if we have handled the interrupt.
When resuming from suspend wrong values were restored to the mixer
which sometimes caused a high-pitched sound to be emitted. (how fast
can you type "mixerctl -w outputs.master.mute=on"?)
-rw-r--r-- | sys/dev/pci/cs4280.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/sys/dev/pci/cs4280.c b/sys/dev/pci/cs4280.c index fe74ba343ec..8c850a31073 100644 --- a/sys/dev/pci/cs4280.c +++ b/sys/dev/pci/cs4280.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cs4280.c,v 1.1 2000/06/30 03:28:07 art Exp $ */ +/* $OpenBSD: cs4280.c,v 1.2 2000/07/12 18:45:17 art Exp $ */ /* $NetBSD: cs4280.c,v 1.5 2000/06/26 04:56:23 simonb Exp $ */ /* @@ -697,6 +697,7 @@ cs4280_intr(p) struct cs4280_softc *sc = p; u_int32_t intr, mem; char * empty_dma; + int handled = 0; intr = BA0READ4(sc, CS4280_HISR); @@ -707,6 +708,7 @@ cs4280_intr(p) /* Playback Interrupt */ if (intr & HISR_PINT) { + handled = 1; mem = BA1READ4(sc, CS4280_PFIE); BA1WRITE4(sc, CS4280_PFIE, (mem & ~PFIE_PI_MASK) | PFIE_PI_DISABLE); if (sc->sc_pintr) { @@ -730,7 +732,8 @@ cs4280_intr(p) if (intr & HISR_CINT) { int i; int16_t rdata; - + + handled = 1; mem = BA1READ4(sc, CS4280_CIE); BA1WRITE4(sc, CS4280_CIE, (mem & ~CIE_CI_MASK) | CIE_CI_DISABLE); ++sc->sc_ri; @@ -792,6 +795,7 @@ cs4280_intr(p) if (intr & HISR_MIDI) { int data; + handled = 1; DPRINTF(("i: %d: ", BA0READ4(sc, CS4280_MIDSR))); /* Read the received data */ @@ -825,7 +829,7 @@ cs4280_intr(p) #endif /* Throw EOI */ BA0WRITE4(sc, CS4280_HICR, HICR_CHGM | HICR_IEV); - return (0); + return handled; } @@ -1822,7 +1826,7 @@ cs4280_power(why, v) for(i = 1; i <= CS4280_SAVE_REG_MAX; i++) { if(i == 0x04) /* AC97_REG_MASTER_TONE */ continue; - cs4280_write_codec(sc, 2*i, sc->ac97_reg[i]); + cs4280_write_codec(sc, 2*i, sc->ac97_reg[i>>1]); } } } |