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>

authored by Anand Jain and committed by David Sterba f2c3bec2 59a39919

Changed files
+1 -1
fs
+1 -1
fs/btrfs/dev-replace.c
··· 165 165 */ 166 166 if (btrfs_find_device(fs_info->fs_devices, &args)) { 167 167 btrfs_err(fs_info, 168 - "replace devid present without an active replace item"); 168 + "replace without active item, run 'device scan --forget' on the target device"); 169 169 ret = -EUCLEAN; 170 170 } else { 171 171 dev_replace->srcdev = NULL;