diff options
Diffstat (limited to 'drivers/block/loop.c')
-rw-r--r-- | drivers/block/loop.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/drivers/block/loop.c b/drivers/block/loop.c index 91797bbbe702..a10c8c9b6b78 100644 --- a/drivers/block/loop.c +++ b/drivers/block/loop.c | |||
@@ -67,7 +67,7 @@ | |||
67 | #include <linux/compat.h> | 67 | #include <linux/compat.h> |
68 | #include <linux/suspend.h> | 68 | #include <linux/suspend.h> |
69 | #include <linux/freezer.h> | 69 | #include <linux/freezer.h> |
70 | #include <linux/smp_lock.h> | 70 | #include <linux/mutex.h> |
71 | #include <linux/writeback.h> | 71 | #include <linux/writeback.h> |
72 | #include <linux/buffer_head.h> /* for invalidate_bdev() */ | 72 | #include <linux/buffer_head.h> /* for invalidate_bdev() */ |
73 | #include <linux/completion.h> | 73 | #include <linux/completion.h> |
@@ -77,6 +77,7 @@ | |||
77 | 77 | ||
78 | #include <asm/uaccess.h> | 78 | #include <asm/uaccess.h> |
79 | 79 | ||
80 | static DEFINE_MUTEX(loop_mutex); | ||
80 | static LIST_HEAD(loop_devices); | 81 | static LIST_HEAD(loop_devices); |
81 | static DEFINE_MUTEX(loop_devices_mutex); | 82 | static DEFINE_MUTEX(loop_devices_mutex); |
82 | 83 | ||
@@ -1409,11 +1410,11 @@ static int lo_open(struct block_device *bdev, fmode_t mode) | |||
1409 | { | 1410 | { |
1410 | struct loop_device *lo = bdev->bd_disk->private_data; | 1411 | struct loop_device *lo = bdev->bd_disk->private_data; |
1411 | 1412 | ||
1412 | lock_kernel(); | 1413 | mutex_lock(&loop_mutex); |
1413 | mutex_lock(&lo->lo_ctl_mutex); | 1414 | mutex_lock(&lo->lo_ctl_mutex); |
1414 | lo->lo_refcnt++; | 1415 | lo->lo_refcnt++; |
1415 | mutex_unlock(&lo->lo_ctl_mutex); | 1416 | mutex_unlock(&lo->lo_ctl_mutex); |
1416 | unlock_kernel(); | 1417 | mutex_unlock(&loop_mutex); |
1417 | 1418 | ||
1418 | return 0; | 1419 | return 0; |
1419 | } | 1420 | } |
@@ -1423,7 +1424,7 @@ static int lo_release(struct gendisk *disk, fmode_t mode) | |||
1423 | struct loop_device *lo = disk->private_data; | 1424 | struct loop_device *lo = disk->private_data; |
1424 | int err; | 1425 | int err; |
1425 | 1426 | ||
1426 | lock_kernel(); | 1427 | mutex_lock(&loop_mutex); |
1427 | mutex_lock(&lo->lo_ctl_mutex); | 1428 | mutex_lock(&lo->lo_ctl_mutex); |
1428 | 1429 | ||
1429 | if (--lo->lo_refcnt) | 1430 | if (--lo->lo_refcnt) |
@@ -1448,7 +1449,7 @@ static int lo_release(struct gendisk *disk, fmode_t mode) | |||
1448 | out: | 1449 | out: |
1449 | mutex_unlock(&lo->lo_ctl_mutex); | 1450 | mutex_unlock(&lo->lo_ctl_mutex); |
1450 | out_unlocked: | 1451 | out_unlocked: |
1451 | lock_kernel(); | 1452 | mutex_unlock(&loop_mutex); |
1452 | return 0; | 1453 | return 0; |
1453 | } | 1454 | } |
1454 | 1455 | ||