diff options
Diffstat (limited to 'linux/drivers/media')
-rw-r--r-- | linux/drivers/media/video/cx88/cx88-alsa.c | 79 |
1 files changed, 31 insertions, 48 deletions
diff --git a/linux/drivers/media/video/cx88/cx88-alsa.c b/linux/drivers/media/video/cx88/cx88-alsa.c index 21f915754..ecc289433 100644 --- a/linux/drivers/media/video/cx88/cx88-alsa.c +++ b/linux/drivers/media/video/cx88/cx88-alsa.c @@ -1,5 +1,5 @@ /* - * $Id: cx88-alsa.c,v 1.12 2005/12/10 03:41:57 mchehab Exp $ + * $Id: cx88-alsa.c,v 1.13 2005/12/10 11:15:54 mchehab Exp $ * * Support for audio capture * PCI function #1 of the cx2388x. @@ -141,18 +141,22 @@ int _cx88_start_audio_dma(snd_cx88_card_t *chip) struct cx88_core *core=chip->core; /* setup fifo + format - out channel */ - cx88_sram_channel_setup(core, &cx88_sram_channels[SRAM_CH26], + cx88_sram_channel_setup(core, &cx88_sram_channels[SRAM_CH25], chip->buf->bpl, chip->buf->risc.dma); - /* FIXME reset counter */ - cx_write(MO_VIDY_GPCNTRL,GP_COUNT_CONTROL_RESET); + /* sets bpl size */ + cx_write(MO_AUDD_LNGTH, chip->buf->bpl); + + /* reset counter */ + cx_write(MO_AUDD_GPCNTRL,GP_COUNT_CONTROL_RESET); /* enable irqs */ cx_set(MO_PCI_INTMSK, chip->core->pci_irqmask | 0x02); /* Enables corresponding bits at AUD_INT_STAT */ -#if 1 - cx_set(MO_AUD_INTMSK, (1<<21)||(1<<19)); +#if 1 /*keep*/ + /* Maybe necessary to enable other errors */ + cx_set(MO_AUD_INTMSK, (1<<21)||(1<<19)||(1<<16)||1); #endif /* start dma */ @@ -173,7 +177,6 @@ int _cx88_stop_audio_dma(snd_cx88_card_t *chip) /* disable irqs */ cx_clear(MO_PCI_INTMSK, 0x000002); - cx_set(MO_AUD_INTMSK, 0); return 0; } @@ -194,23 +197,25 @@ static void cx8801_timeout(unsigned long data) #endif } -/* FIXME: Wrong values*/ static char *cx88_aud_irqs[32] = { - "y_risci1", "u_risci1", "v_risci1", "vbi_risc1", - "y_risci2", "u_risci2", "v_risci2", "vbi_risc2", - "y_oflow", "u_oflow", "v_oflow", "vbi_oflow", - "y_sync", "u_sync", "v_sync", "vbi_sync", - "opc_err", "par_err", "rip_err", "pci_abort", + "dn_risci1", "up_risci1", "rds_dn_risc1", /* 0-2 */ + "", /* reserved */ + "dn_risci2", "up_risci2", "rds_dn_risc2", /* 4-6 */ + "", /* reserved */ + "dnf_of", "upf_uf", "rds_dnf_uf", /* 8-10 */ + "", /* reserved */ + "dn_sync", "up_sync", "rds_dn_sync", /* 12-14 */ + "", /* reserved */ + "opc_err", "par_err", "rip_err", /* 16-18 */ + "pci_abort", "ber_irq", "mchg_irq" /* 19-21 */ }; - static void cx8801_aud_irq(snd_cx88_card_t *chip) { struct cx88_core *core = chip->core; u32 status, mask; -#if 0 u32 count; -#endif + status = cx_read(MO_AUD_INTSTAT); mask = cx_read(MO_AUD_INTMSK); if (0 == (status & mask)) @@ -219,47 +224,25 @@ static void cx8801_aud_irq(snd_cx88_card_t *chip) if (debug || (status & mask & ~0xff)) cx88_print_irqbits(core->name, "irq aud", cx88_aud_irqs, status, mask); -#if 0 /* FIXME */ /* risc op code error */ if (status & (1 << 16)) { printk(KERN_WARNING "%s/0: video risc op code error\n",core->name); - cx_clear(MO_VID_DMACNTRL, 0x11); + cx_clear(MO_AUD_DMACNTRL, 0x11); +#if 0 /* FIXME: anything else? */ cx_clear(VID_CAPTURE_CONTROL, 0x06); - cx88_sram_channel_dump(dev->core, &cx88_sram_channels[SRAM_CH21]); +#endif + cx88_sram_channel_dump(core, &cx88_sram_channels[SRAM_CH21]); } - /* risc1 y */ + /* risc1 downstream */ if (status & 0x01) { - spin_lock(&dev->slock); - count = cx_read(MO_VIDY_GPCNT); - cx88_wakeup(dev->core, &dev->vidq, count); - spin_unlock(&dev->slock); - } - - /* risc1 vbi */ - if (status & 0x08) { - spin_lock(&dev->slock); - count = cx_read(MO_VBI_GPCNT); - cx88_wakeup(dev->core, &dev->vbiq, count); - spin_unlock(&dev->slock); + spin_lock_irq(&chip->reg_lock); + count = cx_read(MO_AUDD_GPCNT); + cx88_wakeup(core, &chip->q, count); + spin_unlock_irq(&chip->reg_lock); } - /* risc2 y */ - if (status & 0x10) { - dprintk(2,"stopper video\n"); - spin_lock(&dev->slock); - restart_video_queue(dev,&dev->vidq); - spin_unlock(&dev->slock); - } - - /* risc2 vbi */ - if (status & 0x80) { - dprintk(2,"stopper vbi\n"); - spin_lock(&dev->slock); - cx8800_restart_vbi_queue(dev,&dev->vbiq); - spin_unlock(&dev->slock); - } -#endif + /* FIXME: Any other status should deserve a special handling? */ } static irqreturn_t cx8801_irq(int irq, void *dev_id, struct pt_regs *regs) |