mirror of https://gitee.com/openkylin/linux.git
btrfs: do proper error handling in merge_reloc_roots
We have a BUG_ON() if we get an error back from btrfs_get_fs_root(). This honestly should never fail, as at this point we have a solid coordination of fs root to reloc root, and these roots will all be in memory. But in the name of killing BUG_ON()'s remove these and handle the error condition properly, ASSERT()'ing for developers. 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
8717cf440d
commit
24213fa46c
|
@ -1969,8 +1969,29 @@ void merge_reloc_roots(struct reloc_control *rc)
|
||||||
root = btrfs_get_fs_root(fs_info, reloc_root->root_key.offset,
|
root = btrfs_get_fs_root(fs_info, reloc_root->root_key.offset,
|
||||||
false);
|
false);
|
||||||
if (btrfs_root_refs(&reloc_root->root_item) > 0) {
|
if (btrfs_root_refs(&reloc_root->root_item) > 0) {
|
||||||
BUG_ON(IS_ERR(root));
|
if (IS_ERR(root)) {
|
||||||
BUG_ON(root->reloc_root != reloc_root);
|
/*
|
||||||
|
* For recovery we read the fs roots on mount,
|
||||||
|
* and if we didn't find the root then we marked
|
||||||
|
* the reloc root as a garbage root. For normal
|
||||||
|
* relocation obviously the root should exist in
|
||||||
|
* memory. However there's no reason we can't
|
||||||
|
* handle the error properly here just in case.
|
||||||
|
*/
|
||||||
|
ASSERT(0);
|
||||||
|
ret = PTR_ERR(root);
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
if (root->reloc_root != reloc_root) {
|
||||||
|
/*
|
||||||
|
* This is actually impossible without something
|
||||||
|
* going really wrong (like weird race condition
|
||||||
|
* or cosmic rays).
|
||||||
|
*/
|
||||||
|
ASSERT(0);
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
ret = merge_reloc_root(rc, root);
|
ret = merge_reloc_root(rc, root);
|
||||||
btrfs_put_root(root);
|
btrfs_put_root(root);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
|
|
Loading…
Reference in New Issue