summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/pci/auvia.c103
1 files changed, 46 insertions, 57 deletions
diff --git a/sys/dev/pci/auvia.c b/sys/dev/pci/auvia.c
index de0afe759a6..ce7a55a2014 100644
--- a/sys/dev/pci/auvia.c
+++ b/sys/dev/pci/auvia.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: auvia.c,v 1.18 2002/05/31 20:28:38 mickey Exp $ */
+/* $OpenBSD: auvia.c,v 1.19 2002/06/02 05:03:18 mickey Exp $ */
/* $NetBSD: auvia.c,v 1.7 2000/11/15 21:06:33 jdolecek Exp $ */
/*-
@@ -153,14 +153,14 @@ struct cfattach auvia_ca = {
#define AUVIA_RPMODE_AUTOSTART 0x80
#define AUVIA_RP_DMAOPS_BASE 0x04
-#define VIA8233_RP_DXS_LVOL 0x02
-#define VIA8233_RP_DXS_RVOL 0x03
-#define VIA8233_RP_RATEFMT 0x08
+#define VIA8233_RP_DXS_LVOL 0x02
+#define VIA8233_RP_DXS_RVOL 0x03
+#define VIA8233_RP_RATEFMT 0x08
#define VIA8233_RATEFMT_48K 0xfffff
#define VIA8233_RATEFMT_STEREO 0x00100000
#define VIA8233_RATEFMT_16BIT 0x00200000
-#define VIA_RP_DMAOPS_COUNT 0x0C
+#define VIA_RP_DMAOPS_COUNT 0x0C
#define AUVIA_CODEC_CTL 0x80
#define AUVIA_CODEC_READ 0x00800000
@@ -215,7 +215,7 @@ auvia_match(struct device *parent, void *match, void *aux)
if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_VIATECH)
return 0;
- switch(PCI_PRODUCT(pa->pa_id)) {
+ switch(PCI_PRODUCT(pa->pa_id)) {
case PCI_PRODUCT_VIATECH_VT82C686A_AC97:
return 1;
case PCI_PRODUCT_VIATECH_VT8233_AC97:
@@ -279,8 +279,8 @@ auvia_attach(struct device *parent, struct device *self, void *aux)
pr &= ~AUVIA_PCICONF_ENABLES; /* clear compat function enables */
/* XXX what to do about MIDI, FM, joystick? */
- pr |= (AUVIA_PCICONF_ACLINKENAB | AUVIA_PCICONF_ACNOTRST
- | AUVIA_PCICONF_ACVSR | AUVIA_PCICONF_ACSGD);
+ pr |= (AUVIA_PCICONF_ACLINKENAB | AUVIA_PCICONF_ACNOTRST |
+ AUVIA_PCICONF_ACVSR | AUVIA_PCICONF_ACSGD);
pr &= ~(AUVIA_PCICONF_ACFM | AUVIA_PCICONF_ACSB);
@@ -294,7 +294,7 @@ auvia_attach(struct device *parent, struct device *self, void *aux)
if ((r = ac97_attach(&sc->host_if)) != 0) {
printf("%s: can't attach codec (error 0x%X)\n",
- sc->sc_dev.dv_xname, r);
+ sc->sc_dev.dv_xname, r);
pci_intr_disestablish(pc, sc->sc_ih);
bus_space_unmap(sc->sc_iot, sc->sc_ioh, iosize);
return;
@@ -315,7 +315,7 @@ auvia_attach(struct device *parent, struct device *self, void *aux)
ctl.un.ord = 0;
ctl.dev = sc->codec_if->vtbl->get_portnum_by_name(sc->codec_if,
- d[i].class, d[i].device, AudioNmute);
+ d[i].class, d[i].device, AudioNmute);
auvia_set_port(sc, &ctl);
}
@@ -327,7 +327,7 @@ auvia_attach(struct device *parent, struct device *self, void *aux)
ctl.un.value.level[AUDIO_MIXER_LEVEL_RIGHT] = 199;
ctl.dev = sc->codec_if->vtbl->get_portnum_by_name(sc->codec_if,
- AudioCoutputs, AudioNmaster, NULL);
+ AudioCoutputs, AudioNmaster, NULL);
auvia_set_port(sc, &ctl);
audio_attach_mi(&auvia_hw_if, sc, &sc->sc_dev);
@@ -360,7 +360,7 @@ auvia_reset_codec(void *addr)
pci_conf_write(sc->sc_pc, sc->sc_pt, AUVIA_PCICONF_JUNK, r);
delay(2);
- r |= AUVIA_PCICONF_ACNOTRST; /* disable RESET (inactive high) */
+ r |= AUVIA_PCICONF_ACNOTRST; /* disable RESET (inactive high) */
pci_conf_write(sc->sc_pc, sc->sc_pt, AUVIA_PCICONF_JUNK, r);
delay(200);
@@ -376,8 +376,9 @@ auvia_waitready_codec(struct auvia_softc *sc)
/* poll until codec not busy */
for (i = 0; (i < TIMEOUT) && (bus_space_read_4(sc->sc_iot, sc->sc_ioh,
- AUVIA_CODEC_CTL) & AUVIA_CODEC_BUSY); i++)
+ AUVIA_CODEC_CTL) & AUVIA_CODEC_BUSY); i++)
delay(1);
+
if (i >= TIMEOUT) {
printf("%s: codec busy\n", sc->sc_dev.dv_xname);
return 1;
@@ -394,8 +395,9 @@ auvia_waitvalid_codec(struct auvia_softc *sc)
/* poll until codec valid */
for (i = 0; (i < TIMEOUT) && !(bus_space_read_4(sc->sc_iot, sc->sc_ioh,
- AUVIA_CODEC_CTL) & AUVIA_CODEC_PRIVALID); i++)
- delay(1);
+ AUVIA_CODEC_CTL) & AUVIA_CODEC_PRIVALID); i++)
+ delay(1);
+
if (i >= TIMEOUT) {
printf("%s: codec invalid\n", sc->sc_dev.dv_xname);
return 1;
@@ -414,7 +416,7 @@ auvia_write_codec(void *addr, u_int8_t reg, u_int16_t val)
return 1;
bus_space_write_4(sc->sc_iot, sc->sc_ioh, AUVIA_CODEC_CTL,
- AUVIA_CODEC_PRIVALID | AUVIA_CODEC_INDEX(reg) | val);
+ AUVIA_CODEC_PRIVALID | AUVIA_CODEC_INDEX(reg) | val);
return 0;
}
@@ -429,7 +431,7 @@ auvia_read_codec(void *addr, u_int8_t reg, u_int16_t *val)
return 1;
bus_space_write_4(sc->sc_iot, sc->sc_ioh, AUVIA_CODEC_CTL,
- AUVIA_CODEC_PRIVALID | AUVIA_CODEC_READ | AUVIA_CODEC_INDEX(reg));
+ AUVIA_CODEC_PRIVALID | AUVIA_CODEC_READ | AUVIA_CODEC_INDEX(reg));
if (auvia_waitready_codec(sc))
return 1;
@@ -523,7 +525,7 @@ auvia_query_encoding(void *addr, struct audio_encoding *fp)
int
auvia_set_params(void *addr, int setmode, int usemode,
- struct audio_params *play, struct audio_params *rec)
+ struct audio_params *play, struct audio_params *rec)
{
struct auvia_softc *sc = addr;
struct audio_params *p;
@@ -582,12 +584,10 @@ auvia_set_params(void *addr, int setmode, int usemode,
p->sw_code = change_sign8;
break;
case AUDIO_ENCODING_ULINEAR_BE:
- if (p->precision == 16) {
- if (mode == AUMODE_PLAY)
- p->sw_code = swap_bytes_change_sign16_le;
- else
- p->sw_code = change_sign16_swap_bytes_le;
- }
+ if (p->precision == 16)
+ p->sw_code = mode == AUMODE_PLAY?
+ swap_bytes_change_sign16_le :
+ change_sign16_swap_bytes_le;
break;
case AUDIO_ENCODING_ULINEAR_LE:
if (p->precision == 16)
@@ -617,11 +617,10 @@ auvia_set_params(void *addr, int setmode, int usemode,
| AUVIA_RPMODE_INTR_FLAG | AUVIA_RPMODE_INTR_EOL
| AUVIA_RPMODE_AUTOSTART;
- if (mode == AUMODE_PLAY) {
+ if (mode == AUMODE_PLAY)
sc->sc_play.sc_reg = regval;
- } else {
+ else
sc->sc_record.sc_reg = regval;
- }
}
return 0;
@@ -814,14 +813,14 @@ auvia_mappage(void *addr, void *mem, off_t off, int prot)
int
auvia_get_props(void *addr)
{
- return AUDIO_PROP_MMAP | AUDIO_PROP_INDEPENDENT
- | AUDIO_PROP_FULLDUPLEX;
+ return (AUDIO_PROP_MMAP | AUDIO_PROP_INDEPENDENT |
+ AUDIO_PROP_FULLDUPLEX);
}
int
auvia_build_dma_ops(struct auvia_softc *sc, struct auvia_softc_chan *ch,
- struct auvia_dma *p, void *start, void *end, int blksize)
+ struct auvia_dma *p, void *start, void *end, int blksize)
{
struct auvia_dma_op *op;
struct auvia_dma *dp;
@@ -836,22 +835,20 @@ auvia_build_dma_ops(struct auvia_softc *sc, struct auvia_softc_chan *ch,
if (segs > (ch->sc_dma_op_count)) {
/* if old list was too small, free it */
- if (ch->sc_dma_ops) {
+ if (ch->sc_dma_ops)
auvia_free(sc, ch->sc_dma_ops, M_DEVBUF);
- }
ch->sc_dma_ops = auvia_malloc(sc, 0,
- sizeof(struct auvia_dma_op) * segs, M_DEVBUF, M_WAITOK);
+ sizeof(struct auvia_dma_op) * segs, M_DEVBUF, M_WAITOK);
- for (dp = sc->sc_dmas;
- dp && dp->addr != (void *)(ch->sc_dma_ops);
- dp = dp->next)
- ;
+ for (dp = sc->sc_dmas; dp &&
+ dp->addr != (void *)(ch->sc_dma_ops); dp = dp->next)
+ ;
if (!dp)
panic("%s: build_dma_ops: where'd my memory go??? "
- "address (%p)\n", sc->sc_dev.dv_xname,
- ch->sc_dma_ops);
+ "address (%p)", sc->sc_dev.dv_xname,
+ ch->sc_dma_ops);
ch->sc_dma_op_count = segs;
ch->sc_dma_ops_dma = dp;
@@ -863,12 +860,8 @@ auvia_build_dma_ops(struct auvia_softc *sc, struct auvia_softc_chan *ch,
while (l) {
op->ptr = s;
l = l - blksize;
- if (!l) {
- /* if last block */
- op->flags = AUVIA_DMAOP_EOL | blksize;
- } else {
- op->flags = AUVIA_DMAOP_FLAG | blksize;
- }
+ /* if last block */
+ op->flags = (l? AUVIA_DMAOP_FLAG : AUVIA_DMAOP_EOL) | blksize;
s += blksize;
op++;
}
@@ -878,9 +871,8 @@ auvia_build_dma_ops(struct auvia_softc *sc, struct auvia_softc_chan *ch,
int
-auvia_trigger_output(void *addr, void *start, void *end,
- int blksize, void (*intr)(void *), void *arg,
- struct audio_params *param)
+auvia_trigger_output(void *addr, void *start, void *end, int blksize,
+ void (*intr)(void *), void *arg, struct audio_params *param)
{
struct auvia_softc *sc = addr;
struct auvia_softc_chan *ch = &(sc->sc_play);
@@ -891,7 +883,7 @@ auvia_trigger_output(void *addr, void *start, void *end,
if (!p)
panic("auvia_trigger_output: request with bad start "
- "address (%p)\n", start);
+ "address (%p)", start);
if (auvia_build_dma_ops(sc, ch, p, start, end, blksize)) {
return 1;
@@ -925,9 +917,8 @@ auvia_trigger_output(void *addr, void *start, void *end,
int
-auvia_trigger_input(void *addr, void *start, void *end,
- int blksize, void (*intr)(void *), void *arg,
- struct audio_params *param)
+auvia_trigger_input(void *addr, void *start, void *end, int blksize,
+ void (*intr)(void *), void *arg, struct audio_params *param)
{
struct auvia_softc *sc = addr;
struct auvia_softc_chan *ch = &(sc->sc_record);
@@ -938,11 +929,10 @@ auvia_trigger_input(void *addr, void *start, void *end,
if (!p)
panic("auvia_trigger_input: request with bad start "
- "address (%p)\n", start);
+ "address (%p)", start);
- if (auvia_build_dma_ops(sc, ch, p, start, end, blksize)) {
+ if (auvia_build_dma_ops(sc, ch, p, start, end, blksize))
return 1;
- }
ch->sc_intr = intr;
ch->sc_arg = arg;
@@ -951,8 +941,7 @@ auvia_trigger_input(void *addr, void *start, void *end,
AUVIA_RECORD_BASE + AUVIA_RP_DMAOPS_BASE,
ch->sc_dma_ops_dma->map->dm_segs[0].ds_addr);
bus_space_write_1(sc->sc_iot, sc->sc_ioh,
- AUVIA_RECORD_BASE + AUVIA_RP_MODE,
- ch->sc_reg);
+ AUVIA_RECORD_BASE + AUVIA_RP_MODE, ch->sc_reg);
if (sc->sc_flags & AUVIA_FLAGS_VT8233) {
bus_space_write_1(sc->sc_iot, sc->sc_ioh,