summaryrefslogtreecommitdiffstats
path: root/fs/bcachefs/ec.c
diff options
context:
space:
mode:
authorKent Overstreet <kent.overstreet@linux.dev>2024-04-20 01:03:58 +0200
committerKent Overstreet <kent.overstreet@linux.dev>2024-05-08 23:29:20 +0200
commit70e3e039cf65f67fa3c41b51cb00a58f6cd48886 (patch)
treeceb664bcda1e3abf653a0e2f489aa6c04a3e4f9b /fs/bcachefs/ec.c
parentbcachefs: Consolidate mark_stripe_bucket() and trans_mark_stripe_bucket() (diff)
downloadlinux-70e3e039cf65f67fa3c41b51cb00a58f6cd48886.tar.xz
linux-70e3e039cf65f67fa3c41b51cb00a58f6cd48886.zip
bcachefs: bch2_bucket_ref_update()
If we hit an inconsistency when updating allocation information, we don't want to fail the update if it's for a deletion - only if it's for a new key. Rename check_bucket_ref() -> bucket_ref_update() so we can centralize the logic to do this. Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
Diffstat (limited to '')
-rw-r--r--fs/bcachefs/ec.c14
1 files changed, 7 insertions, 7 deletions
diff --git a/fs/bcachefs/ec.c b/fs/bcachefs/ec.c
index 2d1b20856841..31db3c8fce50 100644
--- a/fs/bcachefs/ec.c
+++ b/fs/bcachefs/ec.c
@@ -243,13 +243,13 @@ static int __mark_stripe_bucket(struct btree_trans *trans,
}
}
- ret = bch2_check_bucket_ref(trans, s.s_c, ptr, sectors, data_type,
- bucket_gen, *bucket_data_type,
- *bucket_dirty_sectors);
- if (ret)
- goto err;
-
- *bucket_dirty_sectors += sectors;
+ if (sectors) {
+ ret = bch2_bucket_ref_update(trans, s.s_c, ptr, sectors, data_type,
+ bucket_gen, *bucket_data_type,
+ bucket_dirty_sectors);
+ if (ret)
+ goto err;
+ }
if (!deleting) {
*bucket_stripe = s.k->p.offset;