Skip to content

Commit

Permalink
Revert "writeback: ensure that WB_SYNC_NONE writeback with sb pinned …
Browse files Browse the repository at this point in the history
…is sync"

This reverts commit 7c8a355.

We are investigating a hang associated with the WB_SYNC_NONE changes,
so revert them for now.

Signed-off-by: Jens Axboe <[email protected]>
  • Loading branch information
Jens Axboe committed Jun 1, 2010
1 parent 0ae0b5d commit f17625b
Showing 1 changed file with 5 additions and 11 deletions.
16 changes: 5 additions & 11 deletions fs/fs-writeback.c
Original file line number Diff line number Diff line change
Expand Up @@ -193,8 +193,7 @@ static void bdi_wait_on_work_clear(struct bdi_work *work)
}

static void bdi_alloc_queue_work(struct backing_dev_info *bdi,
struct wb_writeback_args *args,
int wait)
struct wb_writeback_args *args)
{
struct bdi_work *work;

Expand All @@ -206,8 +205,6 @@ static void bdi_alloc_queue_work(struct backing_dev_info *bdi,
if (work) {
bdi_work_init(work, args);
bdi_queue_work(bdi, work);
if (wait)
bdi_wait_on_work_clear(work);
} else {
struct bdi_writeback *wb = &bdi->wb;

Expand Down Expand Up @@ -282,7 +279,7 @@ void bdi_start_writeback(struct backing_dev_info *bdi, struct super_block *sb,
args.for_background = 1;
}

bdi_alloc_queue_work(bdi, &args, sb_locked);
bdi_alloc_queue_work(bdi, &args);
}

/*
Expand Down Expand Up @@ -912,21 +909,18 @@ long wb_do_writeback(struct bdi_writeback *wb, int force_wait)

while ((work = get_next_work_item(bdi, wb)) != NULL) {
struct wb_writeback_args args = work->args;
int post_clear;

/*
* Override sync mode, in case we must wait for completion
*/
if (force_wait)
work->args.sync_mode = args.sync_mode = WB_SYNC_ALL;

post_clear = WB_SYNC_ALL || args.sb_pinned;

/*
* If this isn't a data integrity operation, just notify
* that we have seen this work and we are now starting it.
*/
if (!post_clear)
if (args.sync_mode == WB_SYNC_NONE)
wb_clear_pending(wb, work);

wrote += wb_writeback(wb, &args);
Expand All @@ -935,7 +929,7 @@ long wb_do_writeback(struct bdi_writeback *wb, int force_wait)
* This is a data integrity writeback, so only do the
* notification when we have completed the work.
*/
if (post_clear)
if (args.sync_mode == WB_SYNC_ALL)
wb_clear_pending(wb, work);
}

Expand Down Expand Up @@ -1011,7 +1005,7 @@ static void bdi_writeback_all(struct super_block *sb, long nr_pages)
if (!bdi_has_dirty_io(bdi))
continue;

bdi_alloc_queue_work(bdi, &args, 0);
bdi_alloc_queue_work(bdi, &args);
}

rcu_read_unlock();
Expand Down

0 comments on commit f17625b

Please sign in to comment.