diff options
author | Jason Wright <jason@cvs.openbsd.org> | 2001-10-01 03:31:04 +0000 |
---|---|---|
committer | Jason Wright <jason@cvs.openbsd.org> | 2001-10-01 03:31:04 +0000 |
commit | 686d07c3dfb9832b9a8c61f95a2abb0f9e721938 (patch) | |
tree | 4b3544021958b580a8807d7d501b03852c780d57 | |
parent | 32896e8b9217805676d39fea7f3b7921f847a37d (diff) |
get rid of local copy of cs4231reg.h (and get defns from dev/ic/ad1848reg.h
and dev/ic/cs4231reg.h). Move APC DMA goop into its own file in dev/ic.
-rw-r--r-- | sys/dev/ic/apcdmareg.h | 118 | ||||
-rw-r--r-- | sys/dev/sbus/cs4231.c | 200 | ||||
-rw-r--r-- | sys/dev/sbus/cs4231reg.h | 391 |
3 files changed, 211 insertions, 498 deletions
diff --git a/sys/dev/ic/apcdmareg.h b/sys/dev/ic/apcdmareg.h new file mode 100644 index 00000000000..425115c2930 --- /dev/null +++ b/sys/dev/ic/apcdmareg.h @@ -0,0 +1,118 @@ +/* $OpenBSD: apcdmareg.h,v 1.1 2001/10/01 03:31:03 jason Exp $ */ + +/* + * Copyright (c) 2001 Jason L. Wright (jason@thought.net) + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. All advertising materials mentioning features or use of this software + * must display the following acknowledgement: + * This product includes software developed by Jason L. Wright + * 4. The name of the author may not be used to endorse or promote products + * derived from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR + * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, + * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, + * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN + * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + * POSSIBILITY OF SUCH DAMAGE. + */ + +/* + * Definitions for Sun APC DMA controller. + */ + +/* APC DMA registers */ +#define APC_CSR 0x0010 /* control/status */ +#define APC_CVA 0x0020 /* capture virtual address */ +#define APC_CC 0x0024 /* capture count */ +#define APC_CNVA 0x0028 /* capture next virtual address */ +#define APC_CNC 0x002c /* capture next count */ +#define APC_PVA 0x0030 /* playback virtual address */ +#define APC_PC 0x0034 /* playback count */ +#define APC_PNVA 0x0038 /* playback next virtual address */ +#define APC_PNC 0x003c /* playback next count */ + +/* + * APC DMA Register definitions + */ +#define APC_CSR_RESET 0x00000001 /* reset */ +#define APC_CSR_CDMA_GO 0x00000004 /* capture dma go */ +#define APC_CSR_PDMA_GO 0x00000008 /* playback dma go */ +#define APC_CSR_CODEC_RESET 0x00000020 /* codec reset */ +#define APC_CSR_CPAUSE 0x00000040 /* capture dma pause */ +#define APC_CSR_PPAUSE 0x00000080 /* playback dma pause */ +#define APC_CSR_CMIE 0x00000100 /* capture pipe empty enb */ +#define APC_CSR_CMI 0x00000200 /* capture pipe empty intr */ +#define APC_CSR_CD 0x00000400 /* capture nva dirty */ +#define APC_CSR_CM 0x00000800 /* capture data lost */ +#define APC_CSR_PMIE 0x00001000 /* pb pipe empty intr enable */ +#define APC_CSR_PD 0x00002000 /* pb nva dirty */ +#define APC_CSR_PM 0x00004000 /* pb pipe empty */ +#define APC_CSR_PMI 0x00008000 /* pb pipe empty interrupt */ +#define APC_CSR_EIE 0x00010000 /* error interrupt enable */ +#define APC_CSR_CIE 0x00020000 /* capture intr enable */ +#define APC_CSR_PIE 0x00040000 /* playback intr enable */ +#define APC_CSR_GIE 0x00080000 /* general intr enable */ +#define APC_CSR_EI 0x00100000 /* error interrupt */ +#define APC_CSR_CI 0x00200000 /* capture interrupt */ +#define APC_CSR_PI 0x00400000 /* playback interrupt */ +#define APC_CSR_GI 0x00800000 /* general interrupt */ + +#define APC_CSR_PLAY ( \ + APC_CSR_EI | \ + APC_CSR_GIE | \ + APC_CSR_PIE | \ + APC_CSR_EIE | \ + APC_CSR_PDMA_GO | \ + APC_CSR_PMIE ) + +#define APC_CSR_CAPTURE ( \ + APC_CSR_EI | \ + APC_CSR_GIE | \ + APC_CSR_CIE | \ + APC_CSR_EIE | \ + APC_CSR_CDMA_GO ) + +#define APC_CSR_PLAY_PAUSE (~( \ + APC_CSR_PPAUSE | \ + APC_CSR_GI | \ + APC_CSR_PI | \ + APC_CSR_CI | \ + APC_CSR_EI | \ + APC_CSR_PMI | \ + APC_CSR_PMIE | \ + APC_CSR_CMI | \ + APC_CSR_CMIE ) ) + +#define APC_CSR_CAPTURE_PAUSE (~( \ + APC_CSR_PPAUSE | \ + APC_CSR_GI | \ + APC_CSR_PI | \ + APC_CSR_CI | \ + APC_CSR_EI | \ + APC_CSR_PMI | \ + APC_CSR_PMIE | \ + APC_CSR_CMI | \ + APC_CSR_CMIE ) ) + +#define APC_CSR_INTR_MASK ( \ + APC_CSR_GI | \ + APC_CSR_PI | \ + APC_CSR_CI | \ + APC_CSR_EI | \ + APC_CSR_PMI | \ + APC_CSR_CMI ) diff --git a/sys/dev/sbus/cs4231.c b/sys/dev/sbus/cs4231.c index 658dd07d751..0eb460fb2f1 100644 --- a/sys/dev/sbus/cs4231.c +++ b/sys/dev/sbus/cs4231.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cs4231.c,v 1.5 2001/10/01 02:35:04 jason Exp $ */ +/* $OpenBSD: cs4231.c,v 1.6 2001/10/01 03:31:03 jason Exp $ */ /* * Copyright (c) 1999 Jason L. Wright (jason@thought.net) @@ -57,8 +57,8 @@ #include <dev/ic/ad1848reg.h> #include <dev/ic/cs4231reg.h> +#include <dev/ic/apcdmareg.h> #include <dev/sbus/sbusvar.h> -#include <dev/sbus/cs4231reg.h> #include <dev/sbus/cs4231var.h> #define CSAUDIO_DAC_LVL 0 @@ -102,10 +102,16 @@ #define DPRINTF(x) #endif +#define CS_TIMEOUT 90000 + +#define CS_PC_LINEMUTE XCTL0_ENABLE +#define CS_PC_HDPHMUTE XCTL1_ENABLE +#define CS_AFS_PI 0x10 + #define CS_WRITE(sc,r,v) \ - bus_space_write_1(sc->sc_bustag, sc->sc_regs, r, v) + bus_space_write_1((sc)->sc_bustag, (sc)->sc_regs, (r) << 2, (v)) #define CS_READ(sc,r) \ - bus_space_read_1(sc->sc_bustag, sc->sc_regs, r) + bus_space_read_1((sc)->sc_bustag, (sc)->sc_regs, (r) << 2) #define APC_WRITE(sc,r,v) \ bus_space_write_4(sc->sc_bustag, sc->sc_regs, r, v) @@ -116,7 +122,6 @@ int cs4231_match __P((struct device *, void *, void *)); void cs4231_attach __P((struct device *, struct device *, void *)); int cs4231_intr __P((void *)); -void cs4231_wait __P((struct cs4231_softc *)); 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)); @@ -187,7 +192,7 @@ struct cfdriver audiocs_cd = { struct audio_device cs4231_device = { "SUNW,CS4231", "b", - "onboard1", /* XXX unknown for ultra */ + "onboard1", }; int @@ -273,8 +278,8 @@ cs4231_write(sc, r, v) struct cs4231_softc *sc; u_int8_t r, v; { - CS_WRITE(sc, CS4231_IAR, r); - CS_WRITE(sc, CS4231_IDR, v); + CS_WRITE(sc, AD1848_IADDR, r); + CS_WRITE(sc, AD1848_IDATA, v); } /* @@ -285,8 +290,8 @@ cs4231_read(sc, r) struct cs4231_softc *sc; u_int8_t r; { - CS_WRITE(sc, CS4231_IAR, r); - return (CS_READ(sc, CS4231_IDR)); + CS_WRITE(sc, AD1848_IADDR, r); + return (CS_READ(sc, AD1848_IDATA)); } void @@ -299,11 +304,11 @@ cs4231_mute_monitor(sc, mute) lv = cs4231_read(sc, SP_LEFT_OUTPUT_CONTROL); rv = cs4231_read(sc, SP_RIGHT_OUTPUT_CONTROL); if (mute) { - lv |= CS_LDACOUT_LDM; - rv |= CS_RDACOUT_RDM; + lv |= OUTPUT_MUTE; + rv |= OUTPUT_MUTE; } else { - lv &= ~CS_LDACOUT_LDM; - rv &= ~CS_RDACOUT_RDM; + lv &= ~OUTPUT_MUTE; + rv &= ~OUTPUT_MUTE; } cs4231_write(sc, SP_LEFT_OUTPUT_CONTROL, lv); cs4231_write(sc, SP_RIGHT_OUTPUT_CONTROL, rv); @@ -326,21 +331,21 @@ cs4231_set_speed(sc, argp) u_long arg = *argp; static speed_struct speed_table[] = { - {5510, (0 << 1) | CS_FSPB_C2SL_XTAL2}, - {5510, (0 << 1) | CS_FSPB_C2SL_XTAL2}, - {6620, (7 << 1) | CS_FSPB_C2SL_XTAL2}, - {8000, (0 << 1) | CS_FSPB_C2SL_XTAL1}, - {9600, (7 << 1) | CS_FSPB_C2SL_XTAL1}, - {11025, (1 << 1) | CS_FSPB_C2SL_XTAL2}, - {16000, (1 << 1) | CS_FSPB_C2SL_XTAL1}, - {18900, (2 << 1) | CS_FSPB_C2SL_XTAL2}, - {22050, (3 << 1) | CS_FSPB_C2SL_XTAL2}, - {27420, (2 << 1) | CS_FSPB_C2SL_XTAL1}, - {32000, (3 << 1) | CS_FSPB_C2SL_XTAL1}, - {33075, (6 << 1) | CS_FSPB_C2SL_XTAL2}, - {33075, (4 << 1) | CS_FSPB_C2SL_XTAL2}, - {44100, (5 << 1) | CS_FSPB_C2SL_XTAL2}, - {48000, (6 << 1) | CS_FSPB_C2SL_XTAL1}, + {5510, (0 << 1) | CLOCK_XTAL2}, + {5510, (0 << 1) | CLOCK_XTAL2}, + {6620, (7 << 1) | CLOCK_XTAL2}, + {8000, (0 << 1) | CLOCK_XTAL1}, + {9600, (7 << 1) | CLOCK_XTAL1}, + {11025, (1 << 1) | CLOCK_XTAL2}, + {16000, (1 << 1) | CLOCK_XTAL1}, + {18900, (2 << 1) | CLOCK_XTAL2}, + {22050, (3 << 1) | CLOCK_XTAL2}, + {27420, (2 << 1) | CLOCK_XTAL1}, + {32000, (3 << 1) | CLOCK_XTAL1}, + {33075, (6 << 1) | CLOCK_XTAL2}, + {33075, (4 << 1) | CLOCK_XTAL2}, + {44100, (5 << 1) | CLOCK_XTAL2}, + {48000, (6 << 1) | CLOCK_XTAL1}, }; int i, n, selected = -1; @@ -389,7 +394,6 @@ cs4231_open(addr, flags) { struct cs4231_softc *sc = addr; int tries; - u_int8_t reg; if (sc->sc_open) return (EBUSY); @@ -411,32 +415,14 @@ cs4231_open(addr, flags) APC_WRITE(sc, APC_CSR, APC_READ(sc, APC_CSR) & (~APC_CSR_CODEC_RESET)); for (tries = CS_TIMEOUT; - tries && CS_READ(sc, CS4231_IAR) == CS_IAR_INIT; tries--) + tries && CS_READ(sc, AD1848_IADDR) == SP_IN_INIT; tries--) DELAY(10); if (tries == 0) printf("%s: timeout waiting for reset\n", sc->sc_dev.dv_xname); /* Turn on cs4231 mode */ cs4231_write(sc, SP_MISC_INFO, - cs4231_read(sc, SP_MISC_INFO) | CS_MODEID_MODE2); - - reg = cs4231_read(sc, CS_VERSION_ID); - if ((reg & CS_VID_CHIP_MASK) == CS_VID_CHIP_CS4231) { - switch (reg & CS_VID_VER_MASK) { - case CS_VID_VER_CS4231A: - case CS_VID_VER_CS4231: - case CS_VID_VER_CS4232: - break; - default: - printf("%s: unknown CS version: %d\n", - sc->sc_dev.dv_xname, reg & CS_VID_VER_MASK); - } - } - else { - printf("%s: unknown CS chip/version: %d/%d\n", - sc->sc_dev.dv_xname, reg & CS_VID_CHIP_MASK, - reg & CS_VID_VER_MASK); - } + cs4231_read(sc, SP_MISC_INFO) | MODE2); cs4231_setup_output(sc); return (0); @@ -453,7 +439,7 @@ cs4231_setup_output(sc) cs4231_write(sc, SP_PIN_CONTROL, r); r = cs4231_read(sc, CS_MONO_IO_CONTROL); - r |= CS_MONO_MOM; + r |= MONO_OUTPUT_MUTE; cs4231_write(sc, CS_MONO_IO_CONTROL, r); switch (sc->sc_out_port) { @@ -467,7 +453,7 @@ cs4231_setup_output(sc) case CSPORT_SPEAKER: if (sc->sc_mute[CSPORT_SPEAKER]) { r = cs4231_read(sc, CS_MONO_IO_CONTROL); - r &= ~CS_MONO_MOM; + r &= ~MONO_OUTPUT_MUTE; cs4231_write(sc, CS_MONO_IO_CONTROL, r); } break; @@ -481,15 +467,15 @@ cs4231_setup_output(sc) } r = cs4231_read(sc, SP_LEFT_OUTPUT_CONTROL); - r &= ~CS_LDACOUT_LDA_MASK; + r &= ~OUTPUT_ATTEN_BITS; r |= (~(sc->sc_volume[CSPORT_SPEAKER].left >> 2)) & - CS_LDACOUT_LDA_MASK; + OUTPUT_ATTEN_BITS; cs4231_write(sc, SP_LEFT_OUTPUT_CONTROL, r); r = cs4231_read(sc, SP_RIGHT_OUTPUT_CONTROL); - r &= ~CS_RDACOUT_RDA_MASK; + r &= ~OUTPUT_ATTEN_BITS; r |= (~(sc->sc_volume[CSPORT_SPEAKER].right >> 2)) & - CS_RDACOUT_RDA_MASK; + OUTPUT_ATTEN_BITS; cs4231_write(sc, SP_RIGHT_OUTPUT_CONTROL, r); } @@ -608,29 +594,29 @@ cs4231_set_params(addr, setmode, usemode, p, r) switch (enc) { case AUDIO_ENCODING_ULAW: - bits = CS_CDF_FMT_ULAW >> 5; + bits = FMT_ULAW >> 5; break; case AUDIO_ENCODING_ALAW: - bits = CS_CDF_FMT_ALAW >> 5; + bits = FMT_ALAW >> 5; break; case AUDIO_ENCODING_ADPCM: - bits = CS_CDF_FMT_ADPCM >> 5; + bits = FMT_ADPCM >> 5; break; case AUDIO_ENCODING_SLINEAR_LE: if (p->precision == 16) - bits = CS_CDF_FMT_LINEAR_LE >> 5; + bits = FMT_TWOS_COMP >> 5; else return (EINVAL); break; case AUDIO_ENCODING_SLINEAR_BE: if (p->precision == 16) - bits = CS_CDF_FMT_LINEAR_BE >> 5; + bits = FMT_TWOS_COMP_BE >> 5; else return (EINVAL); break; case AUDIO_ENCODING_ULINEAR_LE: if (p->precision == 8) - bits = CS_CDF_FMT_ULINEAR >> 5; + bits = FMT_PCM8 >> 5; else return (EINVAL); break; @@ -678,46 +664,46 @@ cs4231_commit_settings(addr) cs4231_mute_monitor(sc, 1); - r = cs4231_read(sc, SP_INTERFACE_CONFIG) | CS_IC_ACAL; - CS_WRITE(sc, CS4231_IAR, CS_IAR_MCE); - CS_WRITE(sc, CS4231_IAR, CS_IAR_MCE | SP_INTERFACE_CONFIG); - CS_WRITE(sc, CS4231_IDR, r); + 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 |= CS_FSPB_SM_STEREO; + r |= FMT_STEREO; - CS_WRITE(sc, CS4231_IAR, CS_IAR_MCE | SP_CLOCK_DATA_FORMAT); - CS_WRITE(sc, CS4231_IDR, r); - CS_READ(sc, CS4231_IDR); - CS_READ(sc, CS4231_IDR); + CS_WRITE(sc, AD1848_IADDR, MODE_CHANGE_ENABLE | SP_CLOCK_DATA_FORMAT); + CS_WRITE(sc, AD1848_IDATA, r); + CS_READ(sc, AD1848_IDATA); + CS_READ(sc, AD1848_IDATA); tries = CS_TIMEOUT; for (tries = CS_TIMEOUT; - tries && CS_READ(sc, CS4231_IAR) == CS_IAR_INIT; tries--) + tries && CS_READ(sc, AD1848_IADDR) == SP_IN_INIT; tries--) DELAY(10); if (tries == 0) printf("%s: timeout committing fspb\n", sc->sc_dev.dv_xname); - CS_WRITE(sc, CS4231_IAR, CS_IAR_MCE | CS_REC_FORMAT); - CS_WRITE(sc, CS4231_IDR, r); - CS_READ(sc, CS4231_IDR); - CS_READ(sc, CS4231_IDR); + CS_WRITE(sc, AD1848_IADDR, MODE_CHANGE_ENABLE | CS_REC_FORMAT); + CS_WRITE(sc, AD1848_IDATA, r); + CS_READ(sc, AD1848_IDATA); + CS_READ(sc, AD1848_IDATA); for (tries = CS_TIMEOUT; - tries && CS_READ(sc, CS4231_IAR) == CS_IAR_INIT; tries--) + tries && CS_READ(sc, AD1848_IADDR) == SP_IN_INIT; tries--) DELAY(10); if (tries == 0) printf("%s: timeout committing cdf\n", sc->sc_dev.dv_xname); - CS_WRITE(sc, CS4231_IAR, 0); + CS_WRITE(sc, AD1848_IADDR, 0); for (tries = CS_TIMEOUT; - tries && CS_READ(sc, CS4231_IAR) == CS_IAR_INIT; tries--) + tries && CS_READ(sc, AD1848_IADDR) == SP_IN_INIT; tries--) DELAY(10); if (tries == 0) printf("%s: timeout waiting for !mce\n", sc->sc_dev.dv_xname); - CS_WRITE(sc, CS4231_IAR, SP_TEST_AND_INIT); + CS_WRITE(sc, AD1848_IADDR, SP_TEST_AND_INIT); for (tries = CS_TIMEOUT; - tries && CS_READ(sc, CS4231_IDR) & CS_ERRINIT_ACI; tries--) + tries && CS_READ(sc, AD1848_IDATA) & AUTO_CAL_IN_PROG; tries--) DELAY(10); if (tries == 0) printf("%s: timeout waiting for autocalibration\n", @@ -741,7 +727,7 @@ cs4231_halt_output(addr) ~(APC_CSR_EI | APC_CSR_GIE | APC_CSR_PIE | APC_CSR_EIE | APC_CSR_PDMA_GO | APC_CSR_PMIE)); cs4231_write(sc, SP_INTERFACE_CONFIG, - cs4231_read(sc, SP_INTERFACE_CONFIG) & (~CS_IC_PEN)); + cs4231_read(sc, SP_INTERFACE_CONFIG) & (~PLAYBACK_ENABLE)); sc->sc_locked = 0; return (0); } @@ -754,7 +740,7 @@ cs4231_halt_input(addr) APC_WRITE(sc, APC_CSR, APC_CSR_CAPTURE_PAUSE); cs4231_write(sc, SP_INTERFACE_CONFIG, - cs4231_read(sc, SP_INTERFACE_CONFIG) & (~CS_IC_CEN)); + cs4231_read(sc, SP_INTERFACE_CONFIG) & (~CAPTURE_ENABLE)); sc->sc_locked = 0; return (0); } @@ -785,14 +771,14 @@ cs4231_set_port(addr, cp) if (cp->un.value.num_channels == 1) cs4231_write(sc, SP_LEFT_AUX1_CONTROL, cp->un.value.level[AUDIO_MIXER_LEVEL_MONO] & - CS_LACIN1_GAIN_MASK); + LINE_INPUT_ATTEN_BITS); else if (cp->un.value.num_channels == 2) { cs4231_write(sc, SP_LEFT_AUX1_CONTROL, cp->un.value.level[AUDIO_MIXER_LEVEL_LEFT] & - CS_LACIN1_GAIN_MASK); + LINE_INPUT_ATTEN_BITS); cs4231_write(sc, SP_RIGHT_AUX1_CONTROL, cp->un.value.level[AUDIO_MIXER_LEVEL_RIGHT] & - CS_RACIN1_GAIN_MASK); + LINE_INPUT_ATTEN_BITS); } else break; error = 0; @@ -803,14 +789,14 @@ cs4231_set_port(addr, cp) if (cp->un.value.num_channels == 1) cs4231_write(sc, CS_LEFT_LINE_CONTROL, cp->un.value.level[AUDIO_MIXER_LEVEL_MONO] & - CS_LLI_GAIN_MASK); + AUX_INPUT_ATTEN_BITS); else if (cp->un.value.num_channels == 2) { cs4231_write(sc, CS_LEFT_LINE_CONTROL, cp->un.value.level[AUDIO_MIXER_LEVEL_LEFT] & - CS_LLI_GAIN_MASK); + AUX_INPUT_ATTEN_BITS); cs4231_write(sc, CS_RIGHT_LINE_CONTROL, cp->un.value.level[AUDIO_MIXER_LEVEL_RIGHT] & - CS_RLI_GAIN_MASK); + AUX_INPUT_ATTEN_BITS); } else break; error = 0; @@ -822,7 +808,7 @@ cs4231_set_port(addr, cp) #if 0 cs4231_write(sc, CS_MONO_IO_CONTROL, cp->un.value.level[AUDIO_MIXER_LEVEL_MONO] & - CS_MONO_MIA_MASK); + MONO_INPUT_ATTEN_BITS); #endif } else break; @@ -834,14 +820,14 @@ cs4231_set_port(addr, cp) if (cp->un.value.num_channels == 1) { cs4231_write(sc, SP_LEFT_AUX2_CONTROL, cp->un.value.level[AUDIO_MIXER_LEVEL_MONO] & - CS_LACIN2_GAIN_MASK); + LINE_INPUT_ATTEN_BITS); } else if (cp->un.value.num_channels == 2) { cs4231_write(sc, SP_LEFT_AUX2_CONTROL, cp->un.value.level[AUDIO_MIXER_LEVEL_LEFT] & - CS_LACIN2_GAIN_MASK); + LINE_INPUT_ATTEN_BITS); cs4231_write(sc, SP_RIGHT_AUX2_CONTROL, cp->un.value.level[AUDIO_MIXER_LEVEL_RIGHT] & - CS_RACIN2_GAIN_MASK); + LINE_INPUT_ATTEN_BITS); } else break; error = 0; @@ -953,14 +939,14 @@ cs4231_get_port(addr, cp) if (cp->un.value.num_channels == 1) cp->un.value.level[AUDIO_MIXER_LEVEL_MONO]= cs4231_read(sc, SP_LEFT_AUX1_CONTROL) & - CS_LACIN1_GAIN_MASK; + LINE_INPUT_ATTEN_BITS; else if (cp->un.value.num_channels == 2) { cp->un.value.level[AUDIO_MIXER_LEVEL_LEFT] = cs4231_read(sc, SP_LEFT_AUX1_CONTROL) & - CS_LACIN1_GAIN_MASK; + LINE_INPUT_ATTEN_BITS; cp->un.value.level[AUDIO_MIXER_LEVEL_RIGHT] = cs4231_read(sc, SP_RIGHT_AUX1_CONTROL) & - CS_RACIN1_GAIN_MASK; + LINE_INPUT_ATTEN_BITS; } else break; error = 0; @@ -970,12 +956,12 @@ cs4231_get_port(addr, cp) break; if (cp->un.value.num_channels == 1) cp->un.value.level[AUDIO_MIXER_LEVEL_MONO] = - cs4231_read(sc, CS_LEFT_LINE_CONTROL) & CS_LLI_GAIN_MASK; + cs4231_read(sc, CS_LEFT_LINE_CONTROL) & AUX_INPUT_ATTEN_BITS; else if (cp->un.value.num_channels == 2) { cp->un.value.level[AUDIO_MIXER_LEVEL_LEFT] = - cs4231_read(sc, CS_LEFT_LINE_CONTROL) & CS_LLI_GAIN_MASK; + cs4231_read(sc, CS_LEFT_LINE_CONTROL) & AUX_INPUT_ATTEN_BITS; cp->un.value.level[AUDIO_MIXER_LEVEL_RIGHT] = - cs4231_read(sc, CS_RIGHT_LINE_CONTROL) & CS_RLI_GAIN_MASK; + cs4231_read(sc, CS_RIGHT_LINE_CONTROL) & AUX_INPUT_ATTEN_BITS; } else break; error = 0; @@ -987,7 +973,7 @@ cs4231_get_port(addr, cp) #if 0 cp->un.value.level[AUDIO_MIXER_LEVEL_MONO] = cs4231_read(sc, CS_MONO_IO_CONTROL) & - CS_MONO_MIA_MASK; + MONO_INPUT_ATTEN_BITS; #endif } else break; @@ -999,14 +985,14 @@ cs4231_get_port(addr, cp) if (cp->un.value.num_channels == 1) cp->un.value.level[AUDIO_MIXER_LEVEL_MONO] = cs4231_read(sc, SP_LEFT_AUX2_CONTROL) & - CS_LACIN2_GAIN_MASK; + LINE_INPUT_ATTEN_BITS; else if (cp->un.value.num_channels == 2) { cp->un.value.level[AUDIO_MIXER_LEVEL_LEFT] = cs4231_read(sc, SP_LEFT_AUX2_CONTROL) & - CS_LACIN2_GAIN_MASK; + LINE_INPUT_ATTEN_BITS; cp->un.value.level[AUDIO_MIXER_LEVEL_RIGHT] = cs4231_read(sc, SP_RIGHT_AUX2_CONTROL) & - CS_RACIN2_GAIN_MASK; + LINE_INPUT_ATTEN_BITS; } else break; @@ -1313,14 +1299,14 @@ cs4231_intr(v) int r = 0; csr = APC_READ(sc, APC_CSR); - status = CS_READ(sc, CS4231_STS); - if (status & (CS_STATUS_INT | CS_STATUS_SER)) { + status = CS_READ(sc, AD1848_STATUS); + if (status & (INTERRUPT_STATUS | SAMPLE_ERROR)) { reg = cs4231_read(sc, CS_IRQ_STATUS); if (reg & CS_AFS_PI) { cs4231_write(sc, SP_LOWER_BASE_COUNT, 0xff); cs4231_write(sc, SP_UPPER_BASE_COUNT, 0xff); } - CS_WRITE(sc, CS4231_STS, 0); + CS_WRITE(sc, AD1848_STATUS, 0); } APC_WRITE(sc, APC_CSR, csr); @@ -1493,7 +1479,7 @@ cs4231_trigger_output(addr, start, end, blksize, intr, arg, param) cs4231_write(sc, SP_LOWER_BASE_COUNT, 0xff); cs4231_write(sc, SP_UPPER_BASE_COUNT, 0xff); cs4231_write(sc, SP_INTERFACE_CONFIG, - cs4231_read(sc, SP_INTERFACE_CONFIG) | CS_IC_PEN); + cs4231_read(sc, SP_INTERFACE_CONFIG) | PLAYBACK_ENABLE); } return (0); } diff --git a/sys/dev/sbus/cs4231reg.h b/sys/dev/sbus/cs4231reg.h deleted file mode 100644 index d8b1b1aa647..00000000000 --- a/sys/dev/sbus/cs4231reg.h +++ /dev/null @@ -1,391 +0,0 @@ -/* $OpenBSD: cs4231reg.h,v 1.3 2001/10/01 02:35:04 jason Exp $ */ - -/* - * Copyright (c) 1999 Jason L. Wright (jason@thought.net) - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Jason L. Wright - * 4. The name of the author may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED - * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, - * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, - * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN - * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE - * POSSIBILITY OF SUCH DAMAGE. - */ - -/* - * Driver for CS4231 SBUS audio. - */ - -#define CS_TIMEOUT 90000 - -/* CS4231 registers */ -#define CS4231_IAR 0x0000 /* index address */ -#define CS4231_IDR 0x0004 /* index data */ -#define CS4231_STS 0x0008 /* status */ -#define CS4231_DAT 0x000c /* pio data */ - -/* APC DMA registers */ -#define APC_CSR 0x0010 /* control/status */ -#define APC_CVA 0x0020 /* capture virtual address */ -#define APC_CC 0x0024 /* capture count */ -#define APC_CNVA 0x0028 /* capture next virtual address */ -#define APC_CNC 0x002c /* capture next count */ -#define APC_PVA 0x0030 /* playback virtual address */ -#define APC_PC 0x0034 /* playback count */ -#define APC_PNVA 0x0038 /* playback next virtual address */ -#define APC_PNC 0x003c /* playback next count */ - -/* - * The CS4231 has 4 direct access registers: iar, idr, status, pior - * - * iar and idr are used to access either 16 or 32 (mode 2 only) "indirect - * registers". - */ - -/* - * Direct mapped registers - */ - -/* cs4231_reg.iar: index address register */ -#define CS_IAR_IR_MASK 0x1f /* indirect register mask */ -#define CS_IAR_TRD 0x20 /* transfer request disable */ -#define CS_IAR_MCE 0x40 /* mode change enable */ -#define CS_IAR_INIT 0x80 /* initialization */ - -/* cs4231_reg.idr: index data register */ -/* Contains the data of the indirect register indexed by the iar */ - -/* cs4231_reg.status: status register */ -#define CS_STATUS_INT 0x01 /* interrupt status(1=active) */ -#define CS_STATUS_PRDY 0x02 /* playback data ready */ -#define CS_STATUS_PL 0x04 /* playback l/r sample */ -#define CS_STATUS_PU 0x08 /* playback up/lw byte needed */ -#define CS_STATUS_SER 0x10 /* sample error */ -#define CS_STATUS_CRDY 0x20 /* capture data ready */ -#define CS_STATUS_CL 0x40 /* capture l/r sample */ -#define CS_STATUS_CU 0x80 /* capture up/lw byte needed */ - -/* cs4231_reg.pior: programmed i/o register */ -/* On write, this is the playback data byte */ -/* On read, it is the capture data byte */ - -/* - * Indirect Mapped Registers - */ - -/* Left ADC Input Control: I0 */ -#define CS_LADCIN_GAIN_MASK 0x0f /* left adc gain */ -#define CS_LADCIN_reserved 0x10 /* reserved */ -#define CS_LADCIN_LMGE 0x20 /* left mic gain enable */ -#define CS_LADCIN_SRC_MASK 0xc0 /* left adc source select */ - -#define CS_LADCIN_SRC_LINE 0x00 /* left input src: line */ -#define CS_LADCIN_SRC_AUX 0x40 /* left input src: aux */ -#define CS_LADCIN_SRC_MIC 0x80 /* left input src: mic */ -#define CS_LADCIN_SRC_LOOP 0xc0 /* left input src: loopback */ - -/* Right ADC Input Control: I1 */ -#define CS_RADCIN_GAIN_MASK 0x0f /* right adc gain */ -#define CS_RADCIN_reserved 0x10 /* reserved */ -#define CS_RADCIN_LMGE 0x20 /* right mic gain enable */ -#define CS_RADCIN_SRC_MASK 0xc0 /* right adc source select */ - -#define CS_RADCIN_SRC_LINE 0x00 /* right input src: line */ -#define CS_RADCIN_SRC_AUX 0x40 /* right input src: aux */ -#define CS_RADCIN_SRC_MIC 0x80 /* right input src: mic */ -#define CS_RADCIN_SRC_LOOP 0xc0 /* right input src: loopback */ - -/* Left Auxiliary #1 Input Control: I2 */ -#define CS_LACIN1_GAIN_MASK 0x1f /* left aux #1 mix gain */ -#define CS_LACIN1_reserved1 0x20 /* reserved */ -#define CS_LACIN1_reserved2 0x40 /* reserved */ -#define CS_LACIN1_LX1M 0x80 /* left aux #1 mute */ - -/* Right Auxiliary #1 Input Control: I3 */ -#define CS_RACIN1_GAIN_MASK 0x1f /* right aux #1 mix gain */ -#define CS_RACIN1_reserved1 0x20 /* reserved */ -#define CS_RACIN1_reserved2 0x40 /* reserved */ -#define CS_RACIN1_RX1M 0x80 /* right aux #1 mute */ - -/* Left Auxiliary #2 Input Control: I4 */ -#define CS_LACIN2_GAIN_MASK 0x1f /* left aux #2 mix gain */ -#define CS_LACIN2_reserved1 0x20 /* reserved */ -#define CS_LACIN2_reserved2 0x40 /* reserved */ -#define CS_LACIN2_LX2M 0x80 /* left aux #2 mute */ - -/* Right Auxiliary #2 Input Control: I5 */ -#define CS_RACIN2_GAIN_MASK 0x1f /* right aux #2 mix gain */ -#define CS_RACIN2_reserved1 0x20 /* reserved */ -#define CS_RACIN2_reserved2 0x40 /* reserved */ -#define CS_RACIN2_RX2M 0x80 /* right aux #2 mute */ - -/* Left DAC Output Control: I6 */ -#define CS_LDACOUT_LDA_MASK 0x3f /* left dac attenuator */ -#define CS_LDACOUT_reserved 0x40 /* reserved */ -#define CS_LDACOUT_LDM 0x80 /* left dac mute */ - -/* Right DAC Output Control: I7 */ -#define CS_RDACOUT_RDA_MASK 0x3f /* right dac attenuator */ -#define CS_RDACOUT_reserved 0x40 /* reserved */ -#define CS_RDACOUT_RDM 0x80 /* right dac mute */ - -/* Fs and Playback Data Format: I8 */ -#define CS_FSPB_C2SL 0x01 /* clock 2 source select */ -#define CS_FSPB_CFS_MASK 0x0e /* clock frequency div select */ -#define CS_FSPB_SM 0x10 /* stereo/mono select */ -#define CS_FSPB_FMT_MASK 0xe0 /* playback format select */ - -#define CS_FSPB_C2SL_XTAL1 0x00 /* use 24.576 Mhz crystal */ -#define CS_FSPB_C2SL_XTAL2 0x01 /* use 16.9344 Mhz crystal */ -#define CS_FSPB_SM_MONO 0x00 /* use mono output */ -#define CS_FSPB_SM_STEREO 0x10 /* use stereo output */ -#define CS_FSPB_FMT_ULINEAR 0x00 /* fmt: linear 8bit unsigned */ -#define CS_FSPB_FMT_ULAW 0x20 /* fmt: ulaw, 8bit companded */ -#define CS_FSPB_FMT_LINEAR_LE 0x40 /* fmt: linear 16bit little */ -#define CS_FSPB_FMT_ALAW 0x60 /* fmt: alaw, 8bit companded */ -#define CS_FSPB_FMT_reserved1 0x80 /* fmt: reserved */ -#define CS_FSPB_FMT_ADPCM 0xa0 /* fmt: adpcm 4bit */ -#define CS_FSPB_FMT_LINEAR_BE 0xc0 /* fmt: linear 16bit big */ -#define CS_FSPB_FMT_reserved2 0xe0 /* fmt: reserved */ - -/* Interface Configuration: I9 */ -#define CS_IC_PEN 0x01 /* playback enable */ -#define CS_IC_CEN 0x02 /* capture enable */ -#define CS_IC_SDC 0x04 /* single dma channel */ -#define CS_IC_ACAL 0x08 /* auto calibration */ -#define CS_IC_CAL_MASK 0x18 /* calibration type mask */ -#define CS_IC_reserved 0x20 /* reserved */ -#define CS_IC_PPIO 0x40 /* playback pio enable */ -#define CS_IC_CPIO 0x80 /* capture pio enable */ - -/* Pin Control: I10 */ -#define CS_PC_reserved1 0x01 /* reserved */ -#define CS_PC_IEN 0x02 /* interrupt enable */ -#define CS_PC_reserved2 0x04 /* reserved */ -#define CS_PC_DEN 0x08 /* dither enable */ -#define CS_PC_reserved3 0x10 /* reserved */ -#define CS_PC_reserved4 0x20 /* reserved */ -#define CS_PC_XCTL_MASK 0xc0 /* xctl control */ -#define CS_PC_LINEMUTE 0x40 /* mute line */ -#define CS_PC_HDPHMUTE 0x80 /* mute headphone */ -#define CS_PC_XCTL0 0x40 /* set xtcl0 to 1 */ -#define CS_PC_XCTL1 0x80 /* set xctl1 to 1 */ - -/* Error Status and Initialization: I11 */ -#define CS_ERRINIT_ORL_MASK 0x03 /* overrange left detect */ -#define CS_ERRINIT_ORR_MASK 0x0c /* overrange right detect */ -#define CS_ERRINIT_DRQ 0x10 /* drq status */ -#define CS_ERRINIT_ACI 0x20 /* auto-calibrate in progress */ -#define CS_ERRINIT_PUR 0x40 /* playback underrun */ -#define CS_ERRINIT_COR 0x80 /* capture overrun */ - -#define CS_ERRINIT_ORL_VLOW 0x00 /* < -1.5 dB from full scale */ -#define CS_ERRINIT_ORL_LOW 0x01 /* -1.5dB < x < 0dB */ -#define CS_ERRINIT_ORL_HIGH 0x02 /* 0dB < x < 1.5dB */ -#define CS_ERRINIT_ORL_VHIGH 0x03 /* > 1.5dB overrange */ -#define CS_ERRINIT_ORR_VLOW 0x00 /* < -1.5 dB from full scale */ -#define CS_ERRINIT_ORR_LOW 0x04 /* -1.5dB < x < 0dB */ -#define CS_ERRINIT_ORR_HIGH 0x08 /* 0dB < x < 1.5dB */ -#define CS_ERRINIT_ORR_VHIGH 0x0c /* > 1.5dB overrange */ - -/* Mode and ID: I12 */ -#define CS_MODEID_ID_MASK 0x0f /* Codec ID */ -#define CS_MODEID_reserved1 0x10 /* reserved */ -#define CS_MODEID_reserved2 0x20 /* reserved */ -#define CS_MODEID_MODE2 0x40 /* enable mode2 operation */ - -#define CS_MODEID_CS4231 0x0a /* 1010 == cs4231 */ - -/* Loopback Control: I13 */ -#define CS_LOOP_LBE 0x01 /* loopback enable */ -#define CS_LOOP_reserved 0x02 /* reserved */ -#define CS_LOOP_LBA_MASK 0xfc /* loopback attenuation */ - -/* Playback Upper Base: I14 */ - -/* Playback Lower Base: I15 */ - -/* Alternate Feature Enable I: I16 */ -#define CS_AFE1_DACZ 0x01 /* dac zero */ -#define CS_AFE1_SPE 0x02 /* serial port enable */ -#define CS_AFE1_SF_MASK 0x0c /* serial format mask */ -#define CS_AFE1_PMCE 0x10 /* playback mode change enbl */ -#define CS_AFE1_CMCE 0x20 /* capture mode change enable */ -#define CS_AFE1_TE 0x40 /* timer enable */ -#define CS_AFE1_OLB 0x80 /* output level bit */ - -#define CS_AFE1_SF_64E 0x00 /* 64 bit enhanced */ -#define CS_AFE1_SF_64 0x04 /* 64 bit */ -#define CS_AFE1_SF_32 0x08 /* 32 bit */ -#define CS_AFE1_SF_reserved 0x0c /* reserved */ -#define CS_AFE1_OLB_2 0x00 /* full scale 2Vpp (-3dB) */ -#define CS_AFE1_OLB_28 0x80 /* full scale 2.8Vpp (0dB) */ - -/* Alternate Feature Enable II: I17 */ -#define CS_AFE2_HPF 0x01 /* high pass filter enable */ -#define CS_AFE2_XTALE 0x02 /* crystal enable */ -#define CS_AFE2_APAR 0x04 /* ADPCM pb accumulator reset */ -#define CS_AFE2_reserved 0x08 /* reserved */ -#define CS_AFE2_TEST_MASK 0xf0 /* factory test bits */ - -/* Left Line Input Control: I18 */ -#define CS_LLI_GAIN_MASK 0x1f /* left line mix gain mask */ -#define CS_LLI_reserved1 0x20 /* reserved */ -#define CS_LLI_reserved2 0x40 /* reserved */ -#define CS_LLI_MUTE 0x80 /* left line mute */ - -/* Right Line Input Control: I19 */ -#define CS_RLI_GAIN_MASK 0x1f /* right line mix gain mask */ -#define CS_RLI_reserved1 0x20 /* reserved */ -#define CS_RLI_reserved2 0x40 /* reserved */ -#define CS_RLI_MUTE 0x80 /* right line mute */ - -/* Timer Lower Base: I20 */ - -/* Timer Upper Base: I21 */ - -/* Reserved: I22 */ - -/* Alternate Feature Enable III: I23 */ -#define CS_AFE3_ACF 0x01 /* ADPCM capture freeze */ -#define CS_AFE3_reserved 0xfe /* reserved bits */ - -/* Alternate Feature Status: I24 */ -#define CS_AFS_PU 0x01 /* playback underrun */ -#define CS_AFS_PO 0x02 /* playback overrun */ -#define CS_AFS_CO 0x04 /* capture underrun */ -#define CS_AFS_CU 0x08 /* capture overrun */ -#define CS_AFS_PI 0x10 /* playback interrupt */ -#define CS_AFS_CI 0x20 /* capture interrupt */ -#define CS_AFS_TI 0x40 /* timer interrupt */ -#define CS_AFS_reserved 0x80 /* reserved */ - -/* Version ID: I25 */ -#define CS_VID_CHIP_MASK 0x07 /* chip id mask */ -#define CS_VID_VER_MASK 0xe0 /* version number mask */ - -#define CS_VID_CHIP_CS4231 0x00 /* CS4231 and CS4231A */ -#define CS_VID_VER_CS4231 0x80 /* CS4231 */ -#define CS_VID_VER_CS4232 0x82 /* CS4232 */ -#define CS_VID_VER_CS4231A 0xa0 /* CS4231A */ - -/* Mono Input & Output Control: I26 */ -#define CS_MONO_MIA_MASK 0x0f /* mono attenuation mask */ -#define CS_MONO_reserved 0x10 /* reserved */ -#define CS_MONO_MBY 0x20 /* mono bypass */ -#define CS_MONO_MOM 0x40 /* mono output mute */ -#define CS_MONO_MIM 0x80 /* mono input mute */ - -/* Reserved: I27 */ - -/* Capture Data Format: I28 */ -#define CS_CDF_reserved 0x0f /* reserved bits */ -#define CS_CDF_SM 0x10 /* Stereo/mono select */ -#define CS_CDF_FMT_MASK 0xe0 /* capture format mask */ - -#define CS_CDF_SM_MONO 0x00 /* select mono capture */ -#define CS_CDF_SM_STEREO 0x10 /* select stereo capture */ -#define CS_CDF_FMT_ULINEAR 0x00 /* fmt: linear 8bit unsigned */ -#define CS_CDF_FMT_ULAW 0x20 /* fmt: ulaw, 8bit companded */ -#define CS_CDF_FMT_LINEAR_LE 0x40 /* fmt: linear 16bit little */ -#define CS_CDF_FMT_ALAW 0x60 /* fmt: alaw, 8bit companded */ -#define CS_CDF_FMT_reserved1 0x80 /* fmt: reserved */ -#define CS_CDF_FMT_ADPCM 0xa0 /* fmt: adpcm 4bit */ -#define CS_CDF_FMT_LINEAR_BE 0xc0 /* fmt: linear 16bit big */ -#define CS_CDF_FMT_reserved2 0xe0 /* fmt: reserved */ - -/* Reserved: I29 */ - -/* Capture Upper Base: I30 */ - -/* Capture Lower Base: I31 */ - -/* - * APC DMA Register definitions - */ -#define APC_CSR_RESET 0x00000001 /* reset */ -#define APC_CSR_CDMA_GO 0x00000004 /* capture dma go */ -#define APC_CSR_PDMA_GO 0x00000008 /* playback dma go */ -#define APC_CSR_CODEC_RESET 0x00000020 /* codec reset */ -#define APC_CSR_CPAUSE 0x00000040 /* capture dma pause */ -#define APC_CSR_PPAUSE 0x00000080 /* playback dma pause */ -#define APC_CSR_CMIE 0x00000100 /* capture pipe empty enb */ -#define APC_CSR_CMI 0x00000200 /* capture pipe empty intr */ -#define APC_CSR_CD 0x00000400 /* capture nva dirty */ -#define APC_CSR_CM 0x00000800 /* capture data lost */ -#define APC_CSR_PMIE 0x00001000 /* pb pipe empty intr enable */ -#define APC_CSR_PD 0x00002000 /* pb nva dirty */ -#define APC_CSR_PM 0x00004000 /* pb pipe empty */ -#define APC_CSR_PMI 0x00008000 /* pb pipe empty interrupt */ -#define APC_CSR_EIE 0x00010000 /* error interrupt enable */ -#define APC_CSR_CIE 0x00020000 /* capture intr enable */ -#define APC_CSR_PIE 0x00040000 /* playback intr enable */ -#define APC_CSR_GIE 0x00080000 /* general intr enable */ -#define APC_CSR_EI 0x00100000 /* error interrupt */ -#define APC_CSR_CI 0x00200000 /* capture interrupt */ -#define APC_CSR_PI 0x00400000 /* playback interrupt */ -#define APC_CSR_GI 0x00800000 /* general interrupt */ - -#define APC_CSR_PLAY ( \ - APC_CSR_EI | \ - APC_CSR_GIE | \ - APC_CSR_PIE | \ - APC_CSR_EIE | \ - APC_CSR_PDMA_GO | \ - APC_CSR_PMIE ) - -#define APC_CSR_CAPTURE ( \ - APC_CSR_EI | \ - APC_CSR_GIE | \ - APC_CSR_CIE | \ - APC_CSR_EIE | \ - APC_CSR_CDMA_GO ) - -#define APC_CSR_PLAY_PAUSE (~( \ - APC_CSR_PPAUSE | \ - APC_CSR_GI | \ - APC_CSR_PI | \ - APC_CSR_CI | \ - APC_CSR_EI | \ - APC_CSR_PMI | \ - APC_CSR_PMIE | \ - APC_CSR_CMI | \ - APC_CSR_CMIE ) ) - -#define APC_CSR_CAPTURE_PAUSE (~( \ - APC_CSR_PPAUSE | \ - APC_CSR_GI | \ - APC_CSR_PI | \ - APC_CSR_CI | \ - APC_CSR_EI | \ - APC_CSR_PMI | \ - APC_CSR_PMIE | \ - APC_CSR_CMI | \ - APC_CSR_CMIE ) ) - -#define APC_CSR_INTR_MASK ( \ - APC_CSR_GI | \ - APC_CSR_PI | \ - APC_CSR_CI | \ - APC_CSR_EI | \ - APC_CSR_PMI | \ - APC_CSR_CMI ) |