Commit f5d58d0c authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: Fix path where dirent -> subvol missing and we don't fix

Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 64304aaf
...@@ -1765,10 +1765,14 @@ static int check_dirent_to_subvol(struct btree_trans *trans, struct btree_iter * ...@@ -1765,10 +1765,14 @@ static int check_dirent_to_subvol(struct btree_trans *trans, struct btree_iter *
if (ret && !bch2_err_matches(ret, ENOENT)) if (ret && !bch2_err_matches(ret, ENOENT))
return ret; return ret;
if (fsck_err_on(ret, c, dirent_to_missing_subvol, if (ret) {
"dirent points to missing subvolume\n%s", if (fsck_err(c, dirent_to_missing_subvol,
(bch2_bkey_val_to_text(&buf, c, d.s_c), buf.buf))) "dirent points to missing subvolume\n%s",
return __remove_dirent(trans, d.k->p); (bch2_bkey_val_to_text(&buf, c, d.s_c), buf.buf)))
return __remove_dirent(trans, d.k->p);
ret = 0;
goto out;
}
ret = lookup_inode(trans, target_inum, ret = lookup_inode(trans, target_inum,
&subvol_root, &target_snapshot); &subvol_root, &target_snapshot);
...@@ -1790,6 +1794,7 @@ static int check_dirent_to_subvol(struct btree_trans *trans, struct btree_iter * ...@@ -1790,6 +1794,7 @@ static int check_dirent_to_subvol(struct btree_trans *trans, struct btree_iter *
target_snapshot); target_snapshot);
if (ret) if (ret)
return ret; return ret;
out:
err: err:
fsck_err: fsck_err:
printbuf_exit(&buf); printbuf_exit(&buf);
......
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