xref: /openbmc/linux/drivers/media/pci/saa7134/saa7134-alsa.c (revision 4ed91d48259d9ddd378424d008f2e6559f7e78f8)
1 /*
2  *   SAA713x ALSA support for V4L
3  *
4  *   This program is free software; you can redistribute it and/or modify
5  *   it under the terms of the GNU General Public License as published by
6  *   the Free Software Foundation, version 2
7  *
8  *   This program is distributed in the hope that it will be useful,
9  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
10  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11  *   GNU General Public License for more details.
12  *
13  */
14 
15 #include "saa7134.h"
16 #include "saa7134-reg.h"
17 
18 #include <linux/init.h>
19 #include <linux/slab.h>
20 #include <linux/time.h>
21 #include <linux/wait.h>
22 #include <linux/module.h>
23 #include <sound/core.h>
24 #include <sound/control.h>
25 #include <sound/pcm.h>
26 #include <sound/pcm_params.h>
27 #include <sound/initval.h>
28 #include <linux/interrupt.h>
29 #include <linux/vmalloc.h>
30 
31 /*
32  * Configuration macros
33  */
34 
35 /* defaults */
36 #define MIXER_ADDR_UNSELECTED	-1
37 #define MIXER_ADDR_TVTUNER	0
38 #define MIXER_ADDR_LINE1	1
39 #define MIXER_ADDR_LINE2	2
40 #define MIXER_ADDR_LAST		2
41 
42 
43 static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX;	/* Index 0-MAX */
44 static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR;	/* ID for this card */
45 static int enable[SNDRV_CARDS] = {1, [1 ... (SNDRV_CARDS - 1)] = 1};
46 
47 module_param_array(index, int, NULL, 0444);
48 module_param_array(enable, int, NULL, 0444);
49 MODULE_PARM_DESC(index, "Index value for SAA7134 capture interface(s).");
50 MODULE_PARM_DESC(enable, "Enable (or not) the SAA7134 capture interface(s).");
51 
52 /*
53  * Main chip structure
54  */
55 
56 typedef struct snd_card_saa7134 {
57 	struct snd_card *card;
58 	spinlock_t mixer_lock;
59 	int mixer_volume[MIXER_ADDR_LAST+1][2];
60 	int capture_source_addr;
61 	int capture_source[2];
62 	struct snd_kcontrol *capture_ctl[MIXER_ADDR_LAST+1];
63 	struct pci_dev *pci;
64 	struct saa7134_dev *dev;
65 
66 	unsigned long iobase;
67 	s16 irq;
68 	u16 mute_was_on;
69 
70 	spinlock_t lock;
71 } snd_card_saa7134_t;
72 
73 
74 /*
75  * PCM structure
76  */
77 
78 typedef struct snd_card_saa7134_pcm {
79 	struct saa7134_dev *dev;
80 
81 	spinlock_t lock;
82 
83 	struct snd_pcm_substream *substream;
84 } snd_card_saa7134_pcm_t;
85 
86 static struct snd_card *snd_saa7134_cards[SNDRV_CARDS];
87 
88 
89 /*
90  * saa7134 DMA audio stop
91  *
92  *   Called when the capture device is released or the buffer overflows
93  *
94  *   - Copied verbatim from saa7134-oss's dsp_dma_stop.
95  *
96  */
97 
98 static void saa7134_dma_stop(struct saa7134_dev *dev)
99 {
100 	dev->dmasound.dma_blk     = -1;
101 	dev->dmasound.dma_running = 0;
102 	saa7134_set_dmabits(dev);
103 }
104 
105 /*
106  * saa7134 DMA audio start
107  *
108  *   Called when preparing the capture device for use
109  *
110  *   - Copied verbatim from saa7134-oss's dsp_dma_start.
111  *
112  */
113 
114 static void saa7134_dma_start(struct saa7134_dev *dev)
115 {
116 	dev->dmasound.dma_blk     = 0;
117 	dev->dmasound.dma_running = 1;
118 	saa7134_set_dmabits(dev);
119 }
120 
121 /*
122  * saa7134 audio DMA IRQ handler
123  *
124  *   Called whenever we get an SAA7134_IRQ_REPORT_DONE_RA3 interrupt
125  *   Handles shifting between the 2 buffers, manages the read counters,
126  *  and notifies ALSA when periods elapse
127  *
128  *   - Mostly copied from saa7134-oss's saa7134_irq_oss_done.
129  *
130  */
131 
132 static void saa7134_irq_alsa_done(struct saa7134_dev *dev,
133 				  unsigned long status)
134 {
135 	int next_blk, reg = 0;
136 
137 	spin_lock(&dev->slock);
138 	if (UNSET == dev->dmasound.dma_blk) {
139 		pr_debug("irq: recording stopped\n");
140 		goto done;
141 	}
142 	if (0 != (status & 0x0f000000))
143 		pr_debug("irq: lost %ld\n", (status >> 24) & 0x0f);
144 	if (0 == (status & 0x10000000)) {
145 		/* odd */
146 		if (0 == (dev->dmasound.dma_blk & 0x01))
147 			reg = SAA7134_RS_BA1(6);
148 	} else {
149 		/* even */
150 		if (1 == (dev->dmasound.dma_blk & 0x01))
151 			reg = SAA7134_RS_BA2(6);
152 	}
153 	if (0 == reg) {
154 		pr_debug("irq: field oops [%s]\n",
155 			(status & 0x10000000) ? "even" : "odd");
156 		goto done;
157 	}
158 
159 	if (dev->dmasound.read_count >= dev->dmasound.blksize * (dev->dmasound.blocks-2)) {
160 		pr_debug("irq: overrun [full=%d/%d] - Blocks in %d\n",
161 			dev->dmasound.read_count,
162 			dev->dmasound.bufsize, dev->dmasound.blocks);
163 		spin_unlock(&dev->slock);
164 		snd_pcm_stop_xrun(dev->dmasound.substream);
165 		return;
166 	}
167 
168 	/* next block addr */
169 	next_blk = (dev->dmasound.dma_blk + 2) % dev->dmasound.blocks;
170 	saa_writel(reg,next_blk * dev->dmasound.blksize);
171 	pr_debug("irq: ok, %s, next_blk=%d, addr=%x, blocks=%u, size=%u, read=%u\n",
172 		(status & 0x10000000) ? "even" : "odd ", next_blk,
173 		 next_blk * dev->dmasound.blksize, dev->dmasound.blocks,
174 		 dev->dmasound.blksize, dev->dmasound.read_count);
175 
176 	/* update status & wake waiting readers */
177 	dev->dmasound.dma_blk = (dev->dmasound.dma_blk + 1) % dev->dmasound.blocks;
178 	dev->dmasound.read_count += dev->dmasound.blksize;
179 
180 	dev->dmasound.recording_on = reg;
181 
182 	if (dev->dmasound.read_count >= snd_pcm_lib_period_bytes(dev->dmasound.substream)) {
183 		spin_unlock(&dev->slock);
184 		snd_pcm_period_elapsed(dev->dmasound.substream);
185 		spin_lock(&dev->slock);
186 	}
187 
188  done:
189 	spin_unlock(&dev->slock);
190 
191 }
192 
193 /*
194  * IRQ request handler
195  *
196  *   Runs along with saa7134's IRQ handler, discards anything that isn't
197  *   DMA sound
198  *
199  */
200 
201 static irqreturn_t saa7134_alsa_irq(int irq, void *dev_id)
202 {
203 	struct saa7134_dmasound *dmasound = dev_id;
204 	struct saa7134_dev *dev = dmasound->priv_data;
205 
206 	unsigned long report, status;
207 	int loop, handled = 0;
208 
209 	for (loop = 0; loop < 10; loop++) {
210 		report = saa_readl(SAA7134_IRQ_REPORT);
211 		status = saa_readl(SAA7134_IRQ_STATUS);
212 
213 		if (report & SAA7134_IRQ_REPORT_DONE_RA3) {
214 			handled = 1;
215 			saa_writel(SAA7134_IRQ_REPORT,
216 				   SAA7134_IRQ_REPORT_DONE_RA3);
217 			saa7134_irq_alsa_done(dev, status);
218 		} else {
219 			goto out;
220 		}
221 	}
222 
223 	if (loop == 10) {
224 		pr_debug("error! looping IRQ!");
225 	}
226 
227 out:
228 	return IRQ_RETVAL(handled);
229 }
230 
231 /*
232  * ALSA capture trigger
233  *
234  *   - One of the ALSA capture callbacks.
235  *
236  *   Called whenever a capture is started or stopped. Must be defined,
237  *   but there's nothing we want to do here
238  *
239  */
240 
241 static int snd_card_saa7134_capture_trigger(struct snd_pcm_substream * substream,
242 					  int cmd)
243 {
244 	struct snd_pcm_runtime *runtime = substream->runtime;
245 	snd_card_saa7134_pcm_t *pcm = runtime->private_data;
246 	struct saa7134_dev *dev=pcm->dev;
247 	int err = 0;
248 
249 	spin_lock(&dev->slock);
250 	if (cmd == SNDRV_PCM_TRIGGER_START) {
251 		/* start dma */
252 		saa7134_dma_start(dev);
253 	} else if (cmd == SNDRV_PCM_TRIGGER_STOP) {
254 		/* stop dma */
255 		saa7134_dma_stop(dev);
256 	} else {
257 		err = -EINVAL;
258 	}
259 	spin_unlock(&dev->slock);
260 
261 	return err;
262 }
263 
264 static int saa7134_alsa_dma_init(struct saa7134_dev *dev, int nr_pages)
265 {
266 	struct saa7134_dmasound *dma = &dev->dmasound;
267 	struct page *pg;
268 	int i;
269 
270 	dma->vaddr = vmalloc_32(nr_pages << PAGE_SHIFT);
271 	if (NULL == dma->vaddr) {
272 		pr_debug("vmalloc_32(%d pages) failed\n", nr_pages);
273 		return -ENOMEM;
274 	}
275 
276 	pr_debug("vmalloc is at addr 0x%08lx, size=%d\n",
277 				(unsigned long)dma->vaddr,
278 				nr_pages << PAGE_SHIFT);
279 
280 	memset(dma->vaddr, 0, nr_pages << PAGE_SHIFT);
281 	dma->nr_pages = nr_pages;
282 
283 	dma->sglist = vzalloc(dma->nr_pages * sizeof(*dma->sglist));
284 	if (NULL == dma->sglist)
285 		goto vzalloc_err;
286 
287 	sg_init_table(dma->sglist, dma->nr_pages);
288 	for (i = 0; i < dma->nr_pages; i++) {
289 		pg = vmalloc_to_page(dma->vaddr + i * PAGE_SIZE);
290 		if (NULL == pg)
291 			goto vmalloc_to_page_err;
292 		sg_set_page(&dma->sglist[i], pg, PAGE_SIZE, 0);
293 	}
294 	return 0;
295 
296 vmalloc_to_page_err:
297 	vfree(dma->sglist);
298 	dma->sglist = NULL;
299 vzalloc_err:
300 	vfree(dma->vaddr);
301 	dma->vaddr = NULL;
302 	return -ENOMEM;
303 }
304 
305 static int saa7134_alsa_dma_map(struct saa7134_dev *dev)
306 {
307 	struct saa7134_dmasound *dma = &dev->dmasound;
308 
309 	dma->sglen = dma_map_sg(&dev->pci->dev, dma->sglist,
310 			dma->nr_pages, PCI_DMA_FROMDEVICE);
311 
312 	if (0 == dma->sglen) {
313 		pr_warn("%s: saa7134_alsa_map_sg failed\n", __func__);
314 		return -ENOMEM;
315 	}
316 	return 0;
317 }
318 
319 static int saa7134_alsa_dma_unmap(struct saa7134_dev *dev)
320 {
321 	struct saa7134_dmasound *dma = &dev->dmasound;
322 
323 	if (!dma->sglen)
324 		return 0;
325 
326 	dma_unmap_sg(&dev->pci->dev, dma->sglist, dma->sglen, PCI_DMA_FROMDEVICE);
327 	dma->sglen = 0;
328 	return 0;
329 }
330 
331 static int saa7134_alsa_dma_free(struct saa7134_dmasound *dma)
332 {
333 	vfree(dma->sglist);
334 	dma->sglist = NULL;
335 	vfree(dma->vaddr);
336 	dma->vaddr = NULL;
337 	return 0;
338 }
339 
340 /*
341  * DMA buffer initialization
342  *
343  *   Uses V4L functions to initialize the DMA. Shouldn't be necessary in
344  *  ALSA, but I was unable to use ALSA's own DMA, and had to force the
345  *  usage of V4L's
346  *
347  *   - Copied verbatim from saa7134-oss.
348  *
349  */
350 
351 static int dsp_buffer_init(struct saa7134_dev *dev)
352 {
353 	int err;
354 
355 	BUG_ON(!dev->dmasound.bufsize);
356 
357 	err = saa7134_alsa_dma_init(dev,
358 			       (dev->dmasound.bufsize + PAGE_SIZE) >> PAGE_SHIFT);
359 	if (0 != err)
360 		return err;
361 	return 0;
362 }
363 
364 /*
365  * DMA buffer release
366  *
367  *   Called after closing the device, during snd_card_saa7134_capture_close
368  *
369  */
370 
371 static int dsp_buffer_free(struct saa7134_dev *dev)
372 {
373 	BUG_ON(!dev->dmasound.blksize);
374 
375 	saa7134_alsa_dma_free(&dev->dmasound);
376 
377 	dev->dmasound.blocks  = 0;
378 	dev->dmasound.blksize = 0;
379 	dev->dmasound.bufsize = 0;
380 
381 	return 0;
382 }
383 
384 /*
385  * Setting the capture source and updating the ALSA controls
386  */
387 static int snd_saa7134_capsrc_set(struct snd_kcontrol *kcontrol,
388 				  int left, int right, bool force_notify)
389 {
390 	snd_card_saa7134_t *chip = snd_kcontrol_chip(kcontrol);
391 	int change = 0, addr = kcontrol->private_value;
392 	int active, old_addr;
393 	u32 anabar, xbarin;
394 	int analog_io, rate;
395 	struct saa7134_dev *dev;
396 
397 	dev = chip->dev;
398 
399 	spin_lock_irq(&chip->mixer_lock);
400 
401 	active = left != 0 || right != 0;
402 	old_addr = chip->capture_source_addr;
403 
404 	/* The active capture source cannot be deactivated */
405 	if (active) {
406 		change = old_addr != addr ||
407 			 chip->capture_source[0] != left ||
408 			 chip->capture_source[1] != right;
409 
410 		chip->capture_source[0] = left;
411 		chip->capture_source[1] = right;
412 		chip->capture_source_addr = addr;
413 		dev->dmasound.input = addr;
414 	}
415 	spin_unlock_irq(&chip->mixer_lock);
416 
417 	if (change) {
418 		switch (dev->pci->device) {
419 
420 		case PCI_DEVICE_ID_PHILIPS_SAA7134:
421 			switch (addr) {
422 			case MIXER_ADDR_TVTUNER:
423 				saa_andorb(SAA7134_AUDIO_FORMAT_CTRL,
424 					   0xc0, 0xc0);
425 				saa_andorb(SAA7134_SIF_SAMPLE_FREQ,
426 					   0x03, 0x00);
427 				break;
428 			case MIXER_ADDR_LINE1:
429 			case MIXER_ADDR_LINE2:
430 				analog_io = (MIXER_ADDR_LINE1 == addr) ?
431 					     0x00 : 0x08;
432 				rate = (32000 == dev->dmasound.rate) ?
433 					0x01 : 0x03;
434 				saa_andorb(SAA7134_ANALOG_IO_SELECT,
435 					   0x08, analog_io);
436 				saa_andorb(SAA7134_AUDIO_FORMAT_CTRL,
437 					   0xc0, 0x80);
438 				saa_andorb(SAA7134_SIF_SAMPLE_FREQ,
439 					   0x03, rate);
440 				break;
441 			}
442 
443 			break;
444 		case PCI_DEVICE_ID_PHILIPS_SAA7133:
445 		case PCI_DEVICE_ID_PHILIPS_SAA7135:
446 			xbarin = 0x03; /* adc */
447 			anabar = 0;
448 			switch (addr) {
449 			case MIXER_ADDR_TVTUNER:
450 				xbarin = 0; /* Demodulator */
451 				anabar = 2; /* DACs */
452 				break;
453 			case MIXER_ADDR_LINE1:
454 				anabar = 0;  /* aux1, aux1 */
455 				break;
456 			case MIXER_ADDR_LINE2:
457 				anabar = 9;  /* aux2, aux2 */
458 				break;
459 			}
460 
461 			/* output xbar always main channel */
462 			saa_dsp_writel(dev, SAA7133_DIGITAL_OUTPUT_SEL1,
463 				       0xbbbb10);
464 
465 			if (left || right) {
466 				/* We've got data, turn the input on */
467 				saa_dsp_writel(dev, SAA7133_DIGITAL_INPUT_XBAR1,
468 					       xbarin);
469 				saa_writel(SAA7133_ANALOG_IO_SELECT, anabar);
470 			} else {
471 				saa_dsp_writel(dev, SAA7133_DIGITAL_INPUT_XBAR1,
472 					       0);
473 				saa_writel(SAA7133_ANALOG_IO_SELECT, 0);
474 			}
475 			break;
476 		}
477 	}
478 
479 	if (change) {
480 		if (force_notify)
481 			snd_ctl_notify(chip->card,
482 				       SNDRV_CTL_EVENT_MASK_VALUE,
483 				       &chip->capture_ctl[addr]->id);
484 
485 		if (old_addr != MIXER_ADDR_UNSELECTED && old_addr != addr)
486 			snd_ctl_notify(chip->card,
487 				       SNDRV_CTL_EVENT_MASK_VALUE,
488 				       &chip->capture_ctl[old_addr]->id);
489 	}
490 
491 	return change;
492 }
493 
494 /*
495  * ALSA PCM preparation
496  *
497  *   - One of the ALSA capture callbacks.
498  *
499  *   Called right after the capture device is opened, this function configures
500  *  the buffer using the previously defined functions, allocates the memory,
501  *  sets up the hardware registers, and then starts the DMA. When this function
502  *  returns, the audio should be flowing.
503  *
504  */
505 
506 static int snd_card_saa7134_capture_prepare(struct snd_pcm_substream * substream)
507 {
508 	struct snd_pcm_runtime *runtime = substream->runtime;
509 	int bswap, sign;
510 	u32 fmt, control;
511 	snd_card_saa7134_t *saa7134 = snd_pcm_substream_chip(substream);
512 	struct saa7134_dev *dev;
513 	snd_card_saa7134_pcm_t *pcm = runtime->private_data;
514 
515 	pcm->dev->dmasound.substream = substream;
516 
517 	dev = saa7134->dev;
518 
519 	if (snd_pcm_format_width(runtime->format) == 8)
520 		fmt = 0x00;
521 	else
522 		fmt = 0x01;
523 
524 	if (snd_pcm_format_signed(runtime->format))
525 		sign = 1;
526 	else
527 		sign = 0;
528 
529 	if (snd_pcm_format_big_endian(runtime->format))
530 		bswap = 1;
531 	else
532 		bswap = 0;
533 
534 	switch (dev->pci->device) {
535 	  case PCI_DEVICE_ID_PHILIPS_SAA7134:
536 		if (1 == runtime->channels)
537 			fmt |= (1 << 3);
538 		if (2 == runtime->channels)
539 			fmt |= (3 << 3);
540 		if (sign)
541 			fmt |= 0x04;
542 
543 		fmt |= (MIXER_ADDR_TVTUNER == dev->dmasound.input) ? 0xc0 : 0x80;
544 		saa_writeb(SAA7134_NUM_SAMPLES0, ((dev->dmasound.blksize - 1) & 0x0000ff));
545 		saa_writeb(SAA7134_NUM_SAMPLES1, ((dev->dmasound.blksize - 1) & 0x00ff00) >>  8);
546 		saa_writeb(SAA7134_NUM_SAMPLES2, ((dev->dmasound.blksize - 1) & 0xff0000) >> 16);
547 		saa_writeb(SAA7134_AUDIO_FORMAT_CTRL, fmt);
548 
549 		break;
550 	  case PCI_DEVICE_ID_PHILIPS_SAA7133:
551 	  case PCI_DEVICE_ID_PHILIPS_SAA7135:
552 		if (1 == runtime->channels)
553 			fmt |= (1 << 4);
554 		if (2 == runtime->channels)
555 			fmt |= (2 << 4);
556 		if (!sign)
557 			fmt |= 0x04;
558 		saa_writel(SAA7133_NUM_SAMPLES, dev->dmasound.blksize -1);
559 		saa_writel(SAA7133_AUDIO_CHANNEL, 0x543210 | (fmt << 24));
560 		break;
561 	}
562 
563 	pr_debug("rec_start: afmt=%d ch=%d  =>  fmt=0x%x swap=%c\n",
564 		runtime->format, runtime->channels, fmt,
565 		bswap ? 'b' : '-');
566 	/* dma: setup channel 6 (= AUDIO) */
567 	control = SAA7134_RS_CONTROL_BURST_16 |
568 		SAA7134_RS_CONTROL_ME |
569 		(dev->dmasound.pt.dma >> 12);
570 	if (bswap)
571 		control |= SAA7134_RS_CONTROL_BSWAP;
572 
573 	saa_writel(SAA7134_RS_BA1(6),0);
574 	saa_writel(SAA7134_RS_BA2(6),dev->dmasound.blksize);
575 	saa_writel(SAA7134_RS_PITCH(6),0);
576 	saa_writel(SAA7134_RS_CONTROL(6),control);
577 
578 	dev->dmasound.rate = runtime->rate;
579 
580 	/* Setup and update the card/ALSA controls */
581 	snd_saa7134_capsrc_set(saa7134->capture_ctl[dev->dmasound.input], 1, 1,
582 			       true);
583 
584 	return 0;
585 
586 }
587 
588 /*
589  * ALSA pointer fetching
590  *
591  *   - One of the ALSA capture callbacks.
592  *
593  *   Called whenever a period elapses, it must return the current hardware
594  *  position of the buffer.
595  *   Also resets the read counter used to prevent overruns
596  *
597  */
598 
599 static snd_pcm_uframes_t
600 snd_card_saa7134_capture_pointer(struct snd_pcm_substream * substream)
601 {
602 	struct snd_pcm_runtime *runtime = substream->runtime;
603 	snd_card_saa7134_pcm_t *pcm = runtime->private_data;
604 	struct saa7134_dev *dev=pcm->dev;
605 
606 	if (dev->dmasound.read_count) {
607 		dev->dmasound.read_count  -= snd_pcm_lib_period_bytes(substream);
608 		dev->dmasound.read_offset += snd_pcm_lib_period_bytes(substream);
609 		if (dev->dmasound.read_offset == dev->dmasound.bufsize)
610 			dev->dmasound.read_offset = 0;
611 	}
612 
613 	return bytes_to_frames(runtime, dev->dmasound.read_offset);
614 }
615 
616 /*
617  * ALSA hardware capabilities definition
618  *
619  *  Report only 32kHz for ALSA:
620  *
621  *  - SAA7133/35 uses DDEP (DemDec Easy Programming mode), which works in 32kHz
622  *    only
623  *  - SAA7134 for TV mode uses DemDec mode (32kHz)
624  *  - Radio works in 32kHz only
625  *  - When recording 48kHz from Line1/Line2, switching of capture source to TV
626  *    means
627  *    switching to 32kHz without any frequency translation
628  */
629 
630 static struct snd_pcm_hardware snd_card_saa7134_capture =
631 {
632 	.info =                 (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED |
633 				 SNDRV_PCM_INFO_BLOCK_TRANSFER |
634 				 SNDRV_PCM_INFO_MMAP_VALID),
635 	.formats =		SNDRV_PCM_FMTBIT_S16_LE | \
636 				SNDRV_PCM_FMTBIT_S16_BE | \
637 				SNDRV_PCM_FMTBIT_S8 | \
638 				SNDRV_PCM_FMTBIT_U8 | \
639 				SNDRV_PCM_FMTBIT_U16_LE | \
640 				SNDRV_PCM_FMTBIT_U16_BE,
641 	.rates =		SNDRV_PCM_RATE_32000,
642 	.rate_min =		32000,
643 	.rate_max =		32000,
644 	.channels_min =		1,
645 	.channels_max =		2,
646 	.buffer_bytes_max =	(256*1024),
647 	.period_bytes_min =	64,
648 	.period_bytes_max =	(256*1024),
649 	.periods_min =		4,
650 	.periods_max =		1024,
651 };
652 
653 static void snd_card_saa7134_runtime_free(struct snd_pcm_runtime *runtime)
654 {
655 	snd_card_saa7134_pcm_t *pcm = runtime->private_data;
656 
657 	kfree(pcm);
658 }
659 
660 
661 /*
662  * ALSA hardware params
663  *
664  *   - One of the ALSA capture callbacks.
665  *
666  *   Called on initialization, right before the PCM preparation
667  *
668  */
669 
670 static int snd_card_saa7134_hw_params(struct snd_pcm_substream * substream,
671 				      struct snd_pcm_hw_params * hw_params)
672 {
673 	snd_card_saa7134_t *saa7134 = snd_pcm_substream_chip(substream);
674 	struct saa7134_dev *dev;
675 	unsigned int period_size, periods;
676 	int err;
677 
678 	period_size = params_period_bytes(hw_params);
679 	periods = params_periods(hw_params);
680 
681 	if (period_size < 0x100 || period_size > 0x10000)
682 		return -EINVAL;
683 	if (periods < 4)
684 		return -EINVAL;
685 	if (period_size * periods > 1024 * 1024)
686 		return -EINVAL;
687 
688 	dev = saa7134->dev;
689 
690 	if (dev->dmasound.blocks == periods &&
691 	    dev->dmasound.blksize == period_size)
692 		return 0;
693 
694 	/* release the old buffer */
695 	if (substream->runtime->dma_area) {
696 		saa7134_pgtable_free(dev->pci, &dev->dmasound.pt);
697 		saa7134_alsa_dma_unmap(dev);
698 		dsp_buffer_free(dev);
699 		substream->runtime->dma_area = NULL;
700 	}
701 	dev->dmasound.blocks  = periods;
702 	dev->dmasound.blksize = period_size;
703 	dev->dmasound.bufsize = period_size * periods;
704 
705 	err = dsp_buffer_init(dev);
706 	if (0 != err) {
707 		dev->dmasound.blocks  = 0;
708 		dev->dmasound.blksize = 0;
709 		dev->dmasound.bufsize = 0;
710 		return err;
711 	}
712 
713 	err = saa7134_alsa_dma_map(dev);
714 	if (err) {
715 		dsp_buffer_free(dev);
716 		return err;
717 	}
718 	err = saa7134_pgtable_alloc(dev->pci, &dev->dmasound.pt);
719 	if (err) {
720 		saa7134_alsa_dma_unmap(dev);
721 		dsp_buffer_free(dev);
722 		return err;
723 	}
724 	err = saa7134_pgtable_build(dev->pci, &dev->dmasound.pt,
725 				dev->dmasound.sglist, dev->dmasound.sglen, 0);
726 	if (err) {
727 		saa7134_pgtable_free(dev->pci, &dev->dmasound.pt);
728 		saa7134_alsa_dma_unmap(dev);
729 		dsp_buffer_free(dev);
730 		return err;
731 	}
732 
733 	/* I should be able to use runtime->dma_addr in the control
734 	   byte, but it doesn't work. So I allocate the DMA using the
735 	   V4L functions, and force ALSA to use that as the DMA area */
736 
737 	substream->runtime->dma_area = dev->dmasound.vaddr;
738 	substream->runtime->dma_bytes = dev->dmasound.bufsize;
739 	substream->runtime->dma_addr = 0;
740 
741 	return 0;
742 
743 }
744 
745 /*
746  * ALSA hardware release
747  *
748  *   - One of the ALSA capture callbacks.
749  *
750  *   Called after closing the device, but before snd_card_saa7134_capture_close
751  *   It stops the DMA audio and releases the buffers.
752  *
753  */
754 
755 static int snd_card_saa7134_hw_free(struct snd_pcm_substream * substream)
756 {
757 	snd_card_saa7134_t *saa7134 = snd_pcm_substream_chip(substream);
758 	struct saa7134_dev *dev;
759 
760 	dev = saa7134->dev;
761 
762 	if (substream->runtime->dma_area) {
763 		saa7134_pgtable_free(dev->pci, &dev->dmasound.pt);
764 		saa7134_alsa_dma_unmap(dev);
765 		dsp_buffer_free(dev);
766 		substream->runtime->dma_area = NULL;
767 	}
768 
769 	return 0;
770 }
771 
772 /*
773  * ALSA capture finish
774  *
775  *   - One of the ALSA capture callbacks.
776  *
777  *   Called after closing the device.
778  *
779  */
780 
781 static int snd_card_saa7134_capture_close(struct snd_pcm_substream * substream)
782 {
783 	snd_card_saa7134_t *saa7134 = snd_pcm_substream_chip(substream);
784 	struct saa7134_dev *dev = saa7134->dev;
785 
786 	if (saa7134->mute_was_on) {
787 		dev->ctl_mute = 1;
788 		saa7134_tvaudio_setmute(dev);
789 	}
790 	return 0;
791 }
792 
793 /*
794  * ALSA capture start
795  *
796  *   - One of the ALSA capture callbacks.
797  *
798  *   Called when opening the device. It creates and populates the PCM
799  *  structure
800  *
801  */
802 
803 static int snd_card_saa7134_capture_open(struct snd_pcm_substream * substream)
804 {
805 	struct snd_pcm_runtime *runtime = substream->runtime;
806 	snd_card_saa7134_pcm_t *pcm;
807 	snd_card_saa7134_t *saa7134 = snd_pcm_substream_chip(substream);
808 	struct saa7134_dev *dev;
809 	int amux, err;
810 
811 	if (!saa7134) {
812 		pr_err("BUG: saa7134 can't find device struct. Can't proceed with open\n");
813 		return -ENODEV;
814 	}
815 	dev = saa7134->dev;
816 	mutex_lock(&dev->dmasound.lock);
817 
818 	dev->dmasound.read_count  = 0;
819 	dev->dmasound.read_offset = 0;
820 
821 	amux = dev->input->amux;
822 	if ((amux < 1) || (amux > 3))
823 		amux = 1;
824 	dev->dmasound.input  =  amux - 1;
825 
826 	mutex_unlock(&dev->dmasound.lock);
827 
828 	pcm = kzalloc(sizeof(*pcm), GFP_KERNEL);
829 	if (pcm == NULL)
830 		return -ENOMEM;
831 
832 	pcm->dev=saa7134->dev;
833 
834 	spin_lock_init(&pcm->lock);
835 
836 	pcm->substream = substream;
837 	runtime->private_data = pcm;
838 	runtime->private_free = snd_card_saa7134_runtime_free;
839 	runtime->hw = snd_card_saa7134_capture;
840 
841 	if (dev->ctl_mute != 0) {
842 		saa7134->mute_was_on = 1;
843 		dev->ctl_mute = 0;
844 		saa7134_tvaudio_setmute(dev);
845 	}
846 
847 	err = snd_pcm_hw_constraint_integer(runtime,
848 						SNDRV_PCM_HW_PARAM_PERIODS);
849 	if (err < 0)
850 		return err;
851 
852 	err = snd_pcm_hw_constraint_step(runtime, 0,
853 						SNDRV_PCM_HW_PARAM_PERIODS, 2);
854 	if (err < 0)
855 		return err;
856 
857 	return 0;
858 }
859 
860 /*
861  * page callback (needed for mmap)
862  */
863 
864 static struct page *snd_card_saa7134_page(struct snd_pcm_substream *substream,
865 					unsigned long offset)
866 {
867 	void *pageptr = substream->runtime->dma_area + offset;
868 	return vmalloc_to_page(pageptr);
869 }
870 
871 /*
872  * ALSA capture callbacks definition
873  */
874 
875 static const struct snd_pcm_ops snd_card_saa7134_capture_ops = {
876 	.open =			snd_card_saa7134_capture_open,
877 	.close =		snd_card_saa7134_capture_close,
878 	.ioctl =		snd_pcm_lib_ioctl,
879 	.hw_params =		snd_card_saa7134_hw_params,
880 	.hw_free =		snd_card_saa7134_hw_free,
881 	.prepare =		snd_card_saa7134_capture_prepare,
882 	.trigger =		snd_card_saa7134_capture_trigger,
883 	.pointer =		snd_card_saa7134_capture_pointer,
884 	.page =			snd_card_saa7134_page,
885 };
886 
887 /*
888  * ALSA PCM setup
889  *
890  *   Called when initializing the board. Sets up the name and hooks up
891  *  the callbacks
892  *
893  */
894 
895 static int snd_card_saa7134_pcm(snd_card_saa7134_t *saa7134, int device)
896 {
897 	struct snd_pcm *pcm;
898 	int err;
899 
900 	if ((err = snd_pcm_new(saa7134->card, "SAA7134 PCM", device, 0, 1, &pcm)) < 0)
901 		return err;
902 	snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_card_saa7134_capture_ops);
903 	pcm->private_data = saa7134;
904 	pcm->info_flags = 0;
905 	strcpy(pcm->name, "SAA7134 PCM");
906 	return 0;
907 }
908 
909 #define SAA713x_VOLUME(xname, xindex, addr) \
910 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, .index = xindex, \
911   .info = snd_saa7134_volume_info, \
912   .get = snd_saa7134_volume_get, .put = snd_saa7134_volume_put, \
913   .private_value = addr }
914 
915 static int snd_saa7134_volume_info(struct snd_kcontrol * kcontrol,
916 				   struct snd_ctl_elem_info * uinfo)
917 {
918 	uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
919 	uinfo->count = 2;
920 	uinfo->value.integer.min = 0;
921 	uinfo->value.integer.max = 20;
922 	return 0;
923 }
924 
925 static int snd_saa7134_volume_get(struct snd_kcontrol * kcontrol,
926 				  struct snd_ctl_elem_value * ucontrol)
927 {
928 	snd_card_saa7134_t *chip = snd_kcontrol_chip(kcontrol);
929 	int addr = kcontrol->private_value;
930 
931 	ucontrol->value.integer.value[0] = chip->mixer_volume[addr][0];
932 	ucontrol->value.integer.value[1] = chip->mixer_volume[addr][1];
933 	return 0;
934 }
935 
936 static int snd_saa7134_volume_put(struct snd_kcontrol * kcontrol,
937 				  struct snd_ctl_elem_value * ucontrol)
938 {
939 	snd_card_saa7134_t *chip = snd_kcontrol_chip(kcontrol);
940 	struct saa7134_dev *dev = chip->dev;
941 
942 	int change, addr = kcontrol->private_value;
943 	int left, right;
944 
945 	left = ucontrol->value.integer.value[0];
946 	if (left < 0)
947 		left = 0;
948 	if (left > 20)
949 		left = 20;
950 	right = ucontrol->value.integer.value[1];
951 	if (right < 0)
952 		right = 0;
953 	if (right > 20)
954 		right = 20;
955 	spin_lock_irq(&chip->mixer_lock);
956 	change = 0;
957 	if (chip->mixer_volume[addr][0] != left) {
958 		change = 1;
959 		right = left;
960 	}
961 	if (chip->mixer_volume[addr][1] != right) {
962 		change = 1;
963 		left = right;
964 	}
965 	if (change) {
966 		switch (dev->pci->device) {
967 			case PCI_DEVICE_ID_PHILIPS_SAA7134:
968 				switch (addr) {
969 					case MIXER_ADDR_TVTUNER:
970 						left = 20;
971 						break;
972 					case MIXER_ADDR_LINE1:
973 						saa_andorb(SAA7134_ANALOG_IO_SELECT,  0x10,
974 							   (left > 10) ? 0x00 : 0x10);
975 						break;
976 					case MIXER_ADDR_LINE2:
977 						saa_andorb(SAA7134_ANALOG_IO_SELECT,  0x20,
978 							   (left > 10) ? 0x00 : 0x20);
979 						break;
980 				}
981 				break;
982 			case PCI_DEVICE_ID_PHILIPS_SAA7133:
983 			case PCI_DEVICE_ID_PHILIPS_SAA7135:
984 				switch (addr) {
985 					case MIXER_ADDR_TVTUNER:
986 						left = 20;
987 						break;
988 					case MIXER_ADDR_LINE1:
989 						saa_andorb(0x0594,  0x10,
990 							   (left > 10) ? 0x00 : 0x10);
991 						break;
992 					case MIXER_ADDR_LINE2:
993 						saa_andorb(0x0594,  0x20,
994 							   (left > 10) ? 0x00 : 0x20);
995 						break;
996 				}
997 				break;
998 		}
999 		chip->mixer_volume[addr][0] = left;
1000 		chip->mixer_volume[addr][1] = right;
1001 	}
1002 	spin_unlock_irq(&chip->mixer_lock);
1003 	return change;
1004 }
1005 
1006 #define SAA713x_CAPSRC(xname, xindex, addr) \
1007 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, .index = xindex, \
1008   .info = snd_saa7134_capsrc_info, \
1009   .get = snd_saa7134_capsrc_get, .put = snd_saa7134_capsrc_put, \
1010   .private_value = addr }
1011 
1012 static int snd_saa7134_capsrc_info(struct snd_kcontrol * kcontrol,
1013 				   struct snd_ctl_elem_info * uinfo)
1014 {
1015 	uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN;
1016 	uinfo->count = 2;
1017 	uinfo->value.integer.min = 0;
1018 	uinfo->value.integer.max = 1;
1019 	return 0;
1020 }
1021 
1022 static int snd_saa7134_capsrc_get(struct snd_kcontrol * kcontrol,
1023 				  struct snd_ctl_elem_value * ucontrol)
1024 {
1025 	snd_card_saa7134_t *chip = snd_kcontrol_chip(kcontrol);
1026 	int addr = kcontrol->private_value;
1027 
1028 	spin_lock_irq(&chip->mixer_lock);
1029 	if (chip->capture_source_addr == addr) {
1030 		ucontrol->value.integer.value[0] = chip->capture_source[0];
1031 		ucontrol->value.integer.value[1] = chip->capture_source[1];
1032 	} else {
1033 		ucontrol->value.integer.value[0] = 0;
1034 		ucontrol->value.integer.value[1] = 0;
1035 	}
1036 	spin_unlock_irq(&chip->mixer_lock);
1037 
1038 	return 0;
1039 }
1040 
1041 static int snd_saa7134_capsrc_put(struct snd_kcontrol * kcontrol,
1042 				  struct snd_ctl_elem_value * ucontrol)
1043 {
1044 	int left, right;
1045 	left = ucontrol->value.integer.value[0] & 1;
1046 	right = ucontrol->value.integer.value[1] & 1;
1047 
1048 	return snd_saa7134_capsrc_set(kcontrol, left, right, false);
1049 }
1050 
1051 static struct snd_kcontrol_new snd_saa7134_volume_controls[] = {
1052 SAA713x_VOLUME("Video Volume", 0, MIXER_ADDR_TVTUNER),
1053 SAA713x_VOLUME("Line Volume", 1, MIXER_ADDR_LINE1),
1054 SAA713x_VOLUME("Line Volume", 2, MIXER_ADDR_LINE2),
1055 };
1056 
1057 static struct snd_kcontrol_new snd_saa7134_capture_controls[] = {
1058 SAA713x_CAPSRC("Video Capture Switch", 0, MIXER_ADDR_TVTUNER),
1059 SAA713x_CAPSRC("Line Capture Switch", 1, MIXER_ADDR_LINE1),
1060 SAA713x_CAPSRC("Line Capture Switch", 2, MIXER_ADDR_LINE2),
1061 };
1062 
1063 /*
1064  * ALSA mixer setup
1065  *
1066  *   Called when initializing the board. Sets up the name and hooks up
1067  *  the callbacks
1068  *
1069  */
1070 
1071 static int snd_card_saa7134_new_mixer(snd_card_saa7134_t * chip)
1072 {
1073 	struct snd_card *card = chip->card;
1074 	struct snd_kcontrol *kcontrol;
1075 	unsigned int idx;
1076 	int err, addr;
1077 
1078 	strcpy(card->mixername, "SAA7134 Mixer");
1079 
1080 	for (idx = 0; idx < ARRAY_SIZE(snd_saa7134_volume_controls); idx++) {
1081 		kcontrol = snd_ctl_new1(&snd_saa7134_volume_controls[idx],
1082 					chip);
1083 		err = snd_ctl_add(card, kcontrol);
1084 		if (err < 0)
1085 			return err;
1086 	}
1087 
1088 	for (idx = 0; idx < ARRAY_SIZE(snd_saa7134_capture_controls); idx++) {
1089 		kcontrol = snd_ctl_new1(&snd_saa7134_capture_controls[idx],
1090 					chip);
1091 		addr = snd_saa7134_capture_controls[idx].private_value;
1092 		chip->capture_ctl[addr] = kcontrol;
1093 		err = snd_ctl_add(card, kcontrol);
1094 		if (err < 0)
1095 			return err;
1096 	}
1097 
1098 	chip->capture_source_addr = MIXER_ADDR_UNSELECTED;
1099 	return 0;
1100 }
1101 
1102 static void snd_saa7134_free(struct snd_card * card)
1103 {
1104 	snd_card_saa7134_t *chip = card->private_data;
1105 
1106 	if (chip->dev->dmasound.priv_data == NULL)
1107 		return;
1108 
1109 	if (chip->irq >= 0)
1110 		free_irq(chip->irq, &chip->dev->dmasound);
1111 
1112 	chip->dev->dmasound.priv_data = NULL;
1113 
1114 }
1115 
1116 /*
1117  * ALSA initialization
1118  *
1119  *   Called by the init routine, once for each saa7134 device present,
1120  *  it creates the basic structures and registers the ALSA devices
1121  *
1122  */
1123 
1124 static int alsa_card_saa7134_create(struct saa7134_dev *dev, int devnum)
1125 {
1126 
1127 	struct snd_card *card;
1128 	snd_card_saa7134_t *chip;
1129 	int err;
1130 
1131 
1132 	if (devnum >= SNDRV_CARDS)
1133 		return -ENODEV;
1134 	if (!enable[devnum])
1135 		return -ENODEV;
1136 
1137 	err = snd_card_new(&dev->pci->dev, index[devnum], id[devnum],
1138 			   THIS_MODULE, sizeof(snd_card_saa7134_t), &card);
1139 	if (err < 0)
1140 		return err;
1141 
1142 	strcpy(card->driver, "SAA7134");
1143 
1144 	/* Card "creation" */
1145 
1146 	card->private_free = snd_saa7134_free;
1147 	chip = card->private_data;
1148 
1149 	spin_lock_init(&chip->lock);
1150 	spin_lock_init(&chip->mixer_lock);
1151 
1152 	chip->dev = dev;
1153 
1154 	chip->card = card;
1155 
1156 	chip->pci = dev->pci;
1157 	chip->iobase = pci_resource_start(dev->pci, 0);
1158 
1159 
1160 	err = request_irq(dev->pci->irq, saa7134_alsa_irq,
1161 				IRQF_SHARED, dev->name,
1162 				(void*) &dev->dmasound);
1163 
1164 	if (err < 0) {
1165 		pr_err("%s: can't get IRQ %d for ALSA\n",
1166 			dev->name, dev->pci->irq);
1167 		goto __nodev;
1168 	}
1169 
1170 	chip->irq = dev->pci->irq;
1171 
1172 	mutex_init(&dev->dmasound.lock);
1173 
1174 	if ((err = snd_card_saa7134_new_mixer(chip)) < 0)
1175 		goto __nodev;
1176 
1177 	if ((err = snd_card_saa7134_pcm(chip, 0)) < 0)
1178 		goto __nodev;
1179 
1180 	/* End of "creation" */
1181 
1182 	strcpy(card->shortname, "SAA7134");
1183 	sprintf(card->longname, "%s at 0x%lx irq %d",
1184 		chip->dev->name, chip->iobase, chip->irq);
1185 
1186 	pr_info("%s/alsa: %s registered as card %d\n",
1187 		dev->name, card->longname, index[devnum]);
1188 
1189 	if ((err = snd_card_register(card)) == 0) {
1190 		snd_saa7134_cards[devnum] = card;
1191 		return 0;
1192 	}
1193 
1194 __nodev:
1195 	snd_card_free(card);
1196 	return err;
1197 }
1198 
1199 
1200 static int alsa_device_init(struct saa7134_dev *dev)
1201 {
1202 	dev->dmasound.priv_data = dev;
1203 	alsa_card_saa7134_create(dev,dev->nr);
1204 	return 1;
1205 }
1206 
1207 static int alsa_device_exit(struct saa7134_dev *dev)
1208 {
1209 	if (!snd_saa7134_cards[dev->nr])
1210 		return 1;
1211 
1212 	snd_card_free(snd_saa7134_cards[dev->nr]);
1213 	snd_saa7134_cards[dev->nr] = NULL;
1214 	return 1;
1215 }
1216 
1217 /*
1218  * Module initializer
1219  *
1220  * Loops through present saa7134 cards, and assigns an ALSA device
1221  * to each one
1222  *
1223  */
1224 
1225 static int saa7134_alsa_init(void)
1226 {
1227 	struct saa7134_dev *dev = NULL;
1228 	struct list_head *list;
1229 
1230 	saa7134_dmasound_init = alsa_device_init;
1231 	saa7134_dmasound_exit = alsa_device_exit;
1232 
1233 	pr_info("saa7134 ALSA driver for DMA sound loaded\n");
1234 
1235 	list_for_each(list,&saa7134_devlist) {
1236 		dev = list_entry(list, struct saa7134_dev, devlist);
1237 		if (dev->pci->device == PCI_DEVICE_ID_PHILIPS_SAA7130)
1238 			pr_info("%s/alsa: %s doesn't support digital audio\n",
1239 				dev->name, saa7134_boards[dev->board].name);
1240 		else
1241 			alsa_device_init(dev);
1242 	}
1243 
1244 	if (dev == NULL)
1245 		pr_info("saa7134 ALSA: no saa7134 cards found\n");
1246 
1247 	return 0;
1248 
1249 }
1250 
1251 /*
1252  * Module destructor
1253  */
1254 
1255 static void saa7134_alsa_exit(void)
1256 {
1257 	int idx;
1258 
1259 	for (idx = 0; idx < SNDRV_CARDS; idx++) {
1260 		if (snd_saa7134_cards[idx])
1261 			snd_card_free(snd_saa7134_cards[idx]);
1262 	}
1263 
1264 	saa7134_dmasound_init = NULL;
1265 	saa7134_dmasound_exit = NULL;
1266 	pr_info("saa7134 ALSA driver for DMA sound unloaded\n");
1267 
1268 	return;
1269 }
1270 
1271 /* We initialize this late, to make sure the sound system is up and running */
1272 late_initcall(saa7134_alsa_init);
1273 module_exit(saa7134_alsa_exit);
1274 MODULE_LICENSE("GPL");
1275 MODULE_AUTHOR("Ricardo Cerqueira");
1276