diff options
| author | Arnd Bergmann <arnd@arndb.de> | 2010-06-02 08:28:52 -0400 |
|---|---|---|
| committer | Arnd Bergmann <arnd@arndb.de> | 2010-09-15 15:00:45 -0400 |
| commit | c45d15d24eb2b49bf734e1e5e7e103befb76b19b (patch) | |
| tree | dd768c089fd3393e8fa2c4f4fb50cedb1044037d /drivers/scsi/sg.c | |
| parent | 49553c2ef88749dd502687f4eb9c258bb10a4f44 (diff) | |
scsi: autoconvert trivial BKL users to private mutex
All these files use the big kernel lock in a trivial
way to serialize their private file operations,
typically resulting from an earlier semi-automatic
pushdown from VFS.
None of these drivers appears to want to lock against
other code, and they all use the BKL as the top-level
lock in their file operations, meaning that there
is no lock-order inversion problem.
Consequently, we can remove the BKL completely,
replacing it with a per-file mutex in every case.
Using a scripted approach means we can avoid
typos.
file=$1
name=$2
if grep -q lock_kernel ${file} ; then
if grep -q 'include.*linux.mutex.h' ${file} ; then
sed -i '/include.*<linux\/smp_lock.h>/d' ${file}
else
sed -i 's/include.*<linux\/smp_lock.h>.*$/include <linux\/mutex.h>/g' ${file}
fi
sed -i ${file} \
-e "/^#include.*linux.mutex.h/,$ {
1,/^\(static\|int\|long\)/ {
/^\(static\|int\|long\)/istatic DEFINE_MUTEX(${name}_mutex);
} }" \
-e "s/\(un\)*lock_kernel\>[ ]*()/mutex_\1lock(\&${name}_mutex)/g" \
-e '/[ ]*cycle_kernel_lock();/d'
else
sed -i -e '/include.*\<smp_lock.h\>/d' ${file} \
-e '/cycle_kernel_lock()/d'
fi
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Cc: linux-scsi@vger.kernel.org
Cc: "James E.J. Bottomley" <James.Bottomley@suse.de>
Diffstat (limited to 'drivers/scsi/sg.c')
| -rw-r--r-- | drivers/scsi/sg.c | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/drivers/scsi/sg.c b/drivers/scsi/sg.c index 78d616315d8e..b5507d59b5a6 100644 --- a/drivers/scsi/sg.c +++ b/drivers/scsi/sg.c | |||
| @@ -49,7 +49,7 @@ static int sg_version_num = 30534; /* 2 digits for each component */ | |||
| 49 | #include <linux/blkdev.h> | 49 | #include <linux/blkdev.h> |
| 50 | #include <linux/delay.h> | 50 | #include <linux/delay.h> |
| 51 | #include <linux/blktrace_api.h> | 51 | #include <linux/blktrace_api.h> |
| 52 | #include <linux/smp_lock.h> | 52 | #include <linux/mutex.h> |
| 53 | 53 | ||
| 54 | #include "scsi.h" | 54 | #include "scsi.h" |
| 55 | #include <scsi/scsi_dbg.h> | 55 | #include <scsi/scsi_dbg.h> |
| @@ -103,6 +103,8 @@ static int scatter_elem_sz_prev = SG_SCATTER_SZ; | |||
| 103 | static int sg_add(struct device *, struct class_interface *); | 103 | static int sg_add(struct device *, struct class_interface *); |
| 104 | static void sg_remove(struct device *, struct class_interface *); | 104 | static void sg_remove(struct device *, struct class_interface *); |
| 105 | 105 | ||
| 106 | static DEFINE_MUTEX(sg_mutex); | ||
| 107 | |||
| 106 | static DEFINE_IDR(sg_index_idr); | 108 | static DEFINE_IDR(sg_index_idr); |
| 107 | static DEFINE_RWLOCK(sg_index_lock); /* Also used to lock | 109 | static DEFINE_RWLOCK(sg_index_lock); /* Also used to lock |
| 108 | file descriptor list for device */ | 110 | file descriptor list for device */ |
| @@ -229,7 +231,7 @@ sg_open(struct inode *inode, struct file *filp) | |||
| 229 | int res; | 231 | int res; |
| 230 | int retval; | 232 | int retval; |
| 231 | 233 | ||
| 232 | lock_kernel(); | 234 | mutex_lock(&sg_mutex); |
| 233 | nonseekable_open(inode, filp); | 235 | nonseekable_open(inode, filp); |
| 234 | SCSI_LOG_TIMEOUT(3, printk("sg_open: dev=%d, flags=0x%x\n", dev, flags)); | 236 | SCSI_LOG_TIMEOUT(3, printk("sg_open: dev=%d, flags=0x%x\n", dev, flags)); |
| 235 | sdp = sg_get_dev(dev); | 237 | sdp = sg_get_dev(dev); |
| @@ -314,7 +316,7 @@ sdp_put: | |||
| 314 | sg_put: | 316 | sg_put: |
| 315 | if (sdp) | 317 | if (sdp) |
| 316 | sg_put_dev(sdp); | 318 | sg_put_dev(sdp); |
| 317 | unlock_kernel(); | 319 | mutex_unlock(&sg_mutex); |
| 318 | return retval; | 320 | return retval; |
| 319 | } | 321 | } |
| 320 | 322 | ||
| @@ -1092,9 +1094,9 @@ sg_unlocked_ioctl(struct file *filp, unsigned int cmd_in, unsigned long arg) | |||
| 1092 | { | 1094 | { |
| 1093 | int ret; | 1095 | int ret; |
| 1094 | 1096 | ||
| 1095 | lock_kernel(); | 1097 | mutex_lock(&sg_mutex); |
| 1096 | ret = sg_ioctl(filp, cmd_in, arg); | 1098 | ret = sg_ioctl(filp, cmd_in, arg); |
| 1097 | unlock_kernel(); | 1099 | mutex_unlock(&sg_mutex); |
| 1098 | 1100 | ||
| 1099 | return ret; | 1101 | return ret; |
| 1100 | } | 1102 | } |
