diff options
author | Kent Overstreet <kent.overstreet@linux.dev> | 2024-03-11 04:00:23 +0100 |
---|---|---|
committer | Kent Overstreet <kent.overstreet@linux.dev> | 2024-03-14 02:22:26 +0100 |
commit | 5d04409a62c322494cca0d0d8fef8b7f2d3bcc3f (patch) | |
tree | d4df9e0da5044b6fb61070761c8794a6402ee9a1 /fs/bcachefs/inode.c | |
parent | bcachefs: Fix order of gc_done passes (diff) | |
download | linux-5d04409a62c322494cca0d0d8fef8b7f2d3bcc3f.tar.xz linux-5d04409a62c322494cca0d0d8fef8b7f2d3bcc3f.zip |
bcachefs: Always flush write buffer in delete_dead_inodes()
Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
Diffstat (limited to '')
-rw-r--r-- | fs/bcachefs/inode.c | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/fs/bcachefs/inode.c b/fs/bcachefs/inode.c index a3139bb66f77..2b5e06770ab3 100644 --- a/fs/bcachefs/inode.c +++ b/fs/bcachefs/inode.c @@ -1181,6 +1181,15 @@ int bch2_delete_dead_inodes(struct bch_fs *c) bool need_another_pass; int ret; again: + /* + * if we ran check_inodes() unlinked inodes will have already been + * cleaned up but the write buffer will be out of sync; therefore we + * alway need a write buffer flush + */ + ret = bch2_btree_write_buffer_flush_sync(trans); + if (ret) + goto err; + need_another_pass = false; /* @@ -1213,12 +1222,8 @@ again: ret; })); - if (!ret && need_another_pass) { - ret = bch2_btree_write_buffer_flush_sync(trans); - if (ret) - goto err; + if (!ret && need_another_pass) goto again; - } err: bch2_trans_put(trans); return ret; |