Commit ad897d24 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: kill bch2_dev_bkey_exists() in btree_gc.c

Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 9cadb4ea
...@@ -993,19 +993,25 @@ static int bch2_gc_alloc_start(struct bch_fs *c) ...@@ -993,19 +993,25 @@ static int bch2_gc_alloc_start(struct bch_fs *c)
rcu_assign_pointer(ca->buckets_gc, buckets); rcu_assign_pointer(ca->buckets_gc, buckets);
} }
struct bch_dev *ca = NULL;
int ret = bch2_trans_run(c, int ret = bch2_trans_run(c,
for_each_btree_key(trans, iter, BTREE_ID_alloc, POS_MIN, for_each_btree_key(trans, iter, BTREE_ID_alloc, POS_MIN,
BTREE_ITER_prefetch, k, ({ BTREE_ITER_prefetch, k, ({
struct bch_dev *ca = bch2_dev_bkey_exists(c, k.k->p.inode); ca = bch2_dev_iterate(c, ca, k.k->p.inode);
struct bucket *g = gc_bucket(ca, k.k->p.offset); if (!ca) {
bch2_btree_iter_set_pos(&iter, POS(k.k->p.inode + 1, 0));
continue;
}
struct bch_alloc_v4 a_convert; struct bch_alloc_v4 a_convert;
const struct bch_alloc_v4 *a = bch2_alloc_to_v4(k, &a_convert); const struct bch_alloc_v4 *a = bch2_alloc_to_v4(k, &a_convert);
struct bucket *g = gc_bucket(ca, k.k->p.offset);
g->gen_valid = 1; g->gen_valid = 1;
g->gen = a->gen; g->gen = a->gen;
0; 0;
}))); })));
bch2_dev_put(ca);
bch_err_fn(c, ret); bch_err_fn(c, ret);
return ret; return ret;
} }
...@@ -1254,22 +1260,29 @@ static int gc_btree_gens_key(struct btree_trans *trans, ...@@ -1254,22 +1260,29 @@ static int gc_btree_gens_key(struct btree_trans *trans,
return -EROFS; return -EROFS;
percpu_down_read(&c->mark_lock); percpu_down_read(&c->mark_lock);
rcu_read_lock();
bkey_for_each_ptr(ptrs, ptr) { bkey_for_each_ptr(ptrs, ptr) {
struct bch_dev *ca = bch2_dev_bkey_exists(c, ptr->dev); struct bch_dev *ca = bch2_dev_rcu(c, ptr->dev);
if (!ca)
continue;
if (dev_ptr_stale(ca, ptr) > 16) { if (dev_ptr_stale(ca, ptr) > 16) {
rcu_read_unlock();
percpu_up_read(&c->mark_lock); percpu_up_read(&c->mark_lock);
goto update; goto update;
} }
} }
bkey_for_each_ptr(ptrs, ptr) { bkey_for_each_ptr(ptrs, ptr) {
struct bch_dev *ca = bch2_dev_bkey_exists(c, ptr->dev); struct bch_dev *ca = bch2_dev_rcu(c, ptr->dev);
u8 *gen = &ca->oldest_gen[PTR_BUCKET_NR(ca, ptr)]; if (!ca)
continue;
u8 *gen = &ca->oldest_gen[PTR_BUCKET_NR(ca, ptr)];
if (gen_after(*gen, ptr->gen)) if (gen_after(*gen, ptr->gen))
*gen = ptr->gen; *gen = ptr->gen;
} }
rcu_read_unlock();
percpu_up_read(&c->mark_lock); percpu_up_read(&c->mark_lock);
return 0; return 0;
update: update:
...@@ -1282,10 +1295,9 @@ static int gc_btree_gens_key(struct btree_trans *trans, ...@@ -1282,10 +1295,9 @@ static int gc_btree_gens_key(struct btree_trans *trans,
return 0; return 0;
} }
static int bch2_alloc_write_oldest_gen(struct btree_trans *trans, struct btree_iter *iter, static int bch2_alloc_write_oldest_gen(struct btree_trans *trans, struct bch_dev *ca,
struct bkey_s_c k) struct btree_iter *iter, struct bkey_s_c k)
{ {
struct bch_dev *ca = bch2_dev_bkey_exists(trans->c, iter->pos.inode);
struct bch_alloc_v4 a_convert; struct bch_alloc_v4 a_convert;
const struct bch_alloc_v4 *a = bch2_alloc_to_v4(k, &a_convert); const struct bch_alloc_v4 *a = bch2_alloc_to_v4(k, &a_convert);
struct bkey_i_alloc_v4 *a_mut; struct bkey_i_alloc_v4 *a_mut;
...@@ -1355,14 +1367,23 @@ int bch2_gc_gens(struct bch_fs *c) ...@@ -1355,14 +1367,23 @@ int bch2_gc_gens(struct bch_fs *c)
goto err; goto err;
} }
struct bch_dev *ca = NULL;
ret = bch2_trans_run(c, ret = bch2_trans_run(c,
for_each_btree_key_commit(trans, iter, BTREE_ID_alloc, for_each_btree_key_commit(trans, iter, BTREE_ID_alloc,
POS_MIN, POS_MIN,
BTREE_ITER_prefetch, BTREE_ITER_prefetch,
k, k,
NULL, NULL, NULL, NULL,
BCH_TRANS_COMMIT_no_enospc, BCH_TRANS_COMMIT_no_enospc, ({
bch2_alloc_write_oldest_gen(trans, &iter, k))); ca = bch2_dev_iterate(c, ca, k.k->p.inode);
if (!ca) {
bch2_btree_iter_set_pos(&iter, POS(k.k->p.inode + 1, 0));
continue;
}
bch2_alloc_write_oldest_gen(trans, ca, &iter, k);
})));
bch2_dev_put(ca);
if (ret) if (ret)
goto err; goto err;
......
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