summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/pci/auich.c646
1 files changed, 323 insertions, 323 deletions
diff --git a/sys/dev/pci/auich.c b/sys/dev/pci/auich.c
index d8c629ff5a4..25e0d2d9d62 100644
--- a/sys/dev/pci/auich.c
+++ b/sys/dev/pci/auich.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: auich.c,v 1.4 2000/11/20 17:48:58 mickey Exp $ */
+/* $OpenBSD: auich.c,v 1.5 2001/01/11 19:22:33 mickey Exp $ */
/*
* Copyright (c) 2000 Michael Shalayeff
@@ -28,7 +28,7 @@
* THE POSSIBILITY OF SUCH DAMAGE.
*/
-/* #define ICH_DEBUG */
+/* #define AUICH_DEBUG */
/*
* AC'97 audio found on Intel 810/820/440MX chipsets.
* http://developer.intel.com/design/chipsets/datashts/290655.htm
@@ -54,120 +54,120 @@
#include <dev/ic/ac97.h>
/* 12.1.10 NAMBAR - native audio mixer base address register */
-#define ICH_NAMBAR 0x10
+#define AUICH_NAMBAR 0x10
/* 12.1.11 NABMBAR - native audio bus mastering base address register */
-#define ICH_NABMBAR 0x14
+#define AUICH_NABMBAR 0x14
/* table 12-3. native audio bus master control registers */
-#define ICH_BDBAR 0x00 /* 8-byte aligned address */
-#define ICH_CIV 0x04 /* 5 bits current index value */
-#define ICH_LVI 0x05 /* 5 bits last valid index value */
-#define ICH_LVI_MASK 0x1f
-#define ICH_STS 0x06 /* 16 bits status */
-#define ICH_FIFOE 0x10 /* fifo error */
-#define ICH_BCIS 0x08 /* r- buf cmplt int sts; wr ack */
-#define ICH_LVBCI 0x04 /* r- last valid bci, wr ack */
-#define ICH_CELV 0x02 /* current equals last valid */
-#define ICH_DCH 0x01 /* dma halted */
-#define ICH_ISTS_BITS "\020\01dch\02celv\03lvbci\04bcis\05fifoe"
-#define ICH_PICB 0x08 /* 16 bits */
-#define ICH_PIV 0x0a /* 5 bits prefetched index value */
-#define ICH_CTRL 0x0b /* control */
-#define ICH_IOCE 0x10 /* int on completion enable */
-#define ICH_FEIE 0x08 /* fifo error int enable */
-#define ICH_LVBIE 0x04 /* last valid buf int enable */
-#define ICH_RR 0x02 /* 1 - reset regs */
-#define ICH_RPBM 0x01 /* 1 - run, 0 - pause */
-
-#define ICH_PCMI 0x00
-#define ICH_PCMO 0x10
-#define ICH_MICI 0x20
-
-#define ICH_GCTRL 0x2c
-#define ICH_SRIE 0x20 /* int when 2ndary codec resume */
-#define ICH_PRIE 0x10 /* int when primary codec resume */
-#define ICH_ACLSO 0x08 /* aclink shut off */
-#define ICH_WRESET 0x04 /* warm reset */
-#define ICH_CRESET 0x02 /* cold reset */
-#define ICH_GIE 0x01 /* gpi int enable */
-#define ICH_GSTS 0x30
-#define ICH_MD3 0x20000 /* pwr-dn semaphore for modem */
-#define ICH_AD3 0x10000 /* pwr-dn semaphore for audio */
-#define ICH_RCS 0x08000 /* read completion status */
-#define ICH_B3S12 0x04000 /* bit 3 of slot 12 */
-#define ICH_B2S12 0x02000 /* bit 2 of slot 12 */
-#define ICH_B1S12 0x01000 /* bit 1 of slot 12 */
-#define ICH_SRI 0x00800 /* secondary resume int */
-#define ICH_PRI 0x00400 /* primary resume int */
-#define ICH_SCR 0x00200 /* secondary codec ready */
-#define ICH_PCR 0x00100 /* primary codec ready */
-#define ICH_MINT 0x00080 /* mic in int */
-#define ICH_POINT 0x00040 /* pcm out int */
-#define ICH_PIINT 0x00020 /* pcm in int */
-#define ICH_MOINT 0x00004 /* modem out int */
-#define ICH_MIINT 0x00002 /* modem in int */
-#define ICH_GSCI 0x00001 /* gpi status change */
-#define ICH_GSTS_BITS "\020\01gsci\02miict\03moint\06piint\07point\010mint\011pcr\012scr\013pri\014sri\015b1s12\016b2s12\017b3s12\020rcs\021ad3\022md3"
-#define ICH_CAS 0x34 /* 1/8 bit */
-#define ICH_SEMATIMO 1000 /* us */
-
-#define ICH_MIXER_RESET 0x00
-#define ICH_MIXER_MUTE 0x02
-#define ICH_MIXER_HDFMUTE 0x04
-#define ICH_MIXER_MONOMUTE 0x06
-#define ICH_MIXER_TONE 0x08
-#define ICH_MIXER_BEEPMUTE 0x0a
-#define ICH_MIXER_PHONEMUTE 0x0c
-#define ICH_MIXER_MICMUTE 0x0e
-#define ICH_MIXER_LINEMUTE 0x10
-#define ICH_MIXER_CDMUTE 0x12
-#define ICH_MIXER_VDMUTE 0x14
-#define ICH_MIXER_AUXMUTE 0x16
-#define ICH_MIXER_PCMMUTE 0x18
-#define ICH_MIXER_RECSEL 0x1a
-#define ICH_MIXER_RECGAIN 0x1c
-#define ICH_MIXER_RECGAINMIC 0x1e
-#define ICH_MIXER_GP 0x20
-#define ICH_MIXER_3DCTRL 0x22
-#define ICH_MIXER_RESERVED 0x24
-#define ICH_PM 0x26
-#define ICH_PM_PCMI 0x100
-#define ICH_PM_PCMO 0x200
-#define ICH_PM_MICI 0x400
-#define ICH_EXTAUDIO 0x28
-#define ICH_EXTAUCTRL 0x2a
-#define ICH_PCMRATE 0x2c
-#define ICH_PCM3dRATE 0x2e
-#define ICH_PCMLFERATE 0x30
-#define ICH_PCMLRRATE 0x32
-#define ICH_MICADCRATE 0x34
-#define ICH_CLFEMUTE 0x36
-#define ICH_LR3DMUTE 0x38
+#define AUICH_BDBAR 0x00 /* 8-byte aligned address */
+#define AUICH_CIV 0x04 /* 5 bits current index value */
+#define AUICH_LVI 0x05 /* 5 bits last valid index value */
+#define AUICH_LVI_MASK 0x1f
+#define AUICH_STS 0x06 /* 16 bits status */
+#define AUICH_FIFOE 0x10 /* fifo error */
+#define AUICH_BCIS 0x08 /* r- buf cmplt int sts; wr ack */
+#define AUICH_LVBCI 0x04 /* r- last valid bci, wr ack */
+#define AUICH_CELV 0x02 /* current equals last valid */
+#define AUICH_DCH 0x01 /* dma halted */
+#define AUICH_ISTS_BITS "\020\01dch\02celv\03lvbci\04bcis\05fifoe"
+#define AUICH_PICB 0x08 /* 16 bits */
+#define AUICH_PIV 0x0a /* 5 bits prefetched index value */
+#define AUICH_CTRL 0x0b /* control */
+#define AUICH_IOCE 0x10 /* int on completion enable */
+#define AUICH_FEIE 0x08 /* fifo error int enable */
+#define AUICH_LVBIE 0x04 /* last valid buf int enable */
+#define AUICH_RR 0x02 /* 1 - reset regs */
+#define AUICH_RPBM 0x01 /* 1 - run, 0 - pause */
+
+#define AUICH_PCMI 0x00
+#define AUICH_PCMO 0x10
+#define AUICH_MICI 0x20
+
+#define AUICH_GCTRL 0x2c
+#define AUICH_SRIE 0x20 /* int when 2ndary codec resume */
+#define AUICH_PRIE 0x10 /* int when primary codec resume */
+#define AUICH_ACLSO 0x08 /* aclink shut off */
+#define AUICH_WRESET 0x04 /* warm reset */
+#define AUICH_CRESET 0x02 /* cold reset */
+#define AUICH_GIE 0x01 /* gpi int enable */
+#define AUICH_GSTS 0x30
+#define AUICH_MD3 0x20000 /* pwr-dn semaphore for modem */
+#define AUICH_AD3 0x10000 /* pwr-dn semaphore for audio */
+#define AUICH_RCS 0x08000 /* read completion status */
+#define AUICH_B3S12 0x04000 /* bit 3 of slot 12 */
+#define AUICH_B2S12 0x02000 /* bit 2 of slot 12 */
+#define AUICH_B1S12 0x01000 /* bit 1 of slot 12 */
+#define AUICH_SRI 0x00800 /* secondary resume int */
+#define AUICH_PRI 0x00400 /* primary resume int */
+#define AUICH_SCR 0x00200 /* secondary codec ready */
+#define AUICH_PCR 0x00100 /* primary codec ready */
+#define AUICH_MINT 0x00080 /* mic in int */
+#define AUICH_POINT 0x00040 /* pcm out int */
+#define AUICH_PIINT 0x00020 /* pcm in int */
+#define AUICH_MOINT 0x00004 /* modem out int */
+#define AUICH_MIINT 0x00002 /* modem in int */
+#define AUICH_GSCI 0x00001 /* gpi status change */
+#define AUICH_GSTS_BITS "\020\01gsci\02miict\03moint\06piint\07point\010mint\011pcr\012scr\013pri\014sri\015b1s12\016b2s12\017b3s12\020rcs\021ad3\022md3"
+#define AUICH_CAS 0x34 /* 1/8 bit */
+#define AUICH_SEMATIMO 1000 /* us */
+
+#define AUICH_MIXER_RESET 0x00
+#define AUICH_MIXER_MUTE 0x02
+#define AUICH_MIXER_HDFMUTE 0x04
+#define AUICH_MIXER_MONOMUTE 0x06
+#define AUICH_MIXER_TONE 0x08
+#define AUICH_MIXER_BEEPMUTE 0x0a
+#define AUICH_MIXER_PHONEMUTE 0x0c
+#define AUICH_MIXER_MICMUTE 0x0e
+#define AUICH_MIXER_LINEMUTE 0x10
+#define AUICH_MIXER_CDMUTE 0x12
+#define AUICH_MIXER_VDMUTE 0x14
+#define AUICH_MIXER_AUXMUTE 0x16
+#define AUICH_MIXER_PCMMUTE 0x18
+#define AUICH_MIXER_RECSEL 0x1a
+#define AUICH_MIXER_RECGAIN 0x1c
+#define AUICH_MIXER_RECGAINMIC 0x1e
+#define AUICH_MIXER_GP 0x20
+#define AUICH_MIXER_3DCTRL 0x22
+#define AUICH_MIXER_RESERVED 0x24
+#define AUICH_PM 0x26
+#define AUICH_PM_PCMI 0x100
+#define AUICH_PM_PCMO 0x200
+#define AUICH_PM_MICI 0x400
+#define AUICH_EXTAUDIO 0x28
+#define AUICH_EXTAUCTRL 0x2a
+#define AUICH_PCMRATE 0x2c
+#define AUICH_PCM3dRATE 0x2e
+#define AUICH_PCMLFERATE 0x30
+#define AUICH_PCMLRRATE 0x32
+#define AUICH_MICADCRATE 0x34
+#define AUICH_CLFEMUTE 0x36
+#define AUICH_LR3DMUTE 0x38
/*
* according to the dev/audiovar.h AU_RING_SIZE is 2^16, what fits
* in our limits perfectly, i.e. setting it to higher value
* in your kernel config would improve perfomance, still 2^21 is the max
*/
-#define ICH_DMALIST_MAX 32
-#define ICH_DMASEG_MAX (65536*2) /* 64k samples, 2x16 bit samples */
-struct ich_dmalist {
+#define AUICH_DMALIST_MAX 32
+#define AUICH_DMASEG_MAX (65536*2) /* 64k samples, 2x16 bit samples */
+struct auich_dmalist {
u_int32_t base;
u_int32_t len;
-#define ICH_DMAF_IOC 0x80000000 /* 1-int on complete */
-#define ICH_DMAF_BUP 0x40000000 /* 0-retrans last, 1-transmit 0 */
+#define AUICH_DMAF_IOC 0x80000000 /* 1-int on complete */
+#define AUICH_DMAF_BUP 0x40000000 /* 0-retrans last, 1-transmit 0 */
};
-struct ich_dma {
+struct auich_dma {
bus_dmamap_t map;
caddr_t addr;
- bus_dma_segment_t segs[ICH_DMALIST_MAX];
+ bus_dma_segment_t segs[AUICH_DMALIST_MAX];
int nsegs;
size_t size;
- struct ich_dma *next;
+ struct auich_dma *next;
};
-struct ich_softc {
+struct auich_softc {
struct device sc_dev;
void *sc_ih;
@@ -182,12 +182,12 @@ struct ich_softc {
struct ac97_host_if host_if;
/* dma scatter-gather buffer lists, aligned to 8 bytes */
- struct ich_dmalist *dmalist_pcmo, *dmap_pcmo,
- dmasto_pcmo[ICH_DMALIST_MAX+1];
- struct ich_dmalist *dmalist_pcmi, *dmap_pcmi,
- dmasto_pcmi[ICH_DMALIST_MAX+1];;
- struct ich_dmalist *dmalist_mici, *dmap_mici,
- dmasto_mici[ICH_DMALIST_MAX+1];;
+ struct auich_dmalist *dmalist_pcmo, *dmap_pcmo,
+ dmasto_pcmo[AUICH_DMALIST_MAX+1];
+ struct auich_dmalist *dmalist_pcmi, *dmap_pcmi,
+ dmasto_pcmi[AUICH_DMALIST_MAX+1];;
+ struct auich_dmalist *dmalist_mici, *dmap_mici,
+ dmasto_mici[AUICH_DMALIST_MAX+1];;
/* i/o buffer pointers */
u_int32_t pcmo_start, pcmo_p, pcmo_end;
int pcmo_blksize, pcmo_fifoe;
@@ -195,7 +195,7 @@ struct ich_softc {
int pcmi_blksize, pcmi_fifoe;
u_int32_t mici_start, mici_p, mici_end;
int mici_blksize, mici_fifoe;
- struct ich_dma *sc_dmas;
+ struct auich_dma *sc_dmas;
void (*sc_pintr) __P((void *));
void *sc_parg;
@@ -204,96 +204,97 @@ struct ich_softc {
void *sc_rarg;
};
-#ifdef ICH_DEBUG
-#define DPRINTF(l,x) do { if (ich_debug & (l)) printf x; } while(0)
-int ich_debug = 0xfffe;
-#define ICH_DEBUG_CODECIO 0x0001
-#define ICH_DEBUG_DMA 0x0002
-#define ICH_DEBUG_PARAM 0x0004
+#ifdef AUICH_DEBUG
+#define DPRINTF(l,x) do { if (auich_debug & (l)) printf x; } while(0)
+int auich_debug = 0xfffe;
+#define AUICH_DEBUG_CODECIO 0x0001
+#define AUICH_DEBUG_DMA 0x0002
+#define AUICH_DEBUG_PARAM 0x0004
#else
#define DPRINTF(x,y) /* nothing */
#endif
-struct cfdriver ich_cd = {
- NULL, "ich", DV_DULL
+struct cfdriver auich_cd = {
+ NULL, "auich", DV_DULL
};
-int ich_match __P((struct device *, void *, void *));
-void ich_attach __P((struct device *, struct device *, void *));
-int ich_intr __P((void *));
+int auich_match __P((struct device *, void *, void *));
+void auich_attach __P((struct device *, struct device *, void *));
+int auich_intr __P((void *));
-struct cfattach ich_ca = {
- sizeof(struct ich_softc), ich_match, ich_attach
+struct cfattach auich_ca = {
+ sizeof(struct auich_softc), auich_match, auich_attach
};
-static const struct ich_devtype {
+static const struct auich_devtype {
int product;
int options;
-} ich_devices[] = {
- { PCI_PRODUCT_INTEL_82801AA_ACA, 0 },
- { PCI_PRODUCT_INTEL_82801AB_ACA, 0 },
- { PCI_PRODUCT_INTEL_82801BA_ACA, 0 },
- { PCI_PRODUCT_INTEL_82440MX_ACA, 0 },
+ char name[8];
+} auich_devices[] = {
+ { PCI_PRODUCT_INTEL_82801AA_ACA, 0, "AUICH" },
+ { PCI_PRODUCT_INTEL_82801AB_ACA, 0, "AUICH0" },
+ { PCI_PRODUCT_INTEL_82801BA_ACA, 0, "AUICH2" },
+ { PCI_PRODUCT_INTEL_82440MX_ACA, 0, "440MX" },
};
-int ich_open __P((void *, int));
-void ich_close __P((void *));
-int ich_query_encoding __P((void *, struct audio_encoding *));
-int ich_set_params __P((void *, int, int, struct audio_params *,
+int auich_open __P((void *, int));
+void auich_close __P((void *));
+int auich_query_encoding __P((void *, struct audio_encoding *));
+int auich_set_params __P((void *, int, int, struct audio_params *,
struct audio_params *));
-int ich_round_blocksize __P((void *, int));
-int ich_halt_output __P((void *));
-int ich_halt_input __P((void *));
-int ich_getdev __P((void *, struct audio_device *));
-int ich_set_port __P((void *, mixer_ctrl_t *));
-int ich_get_port __P((void *, mixer_ctrl_t *));
-int ich_query_devinfo __P((void *, mixer_devinfo_t *));
-void *ich_allocm __P((void *, u_long, int, int));
-void ich_freem __P((void *, void *, int));
-u_long ich_round_buffersize __P((void *, u_long));
-int ich_mappage __P((void *, void *, int, int));
-int ich_get_props __P((void *));
-int ich_trigger_output __P((void *, void *, void *, int, void (*)(void *),
+int auich_round_blocksize __P((void *, int));
+int auich_halt_output __P((void *));
+int auich_halt_input __P((void *));
+int auich_getdev __P((void *, struct audio_device *));
+int auich_set_port __P((void *, mixer_ctrl_t *));
+int auich_get_port __P((void *, mixer_ctrl_t *));
+int auich_query_devinfo __P((void *, mixer_devinfo_t *));
+void *auich_allocm __P((void *, u_long, int, int));
+void auich_freem __P((void *, void *, int));
+u_long auich_round_buffersize __P((void *, u_long));
+int auich_mappage __P((void *, void *, int, int));
+int auich_get_props __P((void *));
+int auich_trigger_output __P((void *, void *, void *, int, void (*)(void *),
void *, struct audio_params *));
-int ich_trigger_input __P((void *, void *, void *, int, void (*)(void *),
+int auich_trigger_input __P((void *, void *, void *, int, void (*)(void *),
void *, struct audio_params *));
-struct audio_hw_if ich_hw_if = {
- ich_open,
- ich_close,
+struct audio_hw_if auich_hw_if = {
+ auich_open,
+ auich_close,
NULL, /* drain */
- ich_query_encoding,
- ich_set_params,
- ich_round_blocksize,
+ auich_query_encoding,
+ auich_set_params,
+ auich_round_blocksize,
NULL, /* commit_setting */
NULL, /* init_output */
NULL, /* init_input */
NULL, /* start_output */
NULL, /* start_input */
- ich_halt_output,
- ich_halt_input,
+ auich_halt_output,
+ auich_halt_input,
NULL, /* speaker_ctl */
- ich_getdev,
+ auich_getdev,
NULL, /* getfd */
- ich_set_port,
- ich_get_port,
- ich_query_devinfo,
- ich_allocm,
- ich_freem,
- ich_round_buffersize,
- ich_mappage,
- ich_get_props,
- ich_trigger_output,
- ich_trigger_input
+ auich_set_port,
+ auich_get_port,
+ auich_query_devinfo,
+ auich_allocm,
+ auich_freem,
+ auich_round_buffersize,
+ auich_mappage,
+ auich_get_props,
+ auich_trigger_output,
+ auich_trigger_input
};
-int ich_attach_codec __P((void *, struct ac97_codec_if *));
-int ich_read_codec __P((void *, u_int8_t, u_int16_t *));
-int ich_write_codec __P((void *, u_int8_t, u_int16_t));
-void ich_reset_codec __P((void *));
+int auich_attach_codec __P((void *, struct ac97_codec_if *));
+int auich_read_codec __P((void *, u_int8_t, u_int16_t *));
+int auich_write_codec __P((void *, u_int8_t, u_int16_t));
+void auich_reset_codec __P((void *));
int
-ich_match(parent, match, aux)
+auich_match(parent, match, aux)
struct device *parent;
void *match;
void *aux;
@@ -304,31 +305,32 @@ ich_match(parent, match, aux)
if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_INTEL)
return 0;
- for (i = sizeof(ich_devices)/sizeof(ich_devices[0]); i--;)
- if (PCI_PRODUCT(pa->pa_id) == ich_devices[i].product)
+ for (i = sizeof(auich_devices)/sizeof(auich_devices[0]); i--;)
+ if (PCI_PRODUCT(pa->pa_id) == auich_devices[i].product)
return 1;
return 0;
}
void
-ich_attach(parent, self, aux)
+auich_attach(parent, self, aux)
struct device *parent, *self;
void *aux;
{
- struct ich_softc *sc = (struct ich_softc *)self;
+ struct auich_softc *sc = (struct auich_softc *)self;
struct pci_attach_args *pa = aux;
pci_intr_handle_t ih;
bus_size_t mix_size, aud_size;
pcireg_t csr;
const char *intrstr;
+ int i;
- if (pci_mapreg_map(pa, ICH_NAMBAR, PCI_MAPREG_TYPE_IO, 0,
+ if (pci_mapreg_map(pa, AUICH_NAMBAR, PCI_MAPREG_TYPE_IO, 0,
&sc->iot, &sc->mix_ioh, NULL, &mix_size)) {
printf(": can't map codec i/o space\n");
return;
}
- if (pci_mapreg_map(pa, ICH_NABMBAR, PCI_MAPREG_TYPE_IO, 0,
+ if (pci_mapreg_map(pa, AUICH_NABMBAR, PCI_MAPREG_TYPE_IO, 0,
&sc->iot, &sc->aud_ioh, NULL, &aud_size)) {
printf(": can't map device i/o space\n");
bus_space_unmap(sc->iot, sc->mix_ioh, mix_size);
@@ -349,7 +351,7 @@ ich_attach(parent, self, aux)
return;
}
intrstr = pci_intr_string(pa->pa_pc, ih);
- sc->sc_ih = pci_intr_establish(pa->pa_pc, ih, IPL_AUDIO, ich_intr, sc,
+ sc->sc_ih = pci_intr_establish(pa->pa_pc, ih, IPL_AUDIO, auich_intr, sc,
sc->sc_dev.dv_xname);
if (!sc->sc_ih) {
printf(": can't establish interrupt");
@@ -361,13 +363,11 @@ ich_attach(parent, self, aux)
return;
}
-#ifdef notused
- for (i = sizeof(ich_devices)/sizeof(ich_devices[0]); i--;)
- if (PCI_PRODUCT(pa->pa_id) == ich_devices[i].product)
+ for (i = sizeof(auich_devices)/sizeof(auich_devices[0]); i--;)
+ if (PCI_PRODUCT(pa->pa_id) == auich_devices[i].product)
break;
-#endif
- strcpy(sc->sc_audev.name, "ICH0 AC97");
+ sprintf(sc->sc_audev.name, "%s AC97", auich_devices[i].name);
sprintf(sc->sc_audev.version, "0x%02x", PCI_REVISION(pa->pa_class));
strcpy(sc->sc_audev.config, sc->sc_dev.dv_xname);
@@ -379,17 +379,17 @@ ich_attach(parent, self, aux)
sc->dmalist_pcmi = sc->dmap_pcmi = a(sc->dmasto_pcmi);
sc->dmalist_mici = sc->dmap_mici = a(sc->dmasto_mici);
#undef a
- DPRINTF(ICH_DEBUG_DMA, ("ich_attach: lists %p %p %p\n",
+ DPRINTF(AUICH_DEBUG_DMA, ("auich_attach: lists %p %p %p\n",
sc->dmalist_pcmo, sc->dmalist_pcmi, sc->dmalist_mici));
/* Reset codec and AC'97 */
- ich_reset_codec(sc);
+ auich_reset_codec(sc);
sc->host_if.arg = sc;
- sc->host_if.attach = ich_attach_codec;
- sc->host_if.read = ich_read_codec;
- sc->host_if.write = ich_write_codec;
- sc->host_if.reset = ich_reset_codec;
+ sc->host_if.attach = auich_attach_codec;
+ sc->host_if.read = auich_read_codec;
+ sc->host_if.write = auich_write_codec;
+ sc->host_if.reset = auich_reset_codec;
if (ac97_attach(&sc->host_if) != 0) {
pci_intr_disestablish(pa->pa_pc, sc->sc_ih);
@@ -398,83 +398,83 @@ ich_attach(parent, self, aux)
return;
}
- audio_attach_mi(&ich_hw_if, sc, &sc->sc_dev);
+ audio_attach_mi(&auich_hw_if, sc, &sc->sc_dev);
}
int
-ich_read_codec(v, reg, val)
+auich_read_codec(v, reg, val)
void *v;
u_int8_t reg;
u_int16_t *val;
{
- struct ich_softc *sc = v;
+ struct auich_softc *sc = v;
int i;
/* wait for an access semaphore */
- for (i = ICH_SEMATIMO; i-- &&
- bus_space_read_1(sc->iot, sc->aud_ioh, ICH_CAS) & 1; DELAY(1));
+ for (i = AUICH_SEMATIMO; i-- &&
+ bus_space_read_1(sc->iot, sc->aud_ioh, AUICH_CAS) & 1; DELAY(1));
if (i > 0) {
*val = bus_space_read_2(sc->iot, sc->mix_ioh, reg);
- DPRINTF(ICH_DEBUG_CODECIO,
- ("ich_read_codec(%x, %x)\n", reg, *val));
+ DPRINTF(AUICH_DEBUG_CODECIO,
+ ("auich_read_codec(%x, %x)\n", reg, *val));
return 0;
} else {
- DPRINTF(ICH_DEBUG_CODECIO,
+ DPRINTF(AUICH_DEBUG_CODECIO,
("%s: read_codec timeout\n", sc->sc_dev.dv_xname));
return -1;
}
}
int
-ich_write_codec(v, reg, val)
+auich_write_codec(v, reg, val)
void *v;
u_int8_t reg;
u_int16_t val;
{
- struct ich_softc *sc = v;
+ struct auich_softc *sc = v;
int i;
- DPRINTF(ICH_DEBUG_CODECIO, ("ich_write_codec(%x, %x)\n", reg, val));
+ DPRINTF(AUICH_DEBUG_CODECIO, ("auich_write_codec(%x, %x)\n", reg, val));
/* wait for an access semaphore */
- for (i = ICH_SEMATIMO; i-- &&
- bus_space_read_1(sc->iot, sc->aud_ioh, ICH_CAS) & 1; DELAY(1));
+ for (i = AUICH_SEMATIMO; i-- &&
+ bus_space_read_1(sc->iot, sc->aud_ioh, AUICH_CAS) & 1; DELAY(1));
if (i > 0) {
bus_space_write_2(sc->iot, sc->mix_ioh, reg, val);
return 0;
} else {
- DPRINTF(ICH_DEBUG_CODECIO,
+ DPRINTF(AUICH_DEBUG_CODECIO,
("%s: write_codec timeout\n", sc->sc_dev.dv_xname));
return -1;
}
}
int
-ich_attach_codec(v, cif)
+auich_attach_codec(v, cif)
void *v;
struct ac97_codec_if *cif;
{
- struct ich_softc *sc = v;
+ struct auich_softc *sc = v;
sc->codec_if = cif;
return 0;
}
void
-ich_reset_codec(v)
+auich_reset_codec(v)
void *v;
{
- struct ich_softc *sc = v;
- bus_space_write_4(sc->iot, sc->aud_ioh, ICH_GCTRL, 0);
+ struct auich_softc *sc = v;
+ bus_space_write_4(sc->iot, sc->aud_ioh, AUICH_GCTRL, 0);
DELAY(10);
- bus_space_write_4(sc->iot, sc->aud_ioh, ICH_GCTRL, ICH_CRESET);
+ bus_space_write_4(sc->iot, sc->aud_ioh, AUICH_GCTRL, AUICH_CRESET);
}
int
-ich_open(v, flags)
+auich_open(v, flags)
void *v;
int flags;
{
@@ -482,13 +482,13 @@ ich_open(v, flags)
}
void
-ich_close(v)
+auich_close(v)
void *v;
{
}
int
-ich_query_encoding(v, aep)
+auich_query_encoding(v, aep)
void *v;
struct audio_encoding *aep;
{
@@ -547,12 +547,12 @@ ich_query_encoding(v, aep)
}
int
-ich_set_params(v, setmode, usemode, play, rec)
+auich_set_params(v, setmode, usemode, play, rec)
void *v;
int setmode, usemode;
struct audio_params *play, *rec;
{
- struct ich_softc *sc = v;
+ struct auich_softc *sc = v;
u_int16_t val, rate;
if (setmode & AUMODE_PLAY) {
@@ -589,14 +589,14 @@ ich_set_params(v, setmode, usemode, play, rec)
return EINVAL;
}
- ich_read_codec(sc, ICH_PM, &val);
- ich_write_codec(sc, ICH_PM, val | ICH_PM_PCMO);
+ auich_read_codec(sc, AUICH_PM, &val);
+ auich_write_codec(sc, AUICH_PM, val | AUICH_PM_PCMO);
- ich_write_codec(sc, ICH_PCMRATE, play->sample_rate);
- ich_read_codec(sc, ICH_PCMRATE, &rate);
+ auich_write_codec(sc, AUICH_PCMRATE, play->sample_rate);
+ auich_read_codec(sc, AUICH_PCMRATE, &rate);
play->sample_rate = rate;
- ich_write_codec(sc, ICH_PM, val);
+ auich_write_codec(sc, AUICH_PM, val);
}
if (setmode & AUMODE_RECORD) {
@@ -631,21 +631,21 @@ ich_set_params(v, setmode, usemode, play, rec)
return EINVAL;
}
- ich_read_codec(sc, ICH_PM, &val);
- ich_write_codec(sc, ICH_PM, val | ICH_PM_PCMI);
+ auich_read_codec(sc, AUICH_PM, &val);
+ auich_write_codec(sc, AUICH_PM, val | AUICH_PM_PCMI);
- ich_write_codec(sc, ICH_PCMLFERATE, play->sample_rate);
- ich_read_codec(sc, ICH_PCMLFERATE, &rate);
+ auich_write_codec(sc, AUICH_PCMLFERATE, play->sample_rate);
+ auich_read_codec(sc, AUICH_PCMLFERATE, &rate);
play->sample_rate = rate;
- ich_write_codec(sc, ICH_PM, val);
+ auich_write_codec(sc, AUICH_PM, val);
}
return 0;
}
int
-ich_round_blocksize(v, blk)
+auich_round_blocksize(v, blk)
void *v;
int blk;
{
@@ -653,83 +653,83 @@ ich_round_blocksize(v, blk)
}
int
-ich_halt_output(v)
+auich_halt_output(v)
void *v;
{
- struct ich_softc *sc = v;
+ struct auich_softc *sc = v;
- DPRINTF(ICH_DEBUG_DMA, ("%s: halt_output\n", sc->sc_dev.dv_xname));
+ DPRINTF(AUICH_DEBUG_DMA, ("%s: halt_output\n", sc->sc_dev.dv_xname));
- bus_space_write_1(sc->iot, sc->aud_ioh, ICH_PCMO + ICH_CTRL, ICH_RR);
+ bus_space_write_1(sc->iot, sc->aud_ioh, AUICH_PCMO + AUICH_CTRL, AUICH_RR);
return 0;
}
int
-ich_halt_input(v)
+auich_halt_input(v)
void *v;
{
- struct ich_softc *sc = v;
+ struct auich_softc *sc = v;
- DPRINTF(ICH_DEBUG_DMA,
+ DPRINTF(AUICH_DEBUG_DMA,
("%s: halt_input\n", sc->sc_dev.dv_xname));
/* XXX halt both unless known otherwise */
- bus_space_write_1(sc->iot, sc->aud_ioh, ICH_PCMI + ICH_CTRL, ICH_RR);
- bus_space_write_1(sc->iot, sc->aud_ioh, ICH_MICI + ICH_CTRL, ICH_RR);
+ bus_space_write_1(sc->iot, sc->aud_ioh, AUICH_PCMI + AUICH_CTRL, AUICH_RR);
+ bus_space_write_1(sc->iot, sc->aud_ioh, AUICH_MICI + AUICH_CTRL, AUICH_RR);
return 0;
}
int
-ich_getdev(v, adp)
+auich_getdev(v, adp)
void *v;
struct audio_device *adp;
{
- struct ich_softc *sc = v;
+ struct auich_softc *sc = v;
*adp = sc->sc_audev;
return 0;
}
int
-ich_set_port(v, cp)
+auich_set_port(v, cp)
void *v;
mixer_ctrl_t *cp;
{
- struct ich_softc *sc = v;
+ struct auich_softc *sc = v;
return sc->codec_if->vtbl->mixer_set_port(sc->codec_if, cp);
}
int
-ich_get_port(v, cp)
+auich_get_port(v, cp)
void *v;
mixer_ctrl_t *cp;
{
- struct ich_softc *sc = v;
+ struct auich_softc *sc = v;
return sc->codec_if->vtbl->mixer_get_port(sc->codec_if, cp);
}
int
-ich_query_devinfo(v, dp)
+auich_query_devinfo(v, dp)
void *v;
mixer_devinfo_t *dp;
{
- struct ich_softc *sc = v;
+ struct auich_softc *sc = v;
return sc->codec_if->vtbl->query_devinfo(sc->codec_if, dp);
}
void *
-ich_allocm(v, size, pool, flags)
+auich_allocm(v, size, pool, flags)
void *v;
u_long size;
int pool, flags;
{
- struct ich_softc *sc = v;
- struct ich_dma *p;
+ struct auich_softc *sc = v;
+ struct auich_dma *p;
int error;
- if (size > ICH_DMALIST_MAX * ICH_DMASEG_MAX)
+ if (size > AUICH_DMALIST_MAX * AUICH_DMASEG_MAX)
return NULL;
p = malloc(sizeof(*p), pool, flags);
@@ -784,17 +784,17 @@ ich_allocm(v, size, pool, flags)
}
void
-ich_freem(v, ptr, pool)
+auich_freem(v, ptr, pool)
void *v;
void *ptr;
int pool;
{
- struct ich_softc *sc = v;
- struct ich_dma *p;
+ struct auich_softc *sc = v;
+ struct auich_dma *p;
for (p = sc->sc_dmas; p->addr != ptr; p = p->next)
if (p->next == NULL) {
- printf("ich_free: trying to free not allocated memory");
+ printf("auich_free: trying to free not allocated memory");
return;
}
@@ -806,25 +806,25 @@ ich_freem(v, ptr, pool)
}
u_long
-ich_round_buffersize(v, size)
+auich_round_buffersize(v, size)
void *v;
u_long size;
{
- if (size > ICH_DMALIST_MAX * ICH_DMASEG_MAX)
- size = ICH_DMALIST_MAX * ICH_DMASEG_MAX;
+ if (size > AUICH_DMALIST_MAX * AUICH_DMASEG_MAX)
+ size = AUICH_DMALIST_MAX * AUICH_DMASEG_MAX;
return size;
}
int
-ich_mappage(v, mem, off, prot)
+auich_mappage(v, mem, off, prot)
void *v;
void *mem;
int off;
int prot;
{
- struct ich_softc *sc = v;
- struct ich_dma *p;
+ struct auich_softc *sc = v;
+ struct auich_dma *p;
if (off < 0)
return -1;
@@ -838,35 +838,35 @@ ich_mappage(v, mem, off, prot)
}
int
-ich_get_props(v)
+auich_get_props(v)
void *v;
{
return AUDIO_PROP_MMAP | AUDIO_PROP_INDEPENDENT | AUDIO_PROP_FULLDUPLEX;
}
int
-ich_intr(v)
+auich_intr(v)
void *v;
{
- struct ich_softc *sc = v;
+ struct auich_softc *sc = v;
int ret = 0, sts, gsts, i;
- gsts = bus_space_read_2(sc->iot, sc->aud_ioh, ICH_GSTS);
- DPRINTF(ICH_DEBUG_DMA, ("ich_intr: gsts=%b\n", gsts, ICH_GSTS_BITS));
+ gsts = bus_space_read_2(sc->iot, sc->aud_ioh, AUICH_GSTS);
+ DPRINTF(AUICH_DEBUG_DMA, ("auich_intr: gsts=%b\n", gsts, AUICH_GSTS_BITS));
- if (gsts & ICH_POINT) {
- sts = bus_space_read_2(sc->iot, sc->aud_ioh, ICH_PCMO+ICH_STS);
- DPRINTF(ICH_DEBUG_DMA,
- ("ich_intr: osts=%b\n", sts, ICH_ISTS_BITS));
+ if (gsts & AUICH_POINT) {
+ sts = bus_space_read_2(sc->iot, sc->aud_ioh, AUICH_PCMO+AUICH_STS);
+ DPRINTF(AUICH_DEBUG_DMA,
+ ("auich_intr: osts=%b\n", sts, AUICH_ISTS_BITS));
- if (sts & ICH_FIFOE) {
+ if (sts & AUICH_FIFOE) {
printf("%s: fifo underrun # %u\n",
sc->sc_dev.dv_xname, ++sc->pcmo_fifoe);
}
- i = bus_space_read_1(sc->iot, sc->aud_ioh, ICH_PCMO + ICH_CIV);
- if (sts & (ICH_LVBCI | ICH_CELV)) {
- struct ich_dmalist *q, *qe;
+ i = bus_space_read_1(sc->iot, sc->aud_ioh, AUICH_PCMO + AUICH_CIV);
+ if (sts & (AUICH_LVBCI | AUICH_CELV)) {
+ struct auich_dmalist *q, *qe;
q = sc->dmap_pcmo;
qe = &sc->dmalist_pcmo[i];
@@ -874,49 +874,49 @@ ich_intr(v)
while (q != qe) {
q->base = sc->pcmo_p;
- q->len = (sc->pcmo_blksize / 2) | ICH_DMAF_IOC;
- DPRINTF(ICH_DEBUG_DMA,
- ("ich_intr: %p, %p = %x @ %p\n",
+ q->len = (sc->pcmo_blksize / 2) | AUICH_DMAF_IOC;
+ DPRINTF(AUICH_DEBUG_DMA,
+ ("auich_intr: %p, %p = %x @ %p\n",
qe, q, sc->pcmo_blksize / 2, sc->pcmo_p));
sc->pcmo_p += sc->pcmo_blksize;
if (sc->pcmo_p >= sc->pcmo_end)
sc->pcmo_p = sc->pcmo_start;
- if (++q == &sc->dmalist_pcmo[ICH_DMALIST_MAX])
+ if (++q == &sc->dmalist_pcmo[AUICH_DMALIST_MAX])
q = sc->dmalist_pcmo;
}
sc->dmap_pcmo = q;
bus_space_write_1(sc->iot, sc->aud_ioh,
- ICH_PCMO + ICH_LVI,
+ AUICH_PCMO + AUICH_LVI,
(sc->dmap_pcmo - sc->dmalist_pcmo - 1) &
- ICH_LVI_MASK);
+ AUICH_LVI_MASK);
}
- if (sts & ICH_BCIS && sc->sc_pintr)
+ if (sts & AUICH_BCIS && sc->sc_pintr)
sc->sc_pintr(sc->sc_parg);
/* int ack */
- bus_space_write_2(sc->iot, sc->aud_ioh, ICH_PCMO + ICH_STS,
- sts & (ICH_LVBCI | ICH_CELV | ICH_BCIS | ICH_FIFOE));
- bus_space_write_2(sc->iot, sc->aud_ioh, ICH_GSTS, ICH_POINT);
+ bus_space_write_2(sc->iot, sc->aud_ioh, AUICH_PCMO + AUICH_STS,
+ sts & (AUICH_LVBCI | AUICH_CELV | AUICH_BCIS | AUICH_FIFOE));
+ bus_space_write_2(sc->iot, sc->aud_ioh, AUICH_GSTS, AUICH_POINT);
ret++;
}
- if (gsts & ICH_PIINT) {
- sts = bus_space_read_2(sc->iot, sc->aud_ioh, ICH_PCMI+ICH_STS);
- DPRINTF(ICH_DEBUG_DMA,
- ("ich_intr: ists=%b\n", sts, ICH_ISTS_BITS));
+ if (gsts & AUICH_PIINT) {
+ sts = bus_space_read_2(sc->iot, sc->aud_ioh, AUICH_PCMI+AUICH_STS);
+ DPRINTF(AUICH_DEBUG_DMA,
+ ("auich_intr: ists=%b\n", sts, AUICH_ISTS_BITS));
- if (sts & ICH_FIFOE) {
+ if (sts & AUICH_FIFOE) {
printf("%s: fifo overrun # %u\n",
sc->sc_dev.dv_xname, ++sc->pcmi_fifoe);
}
- i = bus_space_read_1(sc->iot, sc->aud_ioh, ICH_PCMI + ICH_CIV);
- if (sts & (ICH_LVBCI | ICH_CELV)) {
- struct ich_dmalist *q, *qe;
+ i = bus_space_read_1(sc->iot, sc->aud_ioh, AUICH_PCMI + AUICH_CIV);
+ if (sts & (AUICH_LVBCI | AUICH_CELV)) {
+ struct auich_dmalist *q, *qe;
q = sc->dmap_pcmi;
qe = &sc->dmalist_pcmi[i];
@@ -924,53 +924,53 @@ ich_intr(v)
while (q != qe) {
q->base = sc->pcmi_p;
- q->len = (sc->pcmi_blksize / 2) | ICH_DMAF_IOC;
- DPRINTF(ICH_DEBUG_DMA,
- ("ich_intr: %p, %p = %x @ %p\n",
+ q->len = (sc->pcmi_blksize / 2) | AUICH_DMAF_IOC;
+ DPRINTF(AUICH_DEBUG_DMA,
+ ("auich_intr: %p, %p = %x @ %p\n",
qe, q, sc->pcmi_blksize / 2, sc->pcmi_p));
sc->pcmi_p += sc->pcmi_blksize;
if (sc->pcmi_p >= sc->pcmi_end)
sc->pcmi_p = sc->pcmi_start;
- if (++q == &sc->dmalist_pcmi[ICH_DMALIST_MAX])
+ if (++q == &sc->dmalist_pcmi[AUICH_DMALIST_MAX])
q = sc->dmalist_pcmi;
}
sc->dmap_pcmi = q;
bus_space_write_1(sc->iot, sc->aud_ioh,
- ICH_PCMI + ICH_LVI,
+ AUICH_PCMI + AUICH_LVI,
(sc->dmap_pcmi - sc->dmalist_pcmi - 1) &
- ICH_LVI_MASK);
+ AUICH_LVI_MASK);
}
- if (sts & ICH_BCIS && sc->sc_rintr)
+ if (sts & AUICH_BCIS && sc->sc_rintr)
sc->sc_rintr(sc->sc_rarg);
/* int ack */
- bus_space_write_2(sc->iot, sc->aud_ioh, ICH_PCMI + ICH_STS,
- sts & (ICH_LVBCI | ICH_CELV | ICH_BCIS | ICH_FIFOE));
- bus_space_write_2(sc->iot, sc->aud_ioh, ICH_GSTS, ICH_POINT);
+ bus_space_write_2(sc->iot, sc->aud_ioh, AUICH_PCMI + AUICH_STS,
+ sts & (AUICH_LVBCI | AUICH_CELV | AUICH_BCIS | AUICH_FIFOE));
+ bus_space_write_2(sc->iot, sc->aud_ioh, AUICH_GSTS, AUICH_POINT);
ret++;
}
- if (gsts & ICH_MIINT) {
- sts = bus_space_read_2(sc->iot, sc->aud_ioh, ICH_MICI+ICH_STS);
- DPRINTF(ICH_DEBUG_DMA,
- ("ich_intr: ists=%b\n", sts, ICH_ISTS_BITS));
- if (sts & ICH_FIFOE)
+ if (gsts & AUICH_MIINT) {
+ sts = bus_space_read_2(sc->iot, sc->aud_ioh, AUICH_MICI+AUICH_STS);
+ DPRINTF(AUICH_DEBUG_DMA,
+ ("auich_intr: ists=%b\n", sts, AUICH_ISTS_BITS));
+ if (sts & AUICH_FIFOE)
printf("%s: fifo overrun\n", sc->sc_dev.dv_xname);
/* TODO mic input dma */
- bus_space_write_2(sc->iot, sc->aud_ioh, ICH_GSTS, ICH_MIINT);
+ bus_space_write_2(sc->iot, sc->aud_ioh, AUICH_GSTS, AUICH_MIINT);
}
return ret;
}
int
-ich_trigger_output(v, start, end, blksize, intr, arg, param)
+auich_trigger_output(v, start, end, blksize, intr, arg, param)
void *v;
void *start, *end;
int blksize;
@@ -978,17 +978,17 @@ ich_trigger_output(v, start, end, blksize, intr, arg, param)
void *arg;
struct audio_params *param;
{
- struct ich_softc *sc = v;
- struct ich_dmalist *q;
+ struct auich_softc *sc = v;
+ struct auich_dmalist *q;
- DPRINTF(ICH_DEBUG_DMA,
- ("ich_trigger_output(%x, %x, %d, %p, %p, %p)\n",
+ DPRINTF(AUICH_DEBUG_DMA,
+ ("auich_trigger_output(%x, %x, %d, %p, %p, %p)\n",
kvtop((caddr_t)start), kvtop((caddr_t)end),
blksize, intr, arg, param));
#ifdef DIAGNOSTIC
{
- struct ich_dma *p;
+ struct auich_dma *p;
for (p = sc->sc_dmas; p && p->addr != start; p = p->next);
if (!p)
return -1;
@@ -1009,23 +1009,23 @@ ich_trigger_output(v, start, end, blksize, intr, arg, param)
q = sc->dmap_pcmo = sc->dmalist_pcmo;
q->base = sc->pcmo_start;
- q->len = (blksize / 2) | ICH_DMAF_IOC;
- if (++q == &sc->dmalist_pcmo[ICH_DMALIST_MAX])
+ q->len = (blksize / 2) | AUICH_DMAF_IOC;
+ if (++q == &sc->dmalist_pcmo[AUICH_DMALIST_MAX])
q = sc->dmalist_pcmo;
sc->dmap_pcmo = q;
- bus_space_write_4(sc->iot, sc->aud_ioh, ICH_PCMO + ICH_BDBAR,
+ bus_space_write_4(sc->iot, sc->aud_ioh, AUICH_PCMO + AUICH_BDBAR,
kvtop((caddr_t)sc->dmalist_pcmo));
- bus_space_write_1(sc->iot, sc->aud_ioh, ICH_PCMO + ICH_CTRL,
- ICH_IOCE | ICH_FEIE | ICH_LVBIE | ICH_RPBM);
- bus_space_write_1(sc->iot, sc->aud_ioh, ICH_PCMO + ICH_LVI,
- (sc->dmap_pcmo - 1 - sc->dmalist_pcmo) & ICH_LVI_MASK);
+ bus_space_write_1(sc->iot, sc->aud_ioh, AUICH_PCMO + AUICH_CTRL,
+ AUICH_IOCE | AUICH_FEIE | AUICH_LVBIE | AUICH_RPBM);
+ bus_space_write_1(sc->iot, sc->aud_ioh, AUICH_PCMO + AUICH_LVI,
+ (sc->dmap_pcmo - 1 - sc->dmalist_pcmo) & AUICH_LVI_MASK);
return 0;
}
int
-ich_trigger_input(v, start, end, blksize, intr, arg, param)
+auich_trigger_input(v, start, end, blksize, intr, arg, param)
void *v;
void *start, *end;
int blksize;
@@ -1033,17 +1033,17 @@ ich_trigger_input(v, start, end, blksize, intr, arg, param)
void *arg;
struct audio_params *param;
{
- struct ich_softc *sc = v;
- struct ich_dmalist *q;
+ struct auich_softc *sc = v;
+ struct auich_dmalist *q;
- DPRINTF(ICH_DEBUG_DMA,
- ("ich_trigger_input(%x, %x, %d, %p, %p, %p)\n",
+ DPRINTF(AUICH_DEBUG_DMA,
+ ("auich_trigger_input(%x, %x, %d, %p, %p, %p)\n",
kvtop((caddr_t)start), kvtop((caddr_t)end),
blksize, intr, arg, param));
#ifdef DIAGNOSTIC
{
- struct ich_dma *p;
+ struct auich_dma *p;
for (p = sc->sc_dmas; p && p->addr != start; p = p->next);
if (!p)
return -1;
@@ -1064,17 +1064,17 @@ ich_trigger_input(v, start, end, blksize, intr, arg, param)
q = sc->dmap_pcmi = sc->dmalist_pcmi;
q->base = sc->pcmi_start;
- q->len = (blksize / 2) | ICH_DMAF_IOC;
- if (++q == &sc->dmalist_pcmi[ICH_DMALIST_MAX])
+ q->len = (blksize / 2) | AUICH_DMAF_IOC;
+ if (++q == &sc->dmalist_pcmi[AUICH_DMALIST_MAX])
q = sc->dmalist_pcmi;
sc->dmap_pcmi = q;
- bus_space_write_4(sc->iot, sc->aud_ioh, ICH_PCMI + ICH_BDBAR,
+ bus_space_write_4(sc->iot, sc->aud_ioh, AUICH_PCMI + AUICH_BDBAR,
kvtop((caddr_t)sc->dmalist_pcmi));
- bus_space_write_1(sc->iot, sc->aud_ioh, ICH_PCMI + ICH_CTRL,
- ICH_IOCE | ICH_FEIE | ICH_LVBIE | ICH_RPBM);
- bus_space_write_1(sc->iot, sc->aud_ioh, ICH_PCMI + ICH_LVI,
- (sc->dmap_pcmi - 1 - sc->dmalist_pcmi) & ICH_LVI_MASK);
+ bus_space_write_1(sc->iot, sc->aud_ioh, AUICH_PCMI + AUICH_CTRL,
+ AUICH_IOCE | AUICH_FEIE | AUICH_LVBIE | AUICH_RPBM);
+ bus_space_write_1(sc->iot, sc->aud_ioh, AUICH_PCMI + AUICH_LVI,
+ (sc->dmap_pcmi - 1 - sc->dmalist_pcmi) & AUICH_LVI_MASK);
return 0;
}