aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/media/pci/cx25821/cx25821-alsa.c79
-rw-r--r--drivers/media/pci/cx25821/cx25821-core.c21
-rw-r--r--drivers/media/pci/cx25821/cx25821-video.c38
-rw-r--r--drivers/media/pci/cx25821/cx25821.h9
4 files changed, 41 insertions, 106 deletions
diff --git a/drivers/media/pci/cx25821/cx25821-alsa.c b/drivers/media/pci/cx25821/cx25821-alsa.c
index b3cac75a4891..81361c26c54e 100644
--- a/drivers/media/pci/cx25821/cx25821-alsa.c
+++ b/drivers/media/pci/cx25821/cx25821-alsa.c
@@ -59,7 +59,6 @@ do { \
59 Data type declarations - Can be moded to a header file later 59 Data type declarations - Can be moded to a header file later
60 ****************************************************************************/ 60 ****************************************************************************/
61 61
62static struct snd_card *snd_cx25821_cards[SNDRV_CARDS];
63static int devno; 62static int devno;
64 63
65struct cx25821_audio_buffer { 64struct cx25821_audio_buffer {
@@ -627,34 +626,6 @@ static DEFINE_PCI_DEVICE_TABLE(cx25821_audio_pci_tbl) = {
627MODULE_DEVICE_TABLE(pci, cx25821_audio_pci_tbl); 626MODULE_DEVICE_TABLE(pci, cx25821_audio_pci_tbl);
628 627
629/* 628/*
630 * Not used in the function snd_cx25821_dev_free so removing
631 * from the file.
632 */
633/*
634static int snd_cx25821_free(struct cx25821_audio_dev *chip)
635{
636 if (chip->irq >= 0)
637 free_irq(chip->irq, chip);
638
639 cx25821_dev_unregister(chip->dev);
640 pci_disable_device(chip->pci);
641
642 return 0;
643}
644*/
645
646/*
647 * Component Destructor
648 */
649static void snd_cx25821_dev_free(struct snd_card *card)
650{
651 struct cx25821_audio_dev *chip = card->private_data;
652
653 /* snd_cx25821_free(chip); */
654 snd_card_free(chip->card);
655}
656
657/*
658 * Alsa Constructor - Component probe 629 * Alsa Constructor - Component probe
659 */ 630 */
660static int cx25821_audio_initdev(struct cx25821_dev *dev) 631static int cx25821_audio_initdev(struct cx25821_dev *dev)
@@ -685,7 +656,6 @@ static int cx25821_audio_initdev(struct cx25821_dev *dev)
685 strcpy(card->driver, "cx25821"); 656 strcpy(card->driver, "cx25821");
686 657
687 /* Card "creation" */ 658 /* Card "creation" */
688 card->private_free = snd_cx25821_dev_free;
689 chip = card->private_data; 659 chip = card->private_data;
690 spin_lock_init(&chip->reg_lock); 660 spin_lock_init(&chip->reg_lock);
691 661
@@ -729,8 +699,7 @@ static int cx25821_audio_initdev(struct cx25821_dev *dev)
729 goto error; 699 goto error;
730 } 700 }
731 701
732 snd_cx25821_cards[devno] = card; 702 dev->card = card;
733
734 devno++; 703 devno++;
735 return 0; 704 return 0;
736 705
@@ -742,9 +711,31 @@ error:
742/**************************************************************************** 711/****************************************************************************
743 LINUX MODULE INIT 712 LINUX MODULE INIT
744 ****************************************************************************/ 713 ****************************************************************************/
714
715static int cx25821_alsa_exit_callback(struct device *dev, void *data)
716{
717 struct v4l2_device *v4l2_dev = dev_get_drvdata(dev);
718 struct cx25821_dev *cxdev = get_cx25821(v4l2_dev);
719
720 snd_card_free(cxdev->card);
721 return 0;
722}
723
745static void cx25821_audio_fini(void) 724static void cx25821_audio_fini(void)
746{ 725{
747 snd_card_free(snd_cx25821_cards[0]); 726 struct device_driver *drv = driver_find("cx25821", &pci_bus_type);
727 int ret;
728
729 ret = driver_for_each_device(drv, NULL, NULL, cx25821_alsa_exit_callback);
730}
731
732static int cx25821_alsa_init_callback(struct device *dev, void *data)
733{
734 struct v4l2_device *v4l2_dev = dev_get_drvdata(dev);
735 struct cx25821_dev *cxdev = get_cx25821(v4l2_dev);
736
737 cx25821_audio_initdev(cxdev);
738 return 0;
748} 739}
749 740
750/* 741/*
@@ -756,29 +747,11 @@ static void cx25821_audio_fini(void)
756 */ 747 */
757static int cx25821_alsa_init(void) 748static int cx25821_alsa_init(void)
758{ 749{
759 struct cx25821_dev *dev = NULL; 750 struct device_driver *drv = driver_find("cx25821", &pci_bus_type);
760 struct list_head *list;
761 751
762 mutex_lock(&cx25821_devlist_mutex); 752 return driver_for_each_device(drv, NULL, NULL, cx25821_alsa_init_callback);
763 list_for_each(list, &cx25821_devlist) {
764 dev = list_entry(list, struct cx25821_dev, devlist);
765 cx25821_audio_initdev(dev);
766 }
767 mutex_unlock(&cx25821_devlist_mutex);
768
769 if (dev == NULL)
770 pr_info("ERROR ALSA: no cx25821 cards found\n");
771
772 return 0;
773 753
774} 754}
775 755
776late_initcall(cx25821_alsa_init); 756late_initcall(cx25821_alsa_init);
777module_exit(cx25821_audio_fini); 757module_exit(cx25821_audio_fini);
778
779/* ----------------------------------------------------------- */
780/*
781 * Local variables:
782 * c-basic-offset: 8
783 * End:
784 */
diff --git a/drivers/media/pci/cx25821/cx25821-core.c b/drivers/media/pci/cx25821/cx25821-core.c
index 48faf6fc273d..6205ade04a97 100644
--- a/drivers/media/pci/cx25821/cx25821-core.c
+++ b/drivers/media/pci/cx25821/cx25821-core.c
@@ -41,13 +41,6 @@ static unsigned int card[] = {[0 ... (CX25821_MAXBOARDS - 1)] = UNSET };
41module_param_array(card, int, NULL, 0444); 41module_param_array(card, int, NULL, 0444);
42MODULE_PARM_DESC(card, "card type"); 42MODULE_PARM_DESC(card, "card type");
43 43
44static unsigned int cx25821_devcount;
45
46DEFINE_MUTEX(cx25821_devlist_mutex);
47EXPORT_SYMBOL(cx25821_devlist_mutex);
48LIST_HEAD(cx25821_devlist);
49EXPORT_SYMBOL(cx25821_devlist);
50
51const struct sram_channel cx25821_sram_channels[] = { 44const struct sram_channel cx25821_sram_channels[] = {
52 [SRAM_CH00] = { 45 [SRAM_CH00] = {
53 .i = SRAM_CH00, 46 .i = SRAM_CH00,
@@ -871,6 +864,7 @@ static void cx25821_iounmap(struct cx25821_dev *dev)
871 864
872static int cx25821_dev_setup(struct cx25821_dev *dev) 865static int cx25821_dev_setup(struct cx25821_dev *dev)
873{ 866{
867 static unsigned int cx25821_devcount;
874 int i; 868 int i;
875 869
876 pr_info("\n***********************************\n"); 870 pr_info("\n***********************************\n");
@@ -879,15 +873,9 @@ static int cx25821_dev_setup(struct cx25821_dev *dev)
879 873
880 mutex_init(&dev->lock); 874 mutex_init(&dev->lock);
881 875
882 atomic_inc(&dev->refcount);
883
884 dev->nr = ++cx25821_devcount; 876 dev->nr = ++cx25821_devcount;
885 sprintf(dev->name, "cx25821[%d]", dev->nr); 877 sprintf(dev->name, "cx25821[%d]", dev->nr);
886 878
887 mutex_lock(&cx25821_devlist_mutex);
888 list_add_tail(&dev->devlist, &cx25821_devlist);
889 mutex_unlock(&cx25821_devlist_mutex);
890
891 if (dev->pci->device != 0x8210) { 879 if (dev->pci->device != 0x8210) {
892 pr_info("%s(): Exiting. Incorrect Hardware device = 0x%02x\n", 880 pr_info("%s(): Exiting. Incorrect Hardware device = 0x%02x\n",
893 __func__, dev->pci->device); 881 __func__, dev->pci->device);
@@ -1021,9 +1009,6 @@ void cx25821_dev_unregister(struct cx25821_dev *dev)
1021 1009
1022 release_mem_region(dev->base_io_addr, pci_resource_len(dev->pci, 0)); 1010 release_mem_region(dev->base_io_addr, pci_resource_len(dev->pci, 0));
1023 1011
1024 if (!atomic_dec_and_test(&dev->refcount))
1025 return;
1026
1027 for (i = 0; i < MAX_VID_CHANNEL_NUM - 1; i++) { 1012 for (i = 0; i < MAX_VID_CHANNEL_NUM - 1; i++) {
1028 if (i == SRAM_CH08) /* audio channel */ 1013 if (i == SRAM_CH08) /* audio channel */
1029 continue; 1014 continue;
@@ -1414,10 +1399,6 @@ static void cx25821_finidev(struct pci_dev *pci_dev)
1414 if (pci_dev->irq) 1399 if (pci_dev->irq)
1415 free_irq(pci_dev->irq, dev); 1400 free_irq(pci_dev->irq, dev);
1416 1401
1417 mutex_lock(&cx25821_devlist_mutex);
1418 list_del(&dev->devlist);
1419 mutex_unlock(&cx25821_devlist_mutex);
1420
1421 cx25821_dev_unregister(dev); 1402 cx25821_dev_unregister(dev);
1422 v4l2_device_unregister(v4l2_dev); 1403 v4l2_device_unregister(v4l2_dev);
1423 kfree(dev); 1404 kfree(dev);
diff --git a/drivers/media/pci/cx25821/cx25821-video.c b/drivers/media/pci/cx25821/cx25821-video.c
index c418e0d38c24..a9aa09651cab 100644
--- a/drivers/media/pci/cx25821/cx25821-video.c
+++ b/drivers/media/pci/cx25821/cx25821-video.c
@@ -654,45 +654,28 @@ static struct videobuf_queue_ops cx25821_video_qops = {
654static int video_open(struct file *file) 654static int video_open(struct file *file)
655{ 655{
656 struct video_device *vdev = video_devdata(file); 656 struct video_device *vdev = video_devdata(file);
657 struct cx25821_dev *h, *dev = video_drvdata(file); 657 struct cx25821_dev *dev = video_drvdata(file);
658 struct cx25821_fh *fh; 658 struct cx25821_fh *fh;
659 struct list_head *list;
660 int minor = video_devdata(file)->minor;
661 enum v4l2_buf_type type = V4L2_BUF_TYPE_VIDEO_CAPTURE; 659 enum v4l2_buf_type type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
662 u32 pix_format; 660 u32 pix_format;
663 int ch_id = 0; 661 int ch_id;
664 int i;
665 662
666 dprintk(1, "open dev=%s type=%s\n", video_device_node_name(vdev), 663 dprintk(1, "open dev=%s type=%s\n", video_device_node_name(vdev),
667 v4l2_type_names[type]); 664 v4l2_type_names[type]);
668 665
666 for (ch_id = 0; ch_id < MAX_VID_CHANNEL_NUM - 1; ch_id++)
667 if (dev->channels[ch_id].video_dev == vdev)
668 break;
669
670 /* Can't happen */
671 if (ch_id >= MAX_VID_CHANNEL_NUM - 1)
672 return -ENODEV;
673
669 /* allocate + initialize per filehandle data */ 674 /* allocate + initialize per filehandle data */
670 fh = kzalloc(sizeof(*fh), GFP_KERNEL); 675 fh = kzalloc(sizeof(*fh), GFP_KERNEL);
671 if (NULL == fh) 676 if (NULL == fh)
672 return -ENOMEM; 677 return -ENOMEM;
673 678
674 mutex_lock(&cx25821_devlist_mutex);
675
676 list_for_each(list, &cx25821_devlist)
677 {
678 h = list_entry(list, struct cx25821_dev, devlist);
679
680 for (i = 0; i < MAX_VID_CHANNEL_NUM - 1; i++) {
681 if (h->channels[i].video_dev &&
682 h->channels[i].video_dev->minor == minor) {
683 dev = h;
684 ch_id = i;
685 type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
686 }
687 }
688 }
689
690 if (NULL == dev) {
691 mutex_unlock(&cx25821_devlist_mutex);
692 kfree(fh);
693 return -ENODEV;
694 }
695
696 file->private_data = fh; 679 file->private_data = fh;
697 fh->dev = dev; 680 fh->dev = dev;
698 fh->type = type; 681 fh->type = type;
@@ -719,7 +702,6 @@ static int video_open(struct file *file)
719 fh, NULL); 702 fh, NULL);
720 703
721 dprintk(1, "post videobuf_queue_init()\n"); 704 dprintk(1, "post videobuf_queue_init()\n");
722 mutex_unlock(&cx25821_devlist_mutex);
723 705
724 return 0; 706 return 0;
725} 707}
diff --git a/drivers/media/pci/cx25821/cx25821.h b/drivers/media/pci/cx25821/cx25821.h
index d7e71f46defc..195b00407b5a 100644
--- a/drivers/media/pci/cx25821/cx25821.h
+++ b/drivers/media/pci/cx25821/cx25821.h
@@ -238,9 +238,9 @@ struct cx25821_channel {
238 int cif_width; 238 int cif_width;
239}; 239};
240 240
241struct snd_card;
242
241struct cx25821_dev { 243struct cx25821_dev {
242 struct list_head devlist;
243 atomic_t refcount;
244 struct v4l2_device v4l2_dev; 244 struct v4l2_device v4l2_dev;
245 245
246 /* pci stuff */ 246 /* pci stuff */
@@ -252,6 +252,8 @@ struct cx25821_dev {
252 u8 __iomem *bmmio; 252 u8 __iomem *bmmio;
253 int pci_irqmask; 253 int pci_irqmask;
254 int hwrevision; 254 int hwrevision;
255 /* used by cx25821-alsa */
256 struct snd_card *card;
255 257
256 u32 clk_freq; 258 u32 clk_freq;
257 259
@@ -403,9 +405,6 @@ static inline struct cx25821_dev *get_cx25821(struct v4l2_device *v4l2_dev)
403#define cx25821_call_all(dev, o, f, args...) \ 405#define cx25821_call_all(dev, o, f, args...) \
404 v4l2_device_call_all(&dev->v4l2_dev, 0, o, f, ##args) 406 v4l2_device_call_all(&dev->v4l2_dev, 0, o, f, ##args)
405 407
406extern struct list_head cx25821_devlist;
407extern struct mutex cx25821_devlist_mutex;
408
409extern struct cx25821_board cx25821_boards[]; 408extern struct cx25821_board cx25821_boards[];
410extern struct cx25821_subid cx25821_subids[]; 409extern struct cx25821_subid cx25821_subids[];
411 410