Commit 951dd86e authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: Fix iterator leak in check_subvol()

A couple small error handling fixes
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 2a1df873
...@@ -92,34 +92,32 @@ static int check_subvol(struct btree_trans *trans, ...@@ -92,34 +92,32 @@ static int check_subvol(struct btree_trans *trans,
} }
struct bch_inode_unpacked inode; struct bch_inode_unpacked inode;
struct btree_iter inode_iter = {}; ret = bch2_inode_find_by_inum_nowarn_trans(trans,
ret = bch2_inode_peek_nowarn(trans, &inode_iter, &inode,
(subvol_inum) { k.k->p.offset, le64_to_cpu(subvol.v->inode) }, (subvol_inum) { k.k->p.offset, le64_to_cpu(subvol.v->inode) },
0); &inode);
bch2_trans_iter_exit(trans, &inode_iter); if (!ret) {
if (fsck_err_on(inode.bi_subvol != subvol.k->p.offset,
if (ret && !bch2_err_matches(ret, ENOENT)) trans, subvol_root_wrong_bi_subvol,
return ret; "subvol root %llu:%u has wrong bi_subvol field: got %u, should be %llu",
inode.bi_inum, inode.bi_snapshot,
if (fsck_err_on(ret, inode.bi_subvol, subvol.k->p.offset)) {
trans, subvol_to_missing_root, inode.bi_subvol = subvol.k->p.offset;
"subvolume %llu points to missing subvolume root %llu:%u", ret = __bch2_fsck_write_inode(trans, &inode, le32_to_cpu(subvol.v->snapshot));
k.k->p.offset, le64_to_cpu(subvol.v->inode), if (ret)
le32_to_cpu(subvol.v->snapshot))) { goto err;
ret = bch2_subvolume_delete(trans, iter->pos.offset); }
bch_err_msg(c, ret, "deleting subvolume %llu", iter->pos.offset); } else if (bch2_err_matches(ret, ENOENT)) {
return ret ?: -BCH_ERR_transaction_restart_nested; if (fsck_err(trans, subvol_to_missing_root,
} "subvolume %llu points to missing subvolume root %llu:%u",
k.k->p.offset, le64_to_cpu(subvol.v->inode),
if (fsck_err_on(inode.bi_subvol != subvol.k->p.offset, le32_to_cpu(subvol.v->snapshot))) {
trans, subvol_root_wrong_bi_subvol, ret = bch2_subvolume_delete(trans, iter->pos.offset);
"subvol root %llu:%u has wrong bi_subvol field: got %u, should be %llu", bch_err_msg(c, ret, "deleting subvolume %llu", iter->pos.offset);
inode.bi_inum, inode_iter.k.p.snapshot, ret = ret ?: -BCH_ERR_transaction_restart_nested;
inode.bi_subvol, subvol.k->p.offset)) {
inode.bi_subvol = subvol.k->p.offset;
ret = __bch2_fsck_write_inode(trans, &inode, le32_to_cpu(subvol.v->snapshot));
if (ret)
goto err; goto err;
}
} else {
goto err;
} }
if (!BCH_SUBVOLUME_SNAP(subvol.v)) { if (!BCH_SUBVOLUME_SNAP(subvol.v)) {
...@@ -137,7 +135,7 @@ static int check_subvol(struct btree_trans *trans, ...@@ -137,7 +135,7 @@ static int check_subvol(struct btree_trans *trans,
"%s: snapshot tree %u not found", __func__, snapshot_tree); "%s: snapshot tree %u not found", __func__, snapshot_tree);
if (ret) if (ret)
return ret; goto err;
if (fsck_err_on(le32_to_cpu(st.master_subvol) != subvol.k->p.offset, if (fsck_err_on(le32_to_cpu(st.master_subvol) != subvol.k->p.offset,
trans, subvol_not_master_and_not_snapshot, trans, subvol_not_master_and_not_snapshot,
...@@ -147,7 +145,7 @@ static int check_subvol(struct btree_trans *trans, ...@@ -147,7 +145,7 @@ static int check_subvol(struct btree_trans *trans,
bch2_bkey_make_mut_typed(trans, iter, &subvol.s_c, 0, subvolume); bch2_bkey_make_mut_typed(trans, iter, &subvol.s_c, 0, subvolume);
ret = PTR_ERR_OR_ZERO(s); ret = PTR_ERR_OR_ZERO(s);
if (ret) if (ret)
return ret; goto err;
SET_BCH_SUBVOLUME_SNAP(&s->v, true); SET_BCH_SUBVOLUME_SNAP(&s->v, true);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment