Commit 3e07a730 authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Fix an RCU splat

Writepoints are never deallocated so the rcu_read_lock() isn't really
needed, but we are doing lockless list traversal.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 633632ef
...@@ -683,11 +683,14 @@ static struct write_point *__writepoint_find(struct hlist_head *head, ...@@ -683,11 +683,14 @@ static struct write_point *__writepoint_find(struct hlist_head *head,
{ {
struct write_point *wp; struct write_point *wp;
rcu_read_lock();
hlist_for_each_entry_rcu(wp, head, node) hlist_for_each_entry_rcu(wp, head, node)
if (wp->write_point == write_point) if (wp->write_point == write_point)
return wp; goto out;
wp = NULL;
return NULL; out:
rcu_read_unlock();
return wp;
} }
static inline bool too_many_writepoints(struct bch_fs *c, unsigned factor) static inline bool too_many_writepoints(struct bch_fs *c, unsigned factor)
......
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