Commit ac7b19a3 authored by Tejun Heo's avatar Tejun Heo Committed by Jens Axboe

writeback: add wb_writeback_work->auto_free

Currently, a wb_writeback_work is freed automatically on completion if
it doesn't have ->done set.  Add wb_writeback_work->auto_free to make
the switch explicit.  This will help cgroup writeback support where
waiting for completion and whether to free automatically don't
necessarily move together.
Signed-off-by: default avatarTejun Heo <tj@kernel.org>
Cc: Jens Axboe <axboe@kernel.dk>
Cc: Jan Kara <jack@suse.cz>
Signed-off-by: default avatarJens Axboe <axboe@fb.com>
parent 001fe6f6
...@@ -47,6 +47,7 @@ struct wb_writeback_work { ...@@ -47,6 +47,7 @@ struct wb_writeback_work {
unsigned int range_cyclic:1; unsigned int range_cyclic:1;
unsigned int for_background:1; unsigned int for_background:1;
unsigned int for_sync:1; /* sync(2) WB_SYNC_ALL writeback */ unsigned int for_sync:1; /* sync(2) WB_SYNC_ALL writeback */
unsigned int auto_free:1; /* free on completion */
enum wb_reason reason; /* why was writeback initiated? */ enum wb_reason reason; /* why was writeback initiated? */
struct list_head list; /* pending work list */ struct list_head list; /* pending work list */
...@@ -258,6 +259,7 @@ void wb_start_writeback(struct bdi_writeback *wb, long nr_pages, ...@@ -258,6 +259,7 @@ void wb_start_writeback(struct bdi_writeback *wb, long nr_pages,
work->nr_pages = nr_pages; work->nr_pages = nr_pages;
work->range_cyclic = range_cyclic; work->range_cyclic = range_cyclic;
work->reason = reason; work->reason = reason;
work->auto_free = 1;
wb_queue_work(wb, work); wb_queue_work(wb, work);
} }
...@@ -1141,19 +1143,16 @@ static long wb_do_writeback(struct bdi_writeback *wb) ...@@ -1141,19 +1143,16 @@ static long wb_do_writeback(struct bdi_writeback *wb)
set_bit(WB_writeback_running, &wb->state); set_bit(WB_writeback_running, &wb->state);
while ((work = get_next_work_item(wb)) != NULL) { while ((work = get_next_work_item(wb)) != NULL) {
struct completion *done = work->done;
trace_writeback_exec(wb->bdi, work); trace_writeback_exec(wb->bdi, work);
wrote += wb_writeback(wb, work); wrote += wb_writeback(wb, work);
/* if (work->auto_free)
* Notify the caller of completion if this is a synchronous
* work item, otherwise just free it.
*/
if (work->done)
complete(work->done);
else
kfree(work); kfree(work);
if (done)
complete(done);
} }
/* /*
......
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