mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-11-24 18:41:00 +07:00
btrfs: add cond_resched() calls when resolving backrefs
Since backref resolution is CPU-intensive, the cond_resched calls should help alleviate soft lockup occurences. Signed-off-by: Edmund Nadolski <enadolski@suse.com> Signed-off-by: Jeff Mahoney <jeffm@suse.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
parent
00142756e1
commit
9dd14fd696
@ -660,6 +660,7 @@ static int resolve_indirect_refs(struct btrfs_fs_info *fs_info,
|
||||
prelim_ref_insert(fs_info, &preftrees->direct, ref);
|
||||
|
||||
ulist_reinit(parents);
|
||||
cond_resched();
|
||||
}
|
||||
out:
|
||||
ulist_free(parents);
|
||||
@ -702,6 +703,7 @@ static int add_missing_keys(struct btrfs_fs_info *fs_info,
|
||||
btrfs_tree_read_unlock(eb);
|
||||
free_extent_buffer(eb);
|
||||
prelim_ref_insert(fs_info, &preftrees->indirect, ref);
|
||||
cond_resched();
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
@ -1243,6 +1245,7 @@ static int find_parent_nodes(struct btrfs_trans_handle *trans,
|
||||
}
|
||||
eie = NULL;
|
||||
}
|
||||
cond_resched();
|
||||
}
|
||||
|
||||
out:
|
||||
|
Loading…
Reference in New Issue
Block a user