Commit a2d23f3d authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: io clock: run timer fns under clock lock

We don't have a way to flush a timer that's executing the callback, and
this is simple and limited enough in scope that we can just use the lock
instead.

Needed for the next patch that adds direct wakeups from the allocator to
copygc, where we're now more frequently calling io_timer_del() on an
expiring timer.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent b5cbb42d
...@@ -132,14 +132,9 @@ static struct io_timer *get_expired_timer(struct io_clock *clock, ...@@ -132,14 +132,9 @@ static struct io_timer *get_expired_timer(struct io_clock *clock,
{ {
struct io_timer *ret = NULL; struct io_timer *ret = NULL;
spin_lock(&clock->timer_lock);
if (clock->timers.used && if (clock->timers.used &&
time_after_eq(now, clock->timers.data[0]->expire)) time_after_eq(now, clock->timers.data[0]->expire))
heap_pop(&clock->timers, ret, io_timer_cmp, NULL); heap_pop(&clock->timers, ret, io_timer_cmp, NULL);
spin_unlock(&clock->timer_lock);
return ret; return ret;
} }
...@@ -148,8 +143,10 @@ void __bch2_increment_clock(struct io_clock *clock, unsigned sectors) ...@@ -148,8 +143,10 @@ void __bch2_increment_clock(struct io_clock *clock, unsigned sectors)
struct io_timer *timer; struct io_timer *timer;
unsigned long now = atomic64_add_return(sectors, &clock->now); unsigned long now = atomic64_add_return(sectors, &clock->now);
spin_lock(&clock->timer_lock);
while ((timer = get_expired_timer(clock, now))) while ((timer = get_expired_timer(clock, now)))
timer->fn(timer); timer->fn(timer);
spin_unlock(&clock->timer_lock);
} }
void bch2_io_timers_to_text(struct printbuf *out, struct io_clock *clock) void bch2_io_timers_to_text(struct printbuf *out, struct io_clock *clock)
......
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