Btrfs: fix mount failure when qgroup rescan is in progress

If a power failure happens while the qgroup rescan kthread is running,
the next mount operation will always fail. This is because of a recent
regression that makes qgroup_rescan_init() incorrectly return -EINVAL
when we are mounting the filesystem (through btrfs_read_qgroup_config()).
This causes the -EINVAL error to be returned regardless of any qgroup
flags being set instead of returning the error only when neither of
the flags BTRFS_QGROUP_STATUS_FLAG_RESCAN nor BTRFS_QGROUP_STATUS_FLAG_ON
are set.

A test case for fstests follows up soon.

Fixes: 9593bf49675e ("btrfs: qgroup: show more meaningful qgroup_rescan_init error message")
Signed-off-by: Filipe Manana <fdmanana@suse.com>
Reviewed-by: Qu Wenruo <wqu@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>

authored by Filipe Manana and committed by David Sterba e4e7ede7 717beb96

+10 -3
+10 -3
fs/btrfs/qgroup.c
··· 2786 2786 2787 2787 if (!init_flags) { 2788 2788 /* we're resuming qgroup rescan at mount time */ 2789 - if (!(fs_info->qgroup_flags & BTRFS_QGROUP_STATUS_FLAG_RESCAN)) 2789 + if (!(fs_info->qgroup_flags & 2790 + BTRFS_QGROUP_STATUS_FLAG_RESCAN)) { 2790 2791 btrfs_warn(fs_info, 2791 2792 "qgroup rescan init failed, qgroup is not enabled"); 2792 - else if (!(fs_info->qgroup_flags & BTRFS_QGROUP_STATUS_FLAG_ON)) 2793 + ret = -EINVAL; 2794 + } else if (!(fs_info->qgroup_flags & 2795 + BTRFS_QGROUP_STATUS_FLAG_ON)) { 2793 2796 btrfs_warn(fs_info, 2794 2797 "qgroup rescan init failed, qgroup rescan is not queued"); 2795 - return -EINVAL; 2798 + ret = -EINVAL; 2799 + } 2800 + 2801 + if (ret) 2802 + return ret; 2796 2803 } 2797 2804 2798 2805 mutex_lock(&fs_info->qgroup_rescan_lock);