Commit adf81796 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: journal_replay_entry_early() checks for nonexistent device

Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 13a16dab
...@@ -373,14 +373,17 @@ static int journal_replay_entry_early(struct bch_fs *c, ...@@ -373,14 +373,17 @@ static int journal_replay_entry_early(struct bch_fs *c,
case BCH_JSET_ENTRY_dev_usage: { case BCH_JSET_ENTRY_dev_usage: {
struct jset_entry_dev_usage *u = struct jset_entry_dev_usage *u =
container_of(entry, struct jset_entry_dev_usage, entry); container_of(entry, struct jset_entry_dev_usage, entry);
struct bch_dev *ca = bch2_dev_bkey_exists(c, le32_to_cpu(u->dev)); unsigned nr_types = jset_entry_dev_usage_nr_types(u);
unsigned i, nr_types = jset_entry_dev_usage_nr_types(u);
rcu_read_lock();
for (i = 0; i < min_t(unsigned, nr_types, BCH_DATA_NR); i++) { struct bch_dev *ca = bch2_dev_rcu(c, le32_to_cpu(u->dev));
ca->usage_base->d[i].buckets = le64_to_cpu(u->d[i].buckets); if (ca)
ca->usage_base->d[i].sectors = le64_to_cpu(u->d[i].sectors); for (unsigned i = 0; i < min_t(unsigned, nr_types, BCH_DATA_NR); i++) {
ca->usage_base->d[i].fragmented = le64_to_cpu(u->d[i].fragmented); ca->usage_base->d[i].buckets = le64_to_cpu(u->d[i].buckets);
} ca->usage_base->d[i].sectors = le64_to_cpu(u->d[i].sectors);
ca->usage_base->d[i].fragmented = le64_to_cpu(u->d[i].fragmented);
}
rcu_read_unlock();
break; break;
} }
......
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