mirror of https://gitee.com/openkylin/linux.git
btrfs: don't clear ret in btrfs_start_dirty_block_groups
If we fail to update a block group item in the loop we'll break, however we'll do btrfs_run_delayed_refs and lose our error value in ret, and thus not clean up properly. Fix this by only running the delayed refs if there was no failure. CC: stable@vger.kernel.org # 4.4+ Reviewed-by: Qu Wenruo <wqu@suse.com> Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com> Signed-off-by: Josef Bacik <josef@toxicpanda.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
parent
fb28610097
commit
34d1eb0e59
|
@ -2669,7 +2669,8 @@ int btrfs_start_dirty_block_groups(struct btrfs_trans_handle *trans)
|
||||||
* Go through delayed refs for all the stuff we've just kicked off
|
* Go through delayed refs for all the stuff we've just kicked off
|
||||||
* and then loop back (just once)
|
* and then loop back (just once)
|
||||||
*/
|
*/
|
||||||
ret = btrfs_run_delayed_refs(trans, 0);
|
if (!ret)
|
||||||
|
ret = btrfs_run_delayed_refs(trans, 0);
|
||||||
if (!ret && loops == 0) {
|
if (!ret && loops == 0) {
|
||||||
loops++;
|
loops++;
|
||||||
spin_lock(&cur_trans->dirty_bgs_lock);
|
spin_lock(&cur_trans->dirty_bgs_lock);
|
||||||
|
|
Loading…
Reference in New Issue