Commit bc3204c8 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: kill bch2_dev_bkey_exists() in check_alloc_info()

Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent d8585a79
...@@ -960,35 +960,34 @@ static struct bkey_s_c bch2_get_key_or_hole(struct btree_iter *iter, struct bpos ...@@ -960,35 +960,34 @@ static struct bkey_s_c bch2_get_key_or_hole(struct btree_iter *iter, struct bpos
} }
} }
static bool next_bucket(struct bch_fs *c, struct bpos *bucket) static bool next_bucket(struct bch_fs *c, struct bch_dev **ca, struct bpos *bucket)
{ {
struct bch_dev *ca; if (*ca) {
if (bucket->offset < (*ca)->mi.first_bucket)
if (bch2_dev_bucket_exists(c, *bucket)) bucket->offset = (*ca)->mi.first_bucket;
return true;
if (bch2_dev_exists(c, bucket->inode)) { if (bucket->offset < (*ca)->mi.nbuckets)
ca = bch2_dev_bkey_exists(c, bucket->inode);
if (bucket->offset < ca->mi.first_bucket) {
bucket->offset = ca->mi.first_bucket;
return true; return true;
}
bch2_dev_put(*ca);
*ca = NULL;
bucket->inode++; bucket->inode++;
bucket->offset = 0; bucket->offset = 0;
} }
rcu_read_lock(); rcu_read_lock();
ca = __bch2_next_dev_idx(c, bucket->inode, NULL); *ca = __bch2_next_dev_idx(c, bucket->inode, NULL);
if (ca) if (*ca) {
*bucket = POS(ca->dev_idx, ca->mi.first_bucket); *bucket = POS((*ca)->dev_idx, (*ca)->mi.first_bucket);
bch2_dev_get(*ca);
}
rcu_read_unlock(); rcu_read_unlock();
return ca != NULL; return *ca != NULL;
} }
static struct bkey_s_c bch2_get_key_or_real_bucket_hole(struct btree_iter *iter, struct bkey *hole) static struct bkey_s_c bch2_get_key_or_real_bucket_hole(struct btree_iter *iter,
struct bch_dev **ca, struct bkey *hole)
{ {
struct bch_fs *c = iter->trans->c; struct bch_fs *c = iter->trans->c;
struct bkey_s_c k; struct bkey_s_c k;
...@@ -997,22 +996,21 @@ static struct bkey_s_c bch2_get_key_or_real_bucket_hole(struct btree_iter *iter, ...@@ -997,22 +996,21 @@ static struct bkey_s_c bch2_get_key_or_real_bucket_hole(struct btree_iter *iter,
if (bkey_err(k)) if (bkey_err(k))
return k; return k;
*ca = bch2_dev_iterate_noerror(c, *ca, k.k->p.inode);
if (!k.k->type) { if (!k.k->type) {
struct bpos bucket = bkey_start_pos(k.k); struct bpos hole_start = bkey_start_pos(k.k);
if (!bch2_dev_bucket_exists(c, bucket)) { if (!*ca || !bucket_valid(*ca, hole_start.offset)) {
if (!next_bucket(c, &bucket)) if (!next_bucket(c, ca, &hole_start))
return bkey_s_c_null; return bkey_s_c_null;
bch2_btree_iter_set_pos(iter, bucket); bch2_btree_iter_set_pos(iter, hole_start);
goto again; goto again;
} }
if (!bch2_dev_bucket_exists(c, k.k->p)) { if (k.k->p.offset > (*ca)->mi.nbuckets)
struct bch_dev *ca = bch2_dev_bkey_exists(c, bucket.inode); bch2_key_resize(hole, (*ca)->mi.nbuckets - hole_start.offset);
bch2_key_resize(hole, ca->mi.nbuckets - bucket.offset);
}
} }
return k; return k;
...@@ -1154,17 +1152,16 @@ int bch2_check_alloc_key(struct btree_trans *trans, ...@@ -1154,17 +1152,16 @@ int bch2_check_alloc_key(struct btree_trans *trans,
static noinline_for_stack static noinline_for_stack
int bch2_check_alloc_hole_freespace(struct btree_trans *trans, int bch2_check_alloc_hole_freespace(struct btree_trans *trans,
struct bch_dev *ca,
struct bpos start, struct bpos start,
struct bpos *end, struct bpos *end,
struct btree_iter *freespace_iter) struct btree_iter *freespace_iter)
{ {
struct bch_fs *c = trans->c; struct bch_fs *c = trans->c;
struct bch_dev *ca;
struct bkey_s_c k; struct bkey_s_c k;
struct printbuf buf = PRINTBUF; struct printbuf buf = PRINTBUF;
int ret; int ret;
ca = bch2_dev_bkey_exists(c, start.inode);
if (!ca->mi.freespace_initialized) if (!ca->mi.freespace_initialized)
return 0; return 0;
...@@ -1342,30 +1339,25 @@ int bch2_check_bucket_gens_key(struct btree_trans *trans, ...@@ -1342,30 +1339,25 @@ int bch2_check_bucket_gens_key(struct btree_trans *trans,
{ {
struct bch_fs *c = trans->c; struct bch_fs *c = trans->c;
struct bkey_i_bucket_gens g; struct bkey_i_bucket_gens g;
struct bch_dev *ca;
u64 start = bucket_gens_pos_to_alloc(k.k->p, 0).offset; u64 start = bucket_gens_pos_to_alloc(k.k->p, 0).offset;
u64 end = bucket_gens_pos_to_alloc(bpos_nosnap_successor(k.k->p), 0).offset; u64 end = bucket_gens_pos_to_alloc(bpos_nosnap_successor(k.k->p), 0).offset;
u64 b; u64 b;
bool need_update = false, dev_exists; bool need_update = false;
struct printbuf buf = PRINTBUF; struct printbuf buf = PRINTBUF;
int ret = 0; int ret = 0;
BUG_ON(k.k->type != KEY_TYPE_bucket_gens); BUG_ON(k.k->type != KEY_TYPE_bucket_gens);
bkey_reassemble(&g.k_i, k); bkey_reassemble(&g.k_i, k);
/* if no bch_dev, skip out whether we repair or not */ struct bch_dev *ca = bch2_dev_tryget_noerror(c, k.k->p.inode);
dev_exists = bch2_dev_exists(c, k.k->p.inode); if (!ca) {
if (!dev_exists) { if (fsck_err(c, bucket_gens_to_invalid_dev,
if (fsck_err_on(!dev_exists, c,
bucket_gens_to_invalid_dev,
"bucket_gens key for invalid device:\n %s", "bucket_gens key for invalid device:\n %s",
(bch2_bkey_val_to_text(&buf, c, k), buf.buf))) { (bch2_bkey_val_to_text(&buf, c, k), buf.buf)))
ret = bch2_btree_delete_at(trans, iter, 0); ret = bch2_btree_delete_at(trans, iter, 0);
}
goto out; goto out;
} }
ca = bch2_dev_bkey_exists(c, k.k->p.inode);
if (fsck_err_on(end <= ca->mi.first_bucket || if (fsck_err_on(end <= ca->mi.first_bucket ||
start >= ca->mi.nbuckets, c, start >= ca->mi.nbuckets, c,
bucket_gens_to_invalid_buckets, bucket_gens_to_invalid_buckets,
...@@ -1403,6 +1395,7 @@ int bch2_check_bucket_gens_key(struct btree_trans *trans, ...@@ -1403,6 +1395,7 @@ int bch2_check_bucket_gens_key(struct btree_trans *trans,
} }
out: out:
fsck_err: fsck_err:
bch2_dev_put(ca);
printbuf_exit(&buf); printbuf_exit(&buf);
return ret; return ret;
} }
...@@ -1411,6 +1404,7 @@ int bch2_check_alloc_info(struct bch_fs *c) ...@@ -1411,6 +1404,7 @@ int bch2_check_alloc_info(struct bch_fs *c)
{ {
struct btree_trans *trans = bch2_trans_get(c); struct btree_trans *trans = bch2_trans_get(c);
struct btree_iter iter, discard_iter, freespace_iter, bucket_gens_iter; struct btree_iter iter, discard_iter, freespace_iter, bucket_gens_iter;
struct bch_dev *ca = NULL;
struct bkey hole; struct bkey hole;
struct bkey_s_c k; struct bkey_s_c k;
int ret = 0; int ret = 0;
...@@ -1429,7 +1423,7 @@ int bch2_check_alloc_info(struct bch_fs *c) ...@@ -1429,7 +1423,7 @@ int bch2_check_alloc_info(struct bch_fs *c)
bch2_trans_begin(trans); bch2_trans_begin(trans);
k = bch2_get_key_or_real_bucket_hole(&iter, &hole); k = bch2_get_key_or_real_bucket_hole(&iter, &ca, &hole);
ret = bkey_err(k); ret = bkey_err(k);
if (ret) if (ret)
goto bkey_err; goto bkey_err;
...@@ -1450,7 +1444,7 @@ int bch2_check_alloc_info(struct bch_fs *c) ...@@ -1450,7 +1444,7 @@ int bch2_check_alloc_info(struct bch_fs *c)
} else { } else {
next = k.k->p; next = k.k->p;
ret = bch2_check_alloc_hole_freespace(trans, ret = bch2_check_alloc_hole_freespace(trans, ca,
bkey_start_pos(k.k), bkey_start_pos(k.k),
&next, &next,
&freespace_iter) ?: &freespace_iter) ?:
...@@ -1478,6 +1472,8 @@ int bch2_check_alloc_info(struct bch_fs *c) ...@@ -1478,6 +1472,8 @@ int bch2_check_alloc_info(struct bch_fs *c)
bch2_trans_iter_exit(trans, &freespace_iter); bch2_trans_iter_exit(trans, &freespace_iter);
bch2_trans_iter_exit(trans, &discard_iter); bch2_trans_iter_exit(trans, &discard_iter);
bch2_trans_iter_exit(trans, &iter); bch2_trans_iter_exit(trans, &iter);
bch2_dev_put(ca);
ca = NULL;
if (ret < 0) if (ret < 0)
goto err; goto err;
......
...@@ -269,6 +269,14 @@ static inline struct bch_dev *bch2_dev_bucket_tryget(struct bch_fs *c, struct bp ...@@ -269,6 +269,14 @@ static inline struct bch_dev *bch2_dev_bucket_tryget(struct bch_fs *c, struct bp
return ca; return ca;
} }
static inline struct bch_dev *bch2_dev_iterate_noerror(struct bch_fs *c, struct bch_dev *ca, unsigned dev_idx)
{
if (ca && ca->dev_idx == dev_idx)
return ca;
bch2_dev_put(ca);
return bch2_dev_tryget_noerror(c, dev_idx);
}
static inline struct bch_dev *bch2_dev_iterate(struct bch_fs *c, struct bch_dev *ca, unsigned dev_idx) static inline struct bch_dev *bch2_dev_iterate(struct bch_fs *c, struct bch_dev *ca, unsigned dev_idx)
{ {
if (ca && ca->dev_idx == dev_idx) if (ca && ca->dev_idx == dev_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