Commit 5ed2b641 authored by Stoyan Gaydarov's avatar Stoyan Gaydarov Committed by Mauro Carvalho Chehab

V4L/DVB (11235): changed ioctls to unlocked

Signed-off-by: default avatarStoyan Gaydarov <stoyboyker@gmail.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent cea0213d
...@@ -552,8 +552,10 @@ static int ca_send_message(struct dst_state *state, struct ca_msg *p_ca_message, ...@@ -552,8 +552,10 @@ static int ca_send_message(struct dst_state *state, struct ca_msg *p_ca_message,
return result; return result;
} }
static int dst_ca_ioctl(struct inode *inode, struct file *file, unsigned int cmd, unsigned long ioctl_arg) static long dst_ca_ioctl(struct file *file, unsigned int cmd, unsigned long ioctl_arg)
{ {
lock_kernel();
struct dvb_device* dvbdev = (struct dvb_device*) file->private_data; struct dvb_device* dvbdev = (struct dvb_device*) file->private_data;
struct dst_state* state = (struct dst_state*) dvbdev->priv; struct dst_state* state = (struct dst_state*) dvbdev->priv;
struct ca_slot_info *p_ca_slot_info; struct ca_slot_info *p_ca_slot_info;
...@@ -647,6 +649,7 @@ static int dst_ca_ioctl(struct inode *inode, struct file *file, unsigned int cmd ...@@ -647,6 +649,7 @@ static int dst_ca_ioctl(struct inode *inode, struct file *file, unsigned int cmd
kfree (p_ca_slot_info); kfree (p_ca_slot_info);
kfree (p_ca_caps); kfree (p_ca_caps);
unlock_kernel();
return result; return result;
} }
...@@ -684,7 +687,7 @@ static ssize_t dst_ca_write(struct file *file, const char __user *buffer, size_t ...@@ -684,7 +687,7 @@ static ssize_t dst_ca_write(struct file *file, const char __user *buffer, size_t
static const struct file_operations dst_ca_fops = { static const struct file_operations dst_ca_fops = {
.owner = THIS_MODULE, .owner = THIS_MODULE,
.ioctl = dst_ca_ioctl, .unlocked_ioctl = dst_ca_ioctl,
.open = dst_ca_open, .open = dst_ca_open,
.release = dst_ca_release, .release = dst_ca_release,
.read = dst_ca_read, .read = dst_ca_read,
......
...@@ -673,8 +673,9 @@ static int dabusb_release (struct inode *inode, struct file *file) ...@@ -673,8 +673,9 @@ static int dabusb_release (struct inode *inode, struct file *file)
return 0; return 0;
} }
static int dabusb_ioctl (struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg) static long dabusb_ioctl (struct file *file, unsigned int cmd, unsigned long arg)
{ {
lock_kernel();
pdabusb_t s = (pdabusb_t) file->private_data; pdabusb_t s = (pdabusb_t) file->private_data;
pbulk_transfer_t pbulk; pbulk_transfer_t pbulk;
int ret = 0; int ret = 0;
...@@ -682,13 +683,16 @@ static int dabusb_ioctl (struct inode *inode, struct file *file, unsigned int cm ...@@ -682,13 +683,16 @@ static int dabusb_ioctl (struct inode *inode, struct file *file, unsigned int cm
dbg("dabusb_ioctl"); dbg("dabusb_ioctl");
if (s->remove_pending) if (s->remove_pending) {
unlock_kernel();
return -EIO; return -EIO;
}
mutex_lock(&s->mutex); mutex_lock(&s->mutex);
if (!s->usbdev) { if (!s->usbdev) {
mutex_unlock(&s->mutex); mutex_unlock(&s->mutex);
unlock_kernel();
return -EIO; return -EIO;
} }
...@@ -729,6 +733,7 @@ static int dabusb_ioctl (struct inode *inode, struct file *file, unsigned int cm ...@@ -729,6 +733,7 @@ static int dabusb_ioctl (struct inode *inode, struct file *file, unsigned int cm
break; break;
} }
mutex_unlock(&s->mutex); mutex_unlock(&s->mutex);
unlock_kernel();
return ret; return ret;
} }
...@@ -737,7 +742,7 @@ static const struct file_operations dabusb_fops = ...@@ -737,7 +742,7 @@ static const struct file_operations dabusb_fops =
.owner = THIS_MODULE, .owner = THIS_MODULE,
.llseek = no_llseek, .llseek = no_llseek,
.read = dabusb_read, .read = dabusb_read,
.ioctl = dabusb_ioctl, .unlocked_ioctl = dabusb_ioctl,
.open = dabusb_open, .open = dabusb_open,
.release = dabusb_release, .release = dabusb_release,
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment