diff options
author | Miao Xie <miaox@cn.fujitsu.com> | 2014-09-03 15:35:32 +0200 |
---|---|---|
committer | Chris Mason <clm@fb.com> | 2014-09-17 22:38:31 +0200 |
commit | 1c43366d3b3f0fa6c6e81aaf3aa18e0550245dad (patch) | |
tree | e5800ddfd965032bcd139ff4595e64d3868a6a5c /fs/btrfs/volumes.h | |
parent | Btrfs: cleanup double assignment of device->bytes_used when device replace fi... (diff) | |
download | linux-1c43366d3b3f0fa6c6e81aaf3aa18e0550245dad.tar.xz linux-1c43366d3b3f0fa6c6e81aaf3aa18e0550245dad.zip |
Btrfs: fix unprotected assignment of the target device
We didn't protect the assignment of the target device, it might cause the
problem that the super block update was skipped because we might find wrong
size of the target device during the assignment. Fix it by moving the
assignment sentences into the initialization function of the target device.
And there is another merit that we can check if the target device is suitable
more early.
Signed-off-by: Miao Xie <miaox@cn.fujitsu.com>
Signed-off-by: Chris Mason <clm@fb.com>
Diffstat (limited to 'fs/btrfs/volumes.h')
-rw-r--r-- | fs/btrfs/volumes.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/fs/btrfs/volumes.h b/fs/btrfs/volumes.h index 37f8bff97df1..e15f2886d33e 100644 --- a/fs/btrfs/volumes.h +++ b/fs/btrfs/volumes.h @@ -322,6 +322,7 @@ struct btrfs_device *btrfs_find_device(struct btrfs_fs_info *fs_info, u64 devid, int btrfs_shrink_device(struct btrfs_device *device, u64 new_size); int btrfs_init_new_device(struct btrfs_root *root, char *path); int btrfs_init_dev_replace_tgtdev(struct btrfs_root *root, char *device_path, + struct btrfs_device *srcdev, struct btrfs_device **device_out); int btrfs_balance(struct btrfs_balance_control *bctl, struct btrfs_ioctl_balance_args *bargs); |