btrfs: add info when mount fails due to stale replace target
authorAnand Jain <anand.jain@oracle.com>
Fri, 12 Aug 2022 10:32:19 +0000 (18:32 +0800)
committerDavid Sterba <dsterba@suse.com>
Tue, 23 Aug 2022 20:15:21 +0000 (22:15 +0200)
commitf2c3bec215694fb8bc0ef5010f2a758d1906fc2d
tree39bd1d6eca0b5e4998473ec60284b1718047496d
parent59a3991984dbc1fc47e5651a265c5200bd85464e
btrfs: add info when mount fails due to stale replace target

If the replace target device reappears after the suspended replace is
cancelled, it blocks the mount operation as it can't find the matching
replace-item in the metadata. As shown below,

   BTRFS error (device sda5): replace devid present without an active replace item

To overcome this situation, the user can run the command

   btrfs device scan --forget <replace target device>

and try the mount command again. And also, to avoid repeating the issue,
superblock on the devid=0 must be wiped.

   wipefs -a device-path-to-devid=0.

This patch adds some info when this situation occurs.

Reported-by: Samuel Greiner <samuel@balkonien.org>
Link: https://lore.kernel.org/linux-btrfs/b4f62b10-b295-26ea-71f9-9a5c9299d42c@balkonien.org/T/
CC: stable@vger.kernel.org # 5.0+
Signed-off-by: Anand Jain <anand.jain@oracle.com>
Signed-off-by: David Sterba <dsterba@suse.com>
fs/btrfs/dev-replace.c