Commit ea27001e authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: delete duplicated checks in check_dirent_to_subvol()

these were already checked in check_subvol()
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent e539ebb8
...@@ -1713,8 +1713,8 @@ static int check_dirent_target(struct btree_trans *trans, ...@@ -1713,8 +1713,8 @@ static int check_dirent_target(struct btree_trans *trans,
return ret; return ret;
} }
static int check_subvol_dirent(struct btree_trans *trans, struct btree_iter *iter, static int check_dirent_to_subvol(struct btree_trans *trans, struct btree_iter *iter,
struct bkey_s_c_dirent d) struct bkey_s_c_dirent d)
{ {
struct bch_fs *c = trans->c; struct bch_fs *c = trans->c;
struct bch_inode_unpacked subvol_root; struct bch_inode_unpacked subvol_root;
...@@ -1724,7 +1724,7 @@ static int check_subvol_dirent(struct btree_trans *trans, struct btree_iter *ite ...@@ -1724,7 +1724,7 @@ static int check_subvol_dirent(struct btree_trans *trans, struct btree_iter *ite
int ret = 0; int ret = 0;
ret = subvol_lookup(trans, target_subvol, ret = subvol_lookup(trans, target_subvol,
&target_snapshot, &target_inum); &target_snapshot, &target_inum);
if (ret && !bch2_err_matches(ret, ENOENT)) if (ret && !bch2_err_matches(ret, ENOENT))
return ret; return ret;
...@@ -1738,25 +1738,6 @@ static int check_subvol_dirent(struct btree_trans *trans, struct btree_iter *ite ...@@ -1738,25 +1738,6 @@ static int check_subvol_dirent(struct btree_trans *trans, struct btree_iter *ite
if (ret && !bch2_err_matches(ret, ENOENT)) if (ret && !bch2_err_matches(ret, ENOENT))
return ret; return ret;
if (fsck_err_on(ret, c, subvol_to_missing_root,
"subvolume %u points to missing subvolume root %llu",
target_subvol,
target_inum)) {
bch_err(c, "repair not implemented yet");
return -EINVAL;
}
if (fsck_err_on(subvol_root.bi_subvol != target_subvol,
c, subvol_root_wrong_bi_subvol,
"subvol root %llu has wrong bi_subvol field: got %u, should be %u",
target_inum,
subvol_root.bi_subvol, target_subvol)) {
subvol_root.bi_subvol = target_subvol;
ret = __bch2_fsck_write_inode(trans, &subvol_root, target_snapshot);
if (ret)
return ret;
}
ret = check_dirent_target(trans, iter, d, &subvol_root, ret = check_dirent_target(trans, iter, d, &subvol_root,
target_snapshot); target_snapshot);
if (ret) if (ret)
...@@ -1849,7 +1830,7 @@ static int check_dirent(struct btree_trans *trans, struct btree_iter *iter, ...@@ -1849,7 +1830,7 @@ static int check_dirent(struct btree_trans *trans, struct btree_iter *iter,
d = bkey_s_c_to_dirent(k); d = bkey_s_c_to_dirent(k);
if (d.v->d_type == DT_SUBVOL) { if (d.v->d_type == DT_SUBVOL) {
ret = check_subvol_dirent(trans, iter, d); ret = check_dirent_to_subvol(trans, iter, d);
if (ret) if (ret)
goto err; goto err;
} else { } else {
......
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