diff options
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 | } |
