aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/cx23885/cx23885-video.c
diff options
context:
space:
mode:
authorHans Verkuil <hverkuil@xs4all.nl>2008-07-30 07:43:36 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2008-10-12 07:36:47 -0400
commitd56dc61265d2527a63ab5b0f03199a43cd89ca36 (patch)
treebea2a5b12fc120ca6e8797b2f16ad9696e0f25dd /drivers/media/video/cx23885/cx23885-video.c
parent95f73c5b57990c97047c200b8746ab62a360c5bc (diff)
V4L/DVB (8613): v4l: move BKL down to the driver level.
The BKL is now moved from the video_open function in v4l2-dev.c to the various drivers. It seems about a third of the drivers already has a lock of some sort protecting the open(), another third uses video_exclusive_open (yuck!) and the last third required adding the BKL in their open function. Signed-off-by: Hans Verkuil <hverkuil@xs4all.nl> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video/cx23885/cx23885-video.c')
-rw-r--r--drivers/media/video/cx23885/cx23885-video.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/drivers/media/video/cx23885/cx23885-video.c b/drivers/media/video/cx23885/cx23885-video.c
index 6047c78d84bf..d9bef1a54d1f 100644
--- a/drivers/media/video/cx23885/cx23885-video.c
+++ b/drivers/media/video/cx23885/cx23885-video.c
@@ -731,6 +731,7 @@ static int video_open(struct inode *inode, struct file *file)
731 enum v4l2_buf_type type = 0; 731 enum v4l2_buf_type type = 0;
732 int radio = 0; 732 int radio = 0;
733 733
734 lock_kernel();
734 list_for_each(list, &cx23885_devlist) { 735 list_for_each(list, &cx23885_devlist) {
735 h = list_entry(list, struct cx23885_dev, devlist); 736 h = list_entry(list, struct cx23885_dev, devlist);
736 if (h->video_dev->minor == minor) { 737 if (h->video_dev->minor == minor) {
@@ -748,16 +749,20 @@ static int video_open(struct inode *inode, struct file *file)
748 dev = h; 749 dev = h;
749 } 750 }
750 } 751 }
751 if (NULL == dev) 752 if (NULL == dev) {
753 unlock_kernel();
752 return -ENODEV; 754 return -ENODEV;
755 }
753 756
754 dprintk(1, "open minor=%d radio=%d type=%s\n", 757 dprintk(1, "open minor=%d radio=%d type=%s\n",
755 minor, radio, v4l2_type_names[type]); 758 minor, radio, v4l2_type_names[type]);
756 759
757 /* allocate + initialize per filehandle data */ 760 /* allocate + initialize per filehandle data */
758 fh = kzalloc(sizeof(*fh), GFP_KERNEL); 761 fh = kzalloc(sizeof(*fh), GFP_KERNEL);
759 if (NULL == fh) 762 if (NULL == fh) {
763 unlock_kernel();
760 return -ENOMEM; 764 return -ENOMEM;
765 }
761 file->private_data = fh; 766 file->private_data = fh;
762 fh->dev = dev; 767 fh->dev = dev;
763 fh->radio = radio; 768 fh->radio = radio;
@@ -775,6 +780,7 @@ static int video_open(struct inode *inode, struct file *file)
775 780
776 dprintk(1, "post videobuf_queue_init()\n"); 781 dprintk(1, "post videobuf_queue_init()\n");
777 782
783 unlock_kernel();
778 784
779 return 0; 785 return 0;
780} 786}