提交 a8500fc8 编写于 作者: M Michael Lyle 提交者: Jens Axboe

bcache: rearrange writeback main thread ratelimit

The time spent searching for things to write back "counts" for the
actual rate achieved, so don't flush the accumulated rate with each
chunk.

This will maintain better fidelity to user-commanded rates, but it
may slightly increase the burstiness of writeback.  The writeback
lock needs improvement to help mitigate this.
Signed-off-by: NMichael Lyle <mlyle@lyle.org>
Reviewed-by: NKent Overstreet <kent.overstreet@gmail.com>
Signed-off-by: NJens Axboe <axboe@kernel.dk>
上级 e41166c5
...@@ -440,6 +440,8 @@ static int bch_writeback_thread(void *arg) ...@@ -440,6 +440,8 @@ static int bch_writeback_thread(void *arg)
struct cached_dev *dc = arg; struct cached_dev *dc = arg;
bool searched_full_index; bool searched_full_index;
bch_ratelimit_reset(&dc->writeback_rate);
while (!kthread_should_stop()) { while (!kthread_should_stop()) {
down_write(&dc->writeback_lock); down_write(&dc->writeback_lock);
if (!atomic_read(&dc->has_dirty) || if (!atomic_read(&dc->has_dirty) ||
...@@ -467,7 +469,6 @@ static int bch_writeback_thread(void *arg) ...@@ -467,7 +469,6 @@ static int bch_writeback_thread(void *arg)
up_write(&dc->writeback_lock); up_write(&dc->writeback_lock);
bch_ratelimit_reset(&dc->writeback_rate);
read_dirty(dc); read_dirty(dc);
if (searched_full_index) { if (searched_full_index) {
...@@ -477,6 +478,8 @@ static int bch_writeback_thread(void *arg) ...@@ -477,6 +478,8 @@ static int bch_writeback_thread(void *arg)
!kthread_should_stop() && !kthread_should_stop() &&
!test_bit(BCACHE_DEV_DETACHING, &dc->disk.flags)) !test_bit(BCACHE_DEV_DETACHING, &dc->disk.flags))
delay = schedule_timeout_interruptible(delay); delay = schedule_timeout_interruptible(delay);
bch_ratelimit_reset(&dc->writeback_rate);
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册