2017-03-16 22:18:50 -08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
#ifndef _BCACHEFS_CLOCK_H
|
|
|
|
#define _BCACHEFS_CLOCK_H
|
|
|
|
|
|
|
|
void bch2_io_timer_add(struct io_clock *, struct io_timer *);
|
|
|
|
void bch2_io_timer_del(struct io_clock *, struct io_timer *);
|
2024-06-29 18:08:20 -04:00
|
|
|
void bch2_kthread_io_clock_wait(struct io_clock *, u64, unsigned long);
|
2019-11-07 15:00:08 -05:00
|
|
|
|
2024-06-29 18:08:20 -04:00
|
|
|
void __bch2_increment_clock(struct io_clock *, u64);
|
2019-11-07 15:00:08 -05:00
|
|
|
|
2024-06-29 18:08:20 -04:00
|
|
|
static inline void bch2_increment_clock(struct bch_fs *c, u64 sectors,
|
2019-11-07 15:00:08 -05:00
|
|
|
int rw)
|
|
|
|
{
|
|
|
|
struct io_clock *clock = &c->io_clock[rw];
|
|
|
|
|
|
|
|
if (unlikely(this_cpu_add_return(*clock->pcpu_buf, sectors) >=
|
|
|
|
IO_CLOCK_PCPU_SECTORS))
|
2019-12-19 15:07:51 -05:00
|
|
|
__bch2_increment_clock(clock, this_cpu_xchg(*clock->pcpu_buf, 0));
|
2019-11-07 15:00:08 -05:00
|
|
|
}
|
2017-03-16 22:18:50 -08:00
|
|
|
|
2024-06-29 18:08:20 -04:00
|
|
|
void bch2_io_clock_schedule_timeout(struct io_clock *, u64);
|
2017-03-16 22:18:50 -08:00
|
|
|
|
2020-07-25 17:06:11 -04:00
|
|
|
void bch2_io_timers_to_text(struct printbuf *, struct io_clock *);
|
2019-12-19 15:07:51 -05:00
|
|
|
|
2017-03-16 22:18:50 -08:00
|
|
|
void bch2_io_clock_exit(struct io_clock *);
|
|
|
|
int bch2_io_clock_init(struct io_clock *);
|
|
|
|
|
|
|
|
#endif /* _BCACHEFS_CLOCK_H */
|