Commit 37b9d1e0 authored by Jörn Engel's avatar Jörn Engel Committed by James Bottomley

[SCSI] sg: remove sg_mutex

With the exception of the detached field, sg_mutex no longer adds any
locking.  detached handling has been broken before and is still broken
and this patch does not seem to make things worse than they were to
begin with.

However, I have observed cases of tasks being blocked for >200s waiting
for sg_mutex.  So the removal clearly adds value for very little cost.
Signed-off-by: default avatarJoern Engel <joern@logfs.org>
Acked-by: default avatarDouglas Gilbert <dgilbert@interlog.com>
Signed-off-by: default avatarJames Bottomley <JBottomley@Parallels.com>
parent 035d12e6
...@@ -104,7 +104,6 @@ static int scatter_elem_sz_prev = SG_SCATTER_SZ; ...@@ -104,7 +104,6 @@ static int scatter_elem_sz_prev = SG_SCATTER_SZ;
static int sg_add(struct device *, struct class_interface *); static int sg_add(struct device *, struct class_interface *);
static void sg_remove(struct device *, struct class_interface *); static void sg_remove(struct device *, struct class_interface *);
static DEFINE_MUTEX(sg_mutex);
static DEFINE_SPINLOCK(sg_open_exclusive_lock); static DEFINE_SPINLOCK(sg_open_exclusive_lock);
static DEFINE_IDR(sg_index_idr); static DEFINE_IDR(sg_index_idr);
...@@ -268,7 +267,6 @@ sg_open(struct inode *inode, struct file *filp) ...@@ -268,7 +267,6 @@ sg_open(struct inode *inode, struct file *filp)
int res; int res;
int retval; int retval;
mutex_lock(&sg_mutex);
nonseekable_open(inode, filp); nonseekable_open(inode, filp);
SCSI_LOG_TIMEOUT(3, printk("sg_open: dev=%d, flags=0x%x\n", dev, flags)); SCSI_LOG_TIMEOUT(3, printk("sg_open: dev=%d, flags=0x%x\n", dev, flags));
sdp = sg_get_dev(dev); sdp = sg_get_dev(dev);
...@@ -350,7 +348,6 @@ sg_open(struct inode *inode, struct file *filp) ...@@ -350,7 +348,6 @@ sg_open(struct inode *inode, struct file *filp)
sg_put: sg_put:
if (sdp) if (sdp)
sg_put_dev(sdp); sg_put_dev(sdp);
mutex_unlock(&sg_mutex);
return retval; return retval;
} }
...@@ -808,7 +805,7 @@ static int srp_done(Sg_fd *sfp, Sg_request *srp) ...@@ -808,7 +805,7 @@ static int srp_done(Sg_fd *sfp, Sg_request *srp)
return ret; return ret;
} }
static int static long
sg_ioctl(struct file *filp, unsigned int cmd_in, unsigned long arg) sg_ioctl(struct file *filp, unsigned int cmd_in, unsigned long arg)
{ {
void __user *p = (void __user *)arg; void __user *p = (void __user *)arg;
...@@ -1118,18 +1115,6 @@ sg_ioctl(struct file *filp, unsigned int cmd_in, unsigned long arg) ...@@ -1118,18 +1115,6 @@ sg_ioctl(struct file *filp, unsigned int cmd_in, unsigned long arg)
} }
} }
static long
sg_unlocked_ioctl(struct file *filp, unsigned int cmd_in, unsigned long arg)
{
int ret;
mutex_lock(&sg_mutex);
ret = sg_ioctl(filp, cmd_in, arg);
mutex_unlock(&sg_mutex);
return ret;
}
#ifdef CONFIG_COMPAT #ifdef CONFIG_COMPAT
static long sg_compat_ioctl(struct file *filp, unsigned int cmd_in, unsigned long arg) static long sg_compat_ioctl(struct file *filp, unsigned int cmd_in, unsigned long arg)
{ {
...@@ -1377,7 +1362,7 @@ static const struct file_operations sg_fops = { ...@@ -1377,7 +1362,7 @@ static const struct file_operations sg_fops = {
.read = sg_read, .read = sg_read,
.write = sg_write, .write = sg_write,
.poll = sg_poll, .poll = sg_poll,
.unlocked_ioctl = sg_unlocked_ioctl, .unlocked_ioctl = sg_ioctl,
#ifdef CONFIG_COMPAT #ifdef CONFIG_COMPAT
.compat_ioctl = sg_compat_ioctl, .compat_ioctl = sg_compat_ioctl,
#endif #endif
......
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