Commit 5b088c1d authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Fix bch2_mark_stripe()

There's no reason not to always recalculate these fields
Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent b88e971e
...@@ -1264,6 +1264,13 @@ static int bch2_mark_stripe(struct bch_fs *c, ...@@ -1264,6 +1264,13 @@ static int bch2_mark_stripe(struct bch_fs *c,
m->algorithm = new_s->algorithm; m->algorithm = new_s->algorithm;
m->nr_blocks = new_s->nr_blocks; m->nr_blocks = new_s->nr_blocks;
m->nr_redundant = new_s->nr_redundant; m->nr_redundant = new_s->nr_redundant;
m->blocks_nonempty = 0;
for (i = 0; i < new_s->nr_blocks; i++) {
m->block_sectors[i] =
stripe_blockcount_get(new_s, i);
m->blocks_nonempty += !!m->block_sectors[i];
}
if (gc && old_s) if (gc && old_s)
update_replicas(c, fs_usage, &m->r.e, update_replicas(c, fs_usage, &m->r.e,
...@@ -1275,17 +1282,6 @@ static int bch2_mark_stripe(struct bch_fs *c, ...@@ -1275,17 +1282,6 @@ static int bch2_mark_stripe(struct bch_fs *c,
update_replicas(c, fs_usage, &m->r.e, update_replicas(c, fs_usage, &m->r.e,
((s64) m->sectors * m->nr_redundant)); ((s64) m->sectors * m->nr_redundant));
/* gc recalculates these fields: */
if (!(flags & BTREE_TRIGGER_GC)) {
m->blocks_nonempty = 0;
for (i = 0; i < new_s->nr_blocks; i++) {
m->block_sectors[i] =
stripe_blockcount_get(new_s, i);
m->blocks_nonempty += !!m->block_sectors[i];
}
}
if (!gc) { if (!gc) {
spin_lock(&c->ec_stripes_heap_lock); spin_lock(&c->ec_stripes_heap_lock);
bch2_stripes_heap_update(c, m, idx); bch2_stripes_heap_update(c, m, idx);
......
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