@@ -504,7 +504,7 @@ struct super_block *freeze_bdev(struct block_device *bdev)
struct super_block *sb;
int error = 0;
- mutex_lock(&bdev->bd_fsfreeze_mutex);
+ mutex_lock(&bdev->bd_fsfreeze_blktrace_mutex);
if (++bdev->bd_fsfreeze_count > 1) {
/*
* We don't even need to grab a reference - the first call
@@ -514,7 +514,7 @@ struct super_block *freeze_bdev(struct block_device *bdev)
sb = get_super(bdev);
if (sb)
drop_super(sb);
- mutex_unlock(&bdev->bd_fsfreeze_mutex);
+ mutex_unlock(&bdev->bd_fsfreeze_blktrace_mutex);
return sb;
}
@@ -528,13 +528,13 @@ struct super_block *freeze_bdev(struct block_device *bdev)
if (error) {
deactivate_super(sb);
bdev->bd_fsfreeze_count--;
- mutex_unlock(&bdev->bd_fsfreeze_mutex);
+ mutex_unlock(&bdev->bd_fsfreeze_blktrace_mutex);
return ERR_PTR(error);
}
deactivate_super(sb);
out:
sync_blockdev(bdev);
- mutex_unlock(&bdev->bd_fsfreeze_mutex);
+ mutex_unlock(&bdev->bd_fsfreeze_blktrace_mutex);
return sb; /* thaw_bdev releases s->s_umount */
}
EXPORT_SYMBOL(freeze_bdev);
@@ -550,7 +550,7 @@ int thaw_bdev(struct block_device *bdev, struct super_block *sb)
{
int error = -EINVAL;
- mutex_lock(&bdev->bd_fsfreeze_mutex);
+ mutex_lock(&bdev->bd_fsfreeze_blktrace_mutex);
if (!bdev->bd_fsfreeze_count)
goto out;
@@ -568,7 +568,7 @@ int thaw_bdev(struct block_device *bdev, struct super_block *sb)
if (error)
bdev->bd_fsfreeze_count++;
out:
- mutex_unlock(&bdev->bd_fsfreeze_mutex);
+ mutex_unlock(&bdev->bd_fsfreeze_blktrace_mutex);
return error;
}
EXPORT_SYMBOL(thaw_bdev);
@@ -767,7 +767,7 @@ static void init_once(void *foo)
bdev->bd_bdi = &noop_backing_dev_info;
inode_init_once(&ei->vfs_inode);
/* Initialize mutex for freeze. */
- mutex_init(&bdev->bd_fsfreeze_mutex);
+ mutex_init(&bdev->bd_fsfreeze_blktrace_mutex);
}
static void bdev_evict_inode(struct inode *inode)
@@ -1269,14 +1269,14 @@ static struct dentry *gfs2_mount(struct file_system_type *fs_type, int flags,
* will protect the lockfs code from trying to start a snapshot
* while we are mounting
*/
- mutex_lock(&bdev->bd_fsfreeze_mutex);
+ mutex_lock(&bdev->bd_fsfreeze_blktrace_mutex);
if (bdev->bd_fsfreeze_count > 0) {
- mutex_unlock(&bdev->bd_fsfreeze_mutex);
+ mutex_unlock(&bdev->bd_fsfreeze_blktrace_mutex);
error = -EBUSY;
goto error_bdev;
}
s = sget(fs_type, test_gfs2_super, set_gfs2_super, flags, bdev);
- mutex_unlock(&bdev->bd_fsfreeze_mutex);
+ mutex_unlock(&bdev->bd_fsfreeze_blktrace_mutex);
error = PTR_ERR(s);
if (IS_ERR(s))
goto error_bdev;
@@ -1306,15 +1306,15 @@ static int nilfs_test_bdev_super(struct super_block *s, void *data)
* will protect the lockfs code from trying to start a snapshot
* while we are mounting
*/
- mutex_lock(&sd.bdev->bd_fsfreeze_mutex);
+ mutex_lock(&sd.bdev->bd_fsfreeze_blktrace_mutex);
if (sd.bdev->bd_fsfreeze_count > 0) {
- mutex_unlock(&sd.bdev->bd_fsfreeze_mutex);
+ mutex_unlock(&sd.bdev->bd_fsfreeze_blktrace_mutex);
err = -EBUSY;
goto failed;
}
s = sget(fs_type, nilfs_test_bdev_super, nilfs_set_bdev_super, flags,
sd.bdev);
- mutex_unlock(&sd.bdev->bd_fsfreeze_mutex);
+ mutex_unlock(&sd.bdev->bd_fsfreeze_blktrace_mutex);
if (IS_ERR(s)) {
err = PTR_ERR(s);
goto failed;
@@ -1083,15 +1083,15 @@ struct dentry *mount_bdev(struct file_system_type *fs_type,
* will protect the lockfs code from trying to start a snapshot
* while we are mounting
*/
- mutex_lock(&bdev->bd_fsfreeze_mutex);
+ mutex_lock(&bdev->bd_fsfreeze_blktrace_mutex);
if (bdev->bd_fsfreeze_count > 0) {
- mutex_unlock(&bdev->bd_fsfreeze_mutex);
+ mutex_unlock(&bdev->bd_fsfreeze_blktrace_mutex);
error = -EBUSY;
goto error_bdev;
}
s = sget(fs_type, test_bdev_super, set_bdev_super, flags | SB_NOSEC,
bdev);
- mutex_unlock(&bdev->bd_fsfreeze_mutex);
+ mutex_unlock(&bdev->bd_fsfreeze_blktrace_mutex);
if (IS_ERR(s))
goto error_s;
@@ -448,8 +448,9 @@ struct block_device {
/* The counter of freeze processes */
int bd_fsfreeze_count;
- /* Mutex for freeze and blktrace */
- struct mutex bd_fsfreeze_mutex;
+
+ /* Mutex for both freeze and blktrace */
+ struct mutex bd_fsfreeze_blktrace_mutex;
} __randomize_layout;
/*
@@ -656,7 +656,7 @@ int blk_trace_startstop(struct request_queue *q, int start)
* Protection from multiple readers and writers accessing blktrace data
* concurrently is still required. The bd_mutex was used for this purpose.
* That could lead to deadlock with concurrent block device deletion and
- * sysfs access. Instead, the block device bd_fsfreeze_mutex is now
+ * sysfs access. Instead, the block device bd_fsfreeze_blktrace_mutex is now
* overloaded for blktrace data protection. Like freeze/thaw, blktrace
* functionality is not frequently used. There is no point in adding
* one more mutex to the block_device structure just for blktrace.
@@ -679,7 +679,7 @@ int blk_trace_ioctl(struct block_device *bdev, unsigned cmd, char __user *arg)
if (!q)
return -ENXIO;
- mutex_lock(&bdev->bd_fsfreeze_mutex);
+ mutex_lock(&bdev->bd_fsfreeze_blktrace_mutex);
switch (cmd) {
case BLKTRACESETUP:
@@ -705,7 +705,7 @@ int blk_trace_ioctl(struct block_device *bdev, unsigned cmd, char __user *arg)
break;
}
- mutex_unlock(&bdev->bd_fsfreeze_mutex);
+ mutex_unlock(&bdev->bd_fsfreeze_blktrace_mutex);
return ret;
}
@@ -1741,7 +1741,7 @@ static ssize_t sysfs_blk_trace_attr_show(struct device *dev,
if (q == NULL)
goto out_bdput;
- mutex_lock(&bdev->bd_fsfreeze_mutex);
+ mutex_lock(&bdev->bd_fsfreeze_blktrace_mutex);
if (attr == &dev_attr_enable) {
ret = sprintf(buf, "%u\n", !!q->blk_trace);
@@ -1760,7 +1760,7 @@ static ssize_t sysfs_blk_trace_attr_show(struct device *dev,
ret = sprintf(buf, "%llu\n", q->blk_trace->end_lba);
out_unlock_bdev:
- mutex_unlock(&bdev->bd_fsfreeze_mutex);
+ mutex_unlock(&bdev->bd_fsfreeze_blktrace_mutex);
out_bdput:
bdput(bdev);
out:
@@ -1802,7 +1802,7 @@ static ssize_t sysfs_blk_trace_attr_store(struct device *dev,
if (q == NULL)
goto out_bdput;
- mutex_lock(&bdev->bd_fsfreeze_mutex);
+ mutex_lock(&bdev->bd_fsfreeze_blktrace_mutex);
if (attr == &dev_attr_enable) {
if (value)
@@ -1828,7 +1828,7 @@ static ssize_t sysfs_blk_trace_attr_store(struct device *dev,
}
out_unlock_bdev:
- mutex_unlock(&bdev->bd_fsfreeze_mutex);
+ mutex_unlock(&bdev->bd_fsfreeze_blktrace_mutex);
out_bdput:
bdput(bdev);
out:
As the bd_fsfreeze_mutex is used by the blktrace subsystem as well, it is now renamed to bd_fsfreeze_blktrace_mutex to better reflect its purpose. Signed-off-by: Waiman Long <longman@redhat.com> --- fs/block_dev.c | 14 +++++++------- fs/gfs2/ops_fstype.c | 6 +++--- fs/nilfs2/super.c | 6 +++--- fs/super.c | 6 +++--- include/linux/fs.h | 5 +++-- kernel/trace/blktrace.c | 14 +++++++------- 6 files changed, 26 insertions(+), 25 deletions(-)