Commit 94af5846 authored by Yafang Shao's avatar Yafang Shao Committed by Jens Axboe

writeback: schedule periodic writeback with sysctl

After disable periodic writeback by writing 0 to
dirty_writeback_centisecs, the handler wb_workfn() will not be
entered again until the dirty background limit reaches or
sync syscall is executed or no enough free memory available or
vmscan is triggered.

So the periodic writeback can't be enabled by writing a non-zero
value to dirty_writeback_centisecs.
As it can be disabled by sysctl, it should be able to enable by
sysctl as well.
Reviewed-by: default avatarJan Kara <jack@suse.cz>
Signed-off-by: default avatarYafang Shao <laoar.shao@gmail.com>
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 4078def8
...@@ -1972,8 +1972,14 @@ bool wb_over_bg_thresh(struct bdi_writeback *wb) ...@@ -1972,8 +1972,14 @@ bool wb_over_bg_thresh(struct bdi_writeback *wb)
int dirty_writeback_centisecs_handler(struct ctl_table *table, int write, int dirty_writeback_centisecs_handler(struct ctl_table *table, int write,
void __user *buffer, size_t *length, loff_t *ppos) void __user *buffer, size_t *length, loff_t *ppos)
{ {
proc_dointvec(table, write, buffer, length, ppos); unsigned int old_interval = dirty_writeback_interval;
return 0; int ret;
ret = proc_dointvec(table, write, buffer, length, ppos);
if (!ret && !old_interval && dirty_writeback_interval)
wakeup_flusher_threads(WB_REASON_PERIODIC);
return ret;
} }
#ifdef CONFIG_BLOCK #ifdef CONFIG_BLOCK
......
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