diff options
author | Nikolay Borisov <nborisov@suse.com> | 2020-01-10 13:11:34 +0100 |
---|---|---|
committer | David Sterba <dsterba@suse.com> | 2020-01-23 17:24:38 +0100 |
commit | 05840710149c7d1a78ea85a2db5723f706e97d8f (patch) | |
tree | 926e216b113647bdc2a5126214718cc9312ef1c1 /sound/mips/hal2.c | |
parent | btrfs: Factor out metadata_uuid code from find_fsid. (diff) | |
download | linux-05840710149c7d1a78ea85a2db5723f706e97d8f.tar.xz linux-05840710149c7d1a78ea85a2db5723f706e97d8f.zip |
btrfs: Handle another split brain scenario with metadata uuid feature
There is one more cases which isn't handled by the original metadata
uuid work. Namely, when a filesystem has METADATA_UUID incompat bit and
the user decides to change the FSID to the original one e.g. have
metadata_uuid and fsid match. In case of power failure while this
operation is in progress we could end up in a situation where some of
the disks have the incompat bit removed and the other half have both
METADATA_UUID_INCOMPAT and FSID_CHANGING_IN_PROGRESS flags.
This patch handles the case where a disk that has successfully changed
its FSID such that it equals METADATA_UUID is scanned first.
Subsequently when a disk with both
METADATA_UUID_INCOMPAT/FSID_CHANGING_IN_PROGRESS flags is scanned
find_fsid_changed won't be able to find an appropriate btrfs_fs_devices.
This is done by extending find_fsid_changed to correctly find
btrfs_fs_devices whose metadata_uuid/fsid are the same and they match
the metadata_uuid of the currently scanned device.
Fixes: cc5de4e70256 ("btrfs: Handle final split-brain possibility during fsid change")
Reviewed-by: Josef Bacik <josef@toxicpanda.com>
Reported-by: Su Yue <Damenly_Su@gmx.com>
Signed-off-by: Nikolay Borisov <nborisov@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'sound/mips/hal2.c')
0 files changed, 0 insertions, 0 deletions