Commit e7ffda56 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: Fix a quota read bug

bch2_fs_quota_read() could see an inode that's been deleted
(KEY_TYPE_inode_generation) - bch2_fs_quota_read_inode() needs to check
for that instead of erroring.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent c26463ce
...@@ -576,6 +576,13 @@ static int bch2_fs_quota_read_inode(struct btree_trans *trans, ...@@ -576,6 +576,13 @@ static int bch2_fs_quota_read_inode(struct btree_trans *trans,
le32_to_cpu(s_t.master_subvol), le32_to_cpu(s_t.master_subvol),
k.k->p.offset, k.k->p.offset,
}, &u); }, &u);
/*
* Inode might be deleted in this snapshot - the easiest way to handle
* that is to just skip it here:
*/
if (bch2_err_matches(ret, ENOENT))
goto advance;
if (ret) if (ret)
return ret; return ret;
...@@ -615,7 +622,7 @@ int bch2_fs_quota_read(struct bch_fs *c) ...@@ -615,7 +622,7 @@ int bch2_fs_quota_read(struct bch_fs *c)
POS_MIN, BTREE_ITER_PREFETCH|BTREE_ITER_ALL_SNAPSHOTS, k, POS_MIN, BTREE_ITER_PREFETCH|BTREE_ITER_ALL_SNAPSHOTS, k,
bch2_fs_quota_read_inode(&trans, &iter, k)); bch2_fs_quota_read_inode(&trans, &iter, k));
if (ret) if (ret)
bch_err(c, "err in quota_read: %s", bch2_err_str(ret)); bch_err(c, "%s: err %s", __func__, bch2_err_str(ret));
bch2_trans_exit(&trans); bch2_trans_exit(&trans);
return ret; return ret;
......
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