Commit 784d8d17 authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Improve warning for copygc failing to move data

This will help narrow down which code is at fault when this happens.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 255adc51
...@@ -177,9 +177,12 @@ static int bch2_migrate_index_update(struct bch_write_op *op) ...@@ -177,9 +177,12 @@ static int bch2_migrate_index_update(struct bch_write_op *op)
} }
continue; continue;
nomatch: nomatch:
if (m->ctxt) if (m->ctxt) {
BUG_ON(k.k->p.offset <= iter->pos.offset);
atomic64_inc(&m->ctxt->stats->keys_raced);
atomic64_add(k.k->p.offset - iter->pos.offset, atomic64_add(k.k->p.offset - iter->pos.offset,
&m->ctxt->stats->sectors_raced); &m->ctxt->stats->sectors_raced);
}
atomic_long_inc(&c->extent_migrate_raced); atomic_long_inc(&c->extent_migrate_raced);
trace_move_race(&new->k); trace_move_race(&new->k);
bch2_btree_iter_next_slot(iter); bch2_btree_iter_next_slot(iter);
......
...@@ -8,6 +8,7 @@ struct bch_move_stats { ...@@ -8,6 +8,7 @@ struct bch_move_stats {
struct bpos pos; struct bpos pos;
atomic64_t keys_moved; atomic64_t keys_moved;
atomic64_t keys_raced;
atomic64_t sectors_moved; atomic64_t sectors_moved;
atomic64_t sectors_seen; atomic64_t sectors_seen;
atomic64_t sectors_raced; atomic64_t sectors_raced;
......
...@@ -78,7 +78,17 @@ static bool __copygc_pred(struct bch_dev *ca, ...@@ -78,7 +78,17 @@ static bool __copygc_pred(struct bch_dev *ca,
ssize_t i = eytzinger0_find_le(h->data, h->used, ssize_t i = eytzinger0_find_le(h->data, h->used,
sizeof(h->data[0]), sizeof(h->data[0]),
bucket_offset_cmp, &search); bucket_offset_cmp, &search);
#if 0
/* eytzinger search verify code: */
ssize_t j = -1, k;
for (k = 0; k < h->used; k++)
if (h->data[k].offset <= ptr->offset &&
(j < 0 || h->data[k].offset > h->data[j].offset))
j = k;
BUG_ON(i != j);
#endif
return (i >= 0 && return (i >= 0 &&
ptr->offset < h->data[i].offset + ca->mi.bucket_size && ptr->offset < h->data[i].offset + ca->mi.bucket_size &&
ptr->gen == h->data[i].gen); ptr->gen == h->data[i].gen);
...@@ -203,9 +213,12 @@ static void bch2_copygc(struct bch_fs *c, struct bch_dev *ca) ...@@ -203,9 +213,12 @@ static void bch2_copygc(struct bch_fs *c, struct bch_dev *ca)
if (sectors_not_moved && !ret) if (sectors_not_moved && !ret)
bch_warn_ratelimited(c, bch_warn_ratelimited(c,
"copygc finished but %llu/%llu sectors, %llu/%llu buckets not moved", "copygc finished but %llu/%llu sectors, %llu/%llu buckets not moved (move stats: moved %llu sectors, raced %llu keys, %llu sectors)",
sectors_not_moved, sectors_to_move, sectors_not_moved, sectors_to_move,
buckets_not_moved, buckets_to_move); buckets_not_moved, buckets_to_move,
atomic64_read(&move_stats.sectors_moved),
atomic64_read(&move_stats.keys_raced),
atomic64_read(&move_stats.sectors_raced));
trace_copygc(ca, trace_copygc(ca,
atomic64_read(&move_stats.sectors_moved), sectors_not_moved, atomic64_read(&move_stats.sectors_moved), sectors_not_moved,
......
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