Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 6606470d authored by Jonathan Corbet's avatar Jonathan Corbet
Browse files

videodev: BKL pushdown



Put explicit lock_kernel() calls into videodev_open().  That function
itself seems OK, but one never knows about all the open() functions
provided by underlying video drivers.

Signed-off-by: default avatarJonathan Corbet <corbet@lwn.net>
parent b5b4aa67
Loading
Loading
Loading
Loading
+4 −0
Original line number Diff line number Diff line
@@ -36,6 +36,7 @@
#include <linux/init.h>
#include <linux/kmod.h>
#include <linux/slab.h>
#include <linux/smp_lock.h>
#include <asm/uaccess.h>
#include <asm/system.h>

@@ -496,6 +497,7 @@ static int video_open(struct inode *inode, struct file *file)

	if(minor>=VIDEO_NUM_DEVICES)
		return -ENODEV;
	lock_kernel();
	mutex_lock(&videodev_lock);
	vfl=video_device[minor];
	if(vfl==NULL) {
@@ -505,6 +507,7 @@ static int video_open(struct inode *inode, struct file *file)
		vfl=video_device[minor];
		if (vfl==NULL) {
			mutex_unlock(&videodev_lock);
			unlock_kernel();
			return -ENODEV;
		}
	}
@@ -518,6 +521,7 @@ static int video_open(struct inode *inode, struct file *file)
	}
	fops_put(old_fops);
	mutex_unlock(&videodev_lock);
	unlock_kernel();
	return err;
}