diff options
Diffstat (limited to 'linux/drivers/media/video')
-rw-r--r-- | linux/drivers/media/video/cx88/cx88-alsa.c | 128 |
1 files changed, 67 insertions, 61 deletions
diff --git a/linux/drivers/media/video/cx88/cx88-alsa.c b/linux/drivers/media/video/cx88/cx88-alsa.c index b9f248c48..6e7a1d5e4 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.14 2005/12/13 04:01:49 rmcc Exp $ + * $Id: cx88-alsa.c,v 1.15 2005/12/13 22:14:01 mchehab Exp $ * * Support for audio capture * PCI function #1 of the cx2388x. @@ -64,6 +64,7 @@ enum { DEVICE_DIGITAL, DEVICE_ANALOG }; /* These can be replaced after done */ #define MIXER_ADDR_LAST MAX_CX88_INPUT + struct cx88_audio_dev { struct cx88_core *core; struct cx88_buffer *buf; @@ -96,12 +97,19 @@ struct cx88_audio_dev { }; typedef struct cx88_audio_dev snd_cx88_card_t; +struct cx8801_fh { + struct cx88_audio_dev *dev; + struct videobuf_queue vb_q; + + int size; +}; + typedef struct snd_card_cx88_pcm { - struct cx88_dev *dev; + struct cx88_dev *dev; - spinlock_t lock; + spinlock_t lock; - snd_pcm_substream_t *substream; + snd_pcm_substream_t *substream; } snd_card_cx88_pcm_t; @@ -279,27 +287,27 @@ static irqreturn_t cx8801_irq(int irq, void *dev_id, struct pt_regs *regs) u32 status; int loop, handled = 0; - for (loop = 0; loop < MAX_IRQ_LOOP; loop++) { - status = cx_read(MO_PCI_INTSTAT) & (core->pci_irqmask | 0x02); - if (0 == status) - goto out; - dprintk( 1, "cx8801_irq\n" ); - dprintk( 1, " loop: %d/%d\n", loop, MAX_IRQ_LOOP ); - dprintk( 1, " status: %d\n", status ); - handled = 1; - cx_write(MO_PCI_INTSTAT, status); - - if (status & core->pci_irqmask) - { - dprintk( 1, " passing to core\n" ); - cx88_core_irq(core,status); + for (loop = 0; loop < MAX_IRQ_LOOP; loop++) { + status = cx_read(MO_PCI_INTSTAT) & (core->pci_irqmask | 0x02); + if (0 == status) + goto out; + dprintk( 1, "cx8801_irq\n" ); + dprintk( 1, " loop: %d/%d\n", loop, MAX_IRQ_LOOP ); + dprintk( 1, " status: %d\n", status ); + handled = 1; + cx_write(MO_PCI_INTSTAT, status); + + if (status & core->pci_irqmask) + { + dprintk( 1, " passing to core\n" ); + cx88_core_irq(core,status); } - if (status & 0x02) + if (status & 0x02) { - dprintk( 1, " ALSA IRQ handling\n" ); - cx8801_aud_irq(chip); + dprintk( 1, " ALSA IRQ handling\n" ); + cx8801_aud_irq(chip); } - }; + }; if (MAX_IRQ_LOOP == loop) { dprintk( 0, "clearing mask\n" ); @@ -348,18 +356,20 @@ static void snd_cx88_pci_error(bt87x_t *chip, unsigned int status) /**************************************************************************** Videobuf setup code ****************************************************************************/ -#if 0 static int buffer_setup(struct videobuf_queue *q, unsigned int *count, unsigned int *size) { - struct cx8800_fh *fh = q->priv_data; + struct cx8801_fh *fh = q->priv_data; - *size = fh->fmt->depth*fh->width*fh->height >> 3; + *size = fh->size; if (0 == *count) *count = 32; - while (*size * *count > vid_limit * 1024 * 1024) - (*count)--; + + if (*count < 2) + *count = 2; + if (*count > 32) + *count = 32; return 0; } @@ -367,28 +377,24 @@ static int buffer_prepare(struct videobuf_queue *q, struct videobuf_buffer *vb, enum v4l2_field field) { - struct cx8800_fh *fh = q->priv_data; - struct cx8800_dev *dev = fh->dev; - struct cx88_core *core = dev->core; + struct cx8801_fh *fh = q->priv_data; + struct cx88_audio_dev *chip = fh->dev; struct cx88_buffer *buf = container_of(vb,struct cx88_buffer,vb); - int rc, init_buffer = 0; - unsigned int size; - - BUG_ON(NULL == fh->fmt); - size = VBI_LINE_COUNT * VBI_LINE_LENGTH * 2; + int rc; + unsigned int size=fh->size; if (0 != buf->vb.baddr && buf->vb.bsize < size) return -EINVAL; if (STATE_NEEDS_INIT == buf->vb.state) { - buf->vb.width = VBI_LINE_LENGTH; - buf->vb.height = VBI_LINE_COUNT; + buf->vb.width = size; + buf->vb.height = 1; buf->vb.size = size; buf->vb.field = V4L2_FIELD_SEQ_TB; - if (0 != (rc = videobuf_iolock(dev->pci,&buf->vb,NULL))) + if (0 != (rc = videobuf_iolock(chip->pci,&buf->vb,NULL))) goto fail; - cx88_risc_buffer(dev->pci, &buf->risc, + cx88_risc_buffer(chip->pci, &buf->risc, buf->vb.dma.sglist, 0, buf->vb.width * buf->vb.height, buf->vb.width, 0, @@ -396,15 +402,15 @@ buffer_prepare(struct videobuf_queue *q, struct videobuf_buffer *vb, } buf->vb.state = STATE_PREPARED; - dprintk_core(2,"[%p/%d] buffer_prepare - %dx%d %dbpp \"%s\" - dma=0x%08lx\n", + dprintk_core(2,"[%p/%d] buffer_prepare - size: %d - dma=0x%08lx\n", buf, buf->vb.i, - fh->width, fh->height, fh->fmt->depth, fh->fmt->name, + fh->size, (unsigned long)buf->risc.dma); return 0; fail: - cx88_free_buffer(dev->pci,buf); + cx88_free_buffer(chip->pci,buf); return rc; } @@ -413,10 +419,10 @@ buffer_queue(struct videobuf_queue *vq, struct videobuf_buffer *vb) { struct cx88_buffer *buf = container_of(vb,struct cx88_buffer,vb); struct cx88_buffer *prev; - struct cx8800_fh *fh = vq->priv_data; - struct cx8800_dev *dev = fh->dev; - struct cx88_core *core = dev->core; - struct cx88_dmaqueue *q = &dev->vidq; + struct cx8801_fh *fh = vq->priv_data; + struct cx88_audio_dev *chip = fh->dev; + struct cx88_core *core = chip->core; + struct cx88_dmaqueue *q = &chip->q; /* add jump to stopper */ buf->risc.jmp[0] = cpu_to_le32(RISC_JUMP | RISC_IRQ1 | RISC_CNT_INC); @@ -430,7 +436,7 @@ buffer_queue(struct videobuf_queue *vq, struct videobuf_buffer *vb) } else if (list_empty(&q->active)) { list_add_tail(&buf->vb.queue,&q->active); - start_video_dma(dev, q, buf); + start_video_dma(chip, q, buf); buf->vb.state = STATE_ACTIVE; buf->count = q->count++; mod_timer(&q->timeout, jiffies+BUFFER_TIMEOUT); @@ -461,18 +467,18 @@ buffer_queue(struct videobuf_queue *vq, struct videobuf_buffer *vb) static void buffer_release(struct videobuf_queue *q, struct videobuf_buffer *vb) { struct cx88_buffer *buf = container_of(vb,struct cx88_buffer,vb); - struct cx8800_fh *fh = q->priv_data; + struct cx8801_fh *fh = q->priv_data; cx88_free_buffer(fh->dev->pci,buf); } -static struct videobuf_queue_ops cx8800_video_qops = { +static struct videobuf_queue_ops audio_qops = { .buf_setup = buffer_setup, .buf_prepare = buffer_prepare, .buf_queue = buffer_queue, .buf_release = buffer_release, }; - +#if 0 static int dsp_buffer_init(snd_cx88_card_t *chip) { int err; @@ -487,7 +493,7 @@ static int dsp_buffer_init(snd_cx88_card_t *chip) file->private_data = fh; fh->dev = dev; - videobuf_queue_init(&fh->mpegq, &blackbird_qops, + videobuf_queue_init(&fh->mpegq, &audio_qops, dev->pci, &dev->slock, V4L2_BUF_TYPE_VIDEO_CAPTURE, V4L2_FIELD_INTERLACED, @@ -904,12 +910,12 @@ static int __devinit snd_cx88_create(snd_card_t *card, struct pci_dev *pci, spin_lock_init(&chip->reg_lock); #if 0 - if (!request_mem_region(pci_resource_start(pci,0), - pci_resource_len(pci,0), - "CX88 audio")) { - err = -EBUSY; - printk(KERN_ERR "%s: can't get MMIO memory @ 0x%lx\n", - "CX88 audio",pci_resource_start(pci,0)); + if (!request_mem_region(pci_resource_start(pci,0), + pci_resource_len(pci,0), + "CX88 audio")) { + err = -EBUSY; + printk(KERN_ERR "%s: can't get MMIO memory @ 0x%lx\n", + "CX88 audio",pci_resource_start(pci,0)); kfree(chip); pci_disable_device(pci); return err; @@ -1089,13 +1095,13 @@ static int cx88_audio_init(void) */ static void cx88_audio_fini(void) { - int idx; + int idx; /* printk(KERN_INFO "cx88 fini\n"); - for (idx = 0; idx < SNDRV_CARDS; idx++) { - snd_card_free(snd_cx88_cards[idx]); + for (idx = 0; idx < SNDRV_CARDS; idx++) { + snd_card_free(snd_cx88_cards[idx]); snd_cx88_cards[idx] = NULL; - }*/ + }*/ pci_unregister_driver(&cx88_audio_pci_driver); } |