aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media')
-rw-r--r--drivers/media/video/saa7134/saa7134-alsa.c110
-rw-r--r--drivers/media/video/saa7134/saa7134-core.c29
-rw-r--r--drivers/media/video/saa7134/saa7134-tvaudio.c3
-rw-r--r--drivers/media/video/saa7134/saa7134.h8
4 files changed, 121 insertions, 29 deletions
diff --git a/drivers/media/video/saa7134/saa7134-alsa.c b/drivers/media/video/saa7134/saa7134-alsa.c
index bf454437b771..7972939cb46c 100644
--- a/drivers/media/video/saa7134/saa7134-alsa.c
+++ b/drivers/media/video/saa7134/saa7134-alsa.c
@@ -1,6 +1,5 @@
1/* 1/*
2 * SAA713x ALSA support for V4L 2 * SAA713x ALSA support for V4L
3 * Ricardo Cerqueira <v4l@cerqueira.org>
4 * 3 *
5 * 4 *
6 * Caveats: 5 * Caveats:
@@ -37,9 +36,13 @@
37#include "saa7134.h" 36#include "saa7134.h"
38#include "saa7134-reg.h" 37#include "saa7134-reg.h"
39 38
40static unsigned int alsa_debug = 0; 39static unsigned int debug = 0;
41module_param(alsa_debug, int, 0644); 40module_param(debug, int, 0644);
42MODULE_PARM_DESC(alsa_debug,"enable debug messages [alsa]"); 41MODULE_PARM_DESC(debug,"enable debug messages [alsa]");
42
43unsigned int dsp_nr = 0;
44module_param(dsp_nr, int, 0444);
45MODULE_PARM_DESC(dsp_nr, "alsa device number");
43 46
44/* 47/*
45 * Configuration macros 48 * Configuration macros
@@ -69,7 +72,7 @@ static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX; /* Index 0-MAX */
69static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR; /* ID for this card */ 72static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR; /* ID for this card */
70static int enable[SNDRV_CARDS] = {1, [1 ... (SNDRV_CARDS - 1)] = 0}; 73static int enable[SNDRV_CARDS] = {1, [1 ... (SNDRV_CARDS - 1)] = 0};
71 74
72#define dprintk(fmt, arg...) if (alsa_debug) \ 75#define dprintk(fmt, arg...) if (debug) \
73 printk(KERN_DEBUG "%s/alsa: " fmt, dev->name , ## arg) 76 printk(KERN_DEBUG "%s/alsa: " fmt, dev->name , ## arg)
74 77
75/* 78/*
@@ -107,6 +110,7 @@ typedef struct snd_card_saa7134_pcm {
107 110
108static snd_card_t *snd_saa7134_cards[SNDRV_CARDS] = SNDRV_DEFAULT_PTR; 111static snd_card_t *snd_saa7134_cards[SNDRV_CARDS] = SNDRV_DEFAULT_PTR;
109 112
113
110/* 114/*
111 * saa7134 DMA audio stop 115 * saa7134 DMA audio stop
112 * 116 *
@@ -189,12 +193,11 @@ void saa7134_irq_alsa_done(struct saa7134_dev *dev, unsigned long status)
189 /* next block addr */ 193 /* next block addr */
190 next_blk = (dev->oss.dma_blk + 2) % dev->oss.blocks; 194 next_blk = (dev->oss.dma_blk + 2) % dev->oss.blocks;
191 saa_writel(reg,next_blk * dev->oss.blksize); 195 saa_writel(reg,next_blk * dev->oss.blksize);
192 if (alsa_debug > 2) 196 if (debug > 2)
193 dprintk("irq: ok, %s, next_blk=%d, addr=%x, blocks=%u, size=%u, read=%u\n", 197 dprintk("irq: ok, %s, next_blk=%d, addr=%x, blocks=%u, size=%u, read=%u\n",
194 (status & 0x10000000) ? "even" : "odd ", next_blk, 198 (status & 0x10000000) ? "even" : "odd ", next_blk,
195 next_blk * dev->oss.blksize, dev->oss.blocks, dev->oss.blksize, dev->oss.read_count); 199 next_blk * dev->oss.blksize, dev->oss.blocks, dev->oss.blksize, dev->oss.read_count);
196 200
197
198 /* update status & wake waiting readers */ 201 /* update status & wake waiting readers */
199 dev->oss.dma_blk = (dev->oss.dma_blk + 1) % dev->oss.blocks; 202 dev->oss.dma_blk = (dev->oss.dma_blk + 1) % dev->oss.blocks;
200 dev->oss.read_count += dev->oss.blksize; 203 dev->oss.read_count += dev->oss.blksize;
@@ -212,6 +215,41 @@ void saa7134_irq_alsa_done(struct saa7134_dev *dev, unsigned long status)
212} 215}
213 216
214/* 217/*
218 * IRQ request handler
219 *
220 * Runs along with saa7134's IRQ handler, discards anything that isn't
221 * DMA sound
222 *
223 */
224
225static irqreturn_t saa7134_alsa_irq(int irq, void *dev_id, struct pt_regs *regs)
226{
227 struct saa7134_dev *dev = (struct saa7134_dev*) dev_id;
228 unsigned long report, status;
229 int loop, handled = 0;
230
231 for (loop = 0; loop < 10; loop++) {
232 report = saa_readl(SAA7134_IRQ_REPORT);
233 status = saa_readl(SAA7134_IRQ_STATUS);
234
235 if (report & SAA7134_IRQ_REPORT_DONE_RA3) {
236 handled = 1;
237 saa_writel(SAA7134_IRQ_REPORT,report);
238 saa7134_irq_alsa_done(dev, status);
239 } else {
240 goto out;
241 }
242 }
243
244 if (loop == 10) {
245 dprintk("error! looping IRQ!");
246 }
247
248out:
249 return IRQ_RETVAL(handled);
250}
251
252/*
215 * ALSA capture trigger 253 * ALSA capture trigger
216 * 254 *
217 * - One of the ALSA capture callbacks. 255 * - One of the ALSA capture callbacks.
@@ -822,11 +860,9 @@ static int snd_saa7134_capsrc_put(snd_kcontrol_t * kcontrol, snd_ctl_elem_value_
822 saa_dsp_writel(dev, SAA7133_DIGITAL_OUTPUT_SEL1, 0xbbbb10); 860 saa_dsp_writel(dev, SAA7133_DIGITAL_OUTPUT_SEL1, 0xbbbb10);
823 861
824 if (left || right) { // We've got data, turn the input on 862 if (left || right) { // We've got data, turn the input on
825 //saa_dsp_writel(dev, SAA7133_DIGITAL_OUTPUT_SEL2, 0x101010);
826 saa_dsp_writel(dev, SAA7133_DIGITAL_INPUT_XBAR1, xbarin); 863 saa_dsp_writel(dev, SAA7133_DIGITAL_INPUT_XBAR1, xbarin);
827 saa_writel(SAA7133_ANALOG_IO_SELECT, anabar); 864 saa_writel(SAA7133_ANALOG_IO_SELECT, anabar);
828 } else { 865 } else {
829 //saa_dsp_writel(dev, SAA7133_DIGITAL_OUTPUT_SEL2, 0x101010);
830 saa_dsp_writel(dev, SAA7133_DIGITAL_INPUT_XBAR1, 0); 866 saa_dsp_writel(dev, SAA7133_DIGITAL_INPUT_XBAR1, 0);
831 saa_writel(SAA7133_ANALOG_IO_SELECT, 0); 867 saa_writel(SAA7133_ANALOG_IO_SELECT, 0);
832 } 868 }
@@ -889,9 +925,10 @@ static int snd_saa7134_dev_free(snd_device_t *device)
889 * 925 *
890 */ 926 */
891 927
892int alsa_card_saa7134_create(struct saa7134_dev *saadev, unsigned int devicenum) 928int alsa_card_saa7134_create (struct saa7134_dev *saadev, unsigned int devicenum)
893{ 929{
894 static int dev; 930 static int dev;
931
895 snd_card_t *card; 932 snd_card_t *card;
896 snd_card_saa7134_t *chip; 933 snd_card_saa7134_t *chip;
897 int err; 934 int err;
@@ -899,6 +936,7 @@ int alsa_card_saa7134_create(struct saa7134_dev *saadev, unsigned int devicenum)
899 .dev_free = snd_saa7134_dev_free, 936 .dev_free = snd_saa7134_dev_free,
900 }; 937 };
901 938
939
902 if (dev >= SNDRV_CARDS) 940 if (dev >= SNDRV_CARDS)
903 return -ENODEV; 941 return -ENODEV;
904 if (!enable[dev]) 942 if (!enable[dev])
@@ -906,6 +944,7 @@ int alsa_card_saa7134_create(struct saa7134_dev *saadev, unsigned int devicenum)
906 944
907 if (devicenum) { 945 if (devicenum) {
908 card = snd_card_new(devicenum, id[dev], THIS_MODULE, 0); 946 card = snd_card_new(devicenum, id[dev], THIS_MODULE, 0);
947 dsp_nr++;
909 } else { 948 } else {
910 card = snd_card_new(index[dev], id[dev], THIS_MODULE, 0); 949 card = snd_card_new(index[dev], id[dev], THIS_MODULE, 0);
911 } 950 }
@@ -931,6 +970,15 @@ int alsa_card_saa7134_create(struct saa7134_dev *saadev, unsigned int devicenum)
931 chip->irq = saadev->pci->irq; 970 chip->irq = saadev->pci->irq;
932 chip->iobase = pci_resource_start(saadev->pci, 0); 971 chip->iobase = pci_resource_start(saadev->pci, 0);
933 972
973 err = request_irq(chip->pci->irq, saa7134_alsa_irq,
974 SA_SHIRQ | SA_INTERRUPT, saadev->name, saadev);
975
976 if (err < 0) {
977 printk(KERN_ERR "%s: can't get IRQ %d for ALSA\n",
978 saadev->name, saadev->pci->irq);
979 return err;
980 }
981
934 if ((err = snd_device_new(card, SNDRV_DEV_LOWLEVEL, chip, &ops)) < 0) { 982 if ((err = snd_device_new(card, SNDRV_DEV_LOWLEVEL, chip, &ops)) < 0) {
935 snd_saa7134_free(chip); 983 snd_saa7134_free(chip);
936 return err; 984 return err;
@@ -963,10 +1011,48 @@ __nodev:
963 return err; 1011 return err;
964} 1012}
965 1013
966void alsa_card_saa7134_exit(void) 1014/*
1015 * Module initializer
1016 *
1017 * Loops through present saa7134 cards, and assigns an ALSA device
1018 * to each one
1019 *
1020 */
1021
1022static int saa7134_alsa_init(void)
1023{
1024 struct saa7134_dev *saadev = NULL;
1025 struct list_head *list;
1026
1027 printk(KERN_INFO "saa7134 ALSA driver for DMA sound loaded\n");
1028
1029 list_for_each(list,&saa7134_devlist) {
1030 saadev = list_entry(list, struct saa7134_dev, devlist);
1031 alsa_card_saa7134_create(saadev,dsp_nr);
1032 }
1033
1034 if (saadev == NULL)
1035 printk(KERN_INFO "saa7134 ALSA: no saa7134 cards found\n");
1036
1037 return 0;
1038
1039}
1040
1041/*
1042 * Module destructor
1043 */
1044
1045void saa7134_alsa_exit(void)
967{ 1046{
968 int idx; 1047 int idx;
969 for (idx = 0; idx < SNDRV_CARDS; idx++) { 1048 for (idx = 0; idx < SNDRV_CARDS; idx++) {
970 snd_card_free(snd_saa7134_cards[idx]); 1049 snd_card_free(snd_saa7134_cards[idx]);
971 } 1050 }
1051 printk(KERN_INFO "saa7134 ALSA driver for DMA sound unloaded\n");
1052 return;
972} 1053}
1054
1055module_init(saa7134_alsa_init);
1056module_exit(saa7134_alsa_exit);
1057MODULE_LICENSE("GPL");
1058MODULE_AUTHOR("Ricardo Cerqueira");
diff --git a/drivers/media/video/saa7134/saa7134-core.c b/drivers/media/video/saa7134/saa7134-core.c
index 454b8a86c830..6c329c440572 100644
--- a/drivers/media/video/saa7134/saa7134-core.c
+++ b/drivers/media/video/saa7134/saa7134-core.c
@@ -574,6 +574,17 @@ static irqreturn_t saa7134_irq(int irq, void *dev_id, struct pt_regs *regs)
574 dev->name); 574 dev->name);
575 goto out; 575 goto out;
576 } 576 }
577
578 /* If alsa support is active and we get a sound report, exit
579 and let the saa7134-alsa module deal with it */
580
581 if ((report & SAA7134_IRQ_REPORT_DONE_RA3) && alsa) {
582 if (irq_debug > 1)
583 printk(KERN_DEBUG "%s/irq: ignoring interrupt for ALSA\n",
584 dev->name);
585 goto out;
586 }
587
577 handled = 1; 588 handled = 1;
578 saa_writel(SAA7134_IRQ_REPORT,report); 589 saa_writel(SAA7134_IRQ_REPORT,report);
579 if (irq_debug) 590 if (irq_debug)
@@ -598,8 +609,6 @@ static irqreturn_t saa7134_irq(int irq, void *dev_id, struct pt_regs *regs)
598 if ((report & SAA7134_IRQ_REPORT_DONE_RA3)) { 609 if ((report & SAA7134_IRQ_REPORT_DONE_RA3)) {
599 if (oss) { 610 if (oss) {
600 saa7134_irq_oss_done(dev,status); 611 saa7134_irq_oss_done(dev,status);
601 } else if (alsa) {
602 saa7134_irq_alsa_done(dev,status);
603 } 612 }
604 } 613 }
605 614
@@ -1029,9 +1038,7 @@ static int __devinit saa7134_initdev(struct pci_dev *pci_dev,
1029 printk(KERN_INFO "%s: registered device mixer%d\n", 1038 printk(KERN_INFO "%s: registered device mixer%d\n",
1030 dev->name,dev->oss.minor_mixer >> 4); 1039 dev->name,dev->oss.minor_mixer >> 4);
1031 } else if (alsa) { 1040 } else if (alsa) {
1032 alsa_card_saa7134_create(dev,dsp_nr[dev->nr]); 1041 request_module("saa7134-alsa");
1033 printk(KERN_INFO "%s: registered ALSA devices\n",
1034 dev->name);
1035 } 1042 }
1036 break; 1043 break;
1037 } 1044 }
@@ -1059,8 +1066,6 @@ static int __devinit saa7134_initdev(struct pci_dev *pci_dev,
1059 case PCI_DEVICE_ID_PHILIPS_SAA7135: 1066 case PCI_DEVICE_ID_PHILIPS_SAA7135:
1060 if (oss) 1067 if (oss)
1061 unregister_sound_dsp(dev->oss.minor_dsp); 1068 unregister_sound_dsp(dev->oss.minor_dsp);
1062 else if (alsa)
1063 alsa_card_saa7134_exit();
1064 break; 1069 break;
1065 } 1070 }
1066 fail4: 1071 fail4:
@@ -1120,8 +1125,7 @@ static void __devexit saa7134_finidev(struct pci_dev *pci_dev)
1120 if (oss) { 1125 if (oss) {
1121 unregister_sound_mixer(dev->oss.minor_mixer); 1126 unregister_sound_mixer(dev->oss.minor_mixer);
1122 unregister_sound_dsp(dev->oss.minor_dsp); 1127 unregister_sound_dsp(dev->oss.minor_dsp);
1123 } else if (alsa) 1128 }
1124 alsa_card_saa7134_exit();
1125 break; 1129 break;
1126 } 1130 }
1127 saa7134_unregister_video(dev); 1131 saa7134_unregister_video(dev);
@@ -1214,6 +1218,13 @@ EXPORT_SYMBOL(saa7134_i2c_call_clients);
1214EXPORT_SYMBOL(saa7134_devlist); 1218EXPORT_SYMBOL(saa7134_devlist);
1215EXPORT_SYMBOL(saa7134_boards); 1219EXPORT_SYMBOL(saa7134_boards);
1216 1220
1221/* ----------------- For ALSA -------------------------------- */
1222
1223EXPORT_SYMBOL(saa7134_pgtable_free);
1224EXPORT_SYMBOL(saa7134_pgtable_build);
1225EXPORT_SYMBOL(saa7134_pgtable_alloc);
1226EXPORT_SYMBOL(saa7134_set_dmabits);
1227
1217/* ----------------------------------------------------------- */ 1228/* ----------------------------------------------------------- */
1218/* 1229/*
1219 * Local variables: 1230 * Local variables:
diff --git a/drivers/media/video/saa7134/saa7134-tvaudio.c b/drivers/media/video/saa7134/saa7134-tvaudio.c
index 3daf1b597958..93268427750d 100644
--- a/drivers/media/video/saa7134/saa7134-tvaudio.c
+++ b/drivers/media/video/saa7134/saa7134-tvaudio.c
@@ -1024,9 +1024,12 @@ int saa7134_tvaudio_do_scan(struct saa7134_dev *dev)
1024 return 0; 1024 return 0;
1025} 1025}
1026 1026
1027EXPORT_SYMBOL(saa_dsp_writel);
1028
1027/* ----------------------------------------------------------- */ 1029/* ----------------------------------------------------------- */
1028/* 1030/*
1029 * Local variables: 1031 * Local variables:
1030 * c-basic-offset: 8 1032 * c-basic-offset: 8
1031 * End: 1033 * End:
1032 */ 1034 */
1035
diff --git a/drivers/media/video/saa7134/saa7134.h b/drivers/media/video/saa7134/saa7134.h
index d993344d37e4..1fdc9e147f87 100644
--- a/drivers/media/video/saa7134/saa7134.h
+++ b/drivers/media/video/saa7134/saa7134.h
@@ -665,14 +665,6 @@ void saa7134_input_fini(struct saa7134_dev *dev);
665void saa7134_input_irq(struct saa7134_dev *dev); 665void saa7134_input_irq(struct saa7134_dev *dev);
666void saa7134_set_i2c_ir(struct saa7134_dev *dev, struct IR_i2c *ir); 666void saa7134_set_i2c_ir(struct saa7134_dev *dev, struct IR_i2c *ir);
667 667
668/* ----------------------------------------------------------- */
669/* saa7134-alsa.c */
670
671int alsa_card_saa7134_create(struct saa7134_dev *saadev, unsigned int devnum);
672void alsa_card_saa7134_exit(void);
673void saa7134_irq_alsa_done(struct saa7134_dev *dev, unsigned long status);
674
675
676/* 668/*
677 * Local variables: 669 * Local variables:
678 * c-basic-offset: 8 670 * c-basic-offset: 8