|
@@ -36,6 +36,7 @@ struct wb_writeback_work {
|
|
|
long nr_pages;
|
|
|
struct super_block *sb;
|
|
|
enum writeback_sync_modes sync_mode;
|
|
|
+ unsigned int tagged_writepages:1;
|
|
|
unsigned int for_kupdate:1;
|
|
|
unsigned int range_cyclic:1;
|
|
|
unsigned int for_background:1;
|
|
@@ -650,6 +651,7 @@ static long wb_writeback(struct bdi_writeback *wb,
|
|
|
{
|
|
|
struct writeback_control wbc = {
|
|
|
.sync_mode = work->sync_mode,
|
|
|
+ .tagged_writepages = work->tagged_writepages,
|
|
|
.older_than_this = NULL,
|
|
|
.for_kupdate = work->for_kupdate,
|
|
|
.for_background = work->for_background,
|
|
@@ -657,7 +659,7 @@ static long wb_writeback(struct bdi_writeback *wb,
|
|
|
};
|
|
|
unsigned long oldest_jif;
|
|
|
long wrote = 0;
|
|
|
- long write_chunk;
|
|
|
+ long write_chunk = MAX_WRITEBACK_PAGES;
|
|
|
struct inode *inode;
|
|
|
|
|
|
if (wbc.for_kupdate) {
|
|
@@ -683,9 +685,7 @@ static long wb_writeback(struct bdi_writeback *wb,
|
|
|
* (quickly) tag currently dirty pages
|
|
|
* (maybe slowly) sync all tagged pages
|
|
|
*/
|
|
|
- if (wbc.sync_mode == WB_SYNC_NONE)
|
|
|
- write_chunk = MAX_WRITEBACK_PAGES;
|
|
|
- else
|
|
|
+ if (wbc.sync_mode == WB_SYNC_ALL || wbc.tagged_writepages)
|
|
|
write_chunk = LONG_MAX;
|
|
|
|
|
|
wbc.wb_start = jiffies; /* livelock avoidance */
|
|
@@ -1188,10 +1188,11 @@ void writeback_inodes_sb_nr(struct super_block *sb, unsigned long nr)
|
|
|
{
|
|
|
DECLARE_COMPLETION_ONSTACK(done);
|
|
|
struct wb_writeback_work work = {
|
|
|
- .sb = sb,
|
|
|
- .sync_mode = WB_SYNC_NONE,
|
|
|
- .done = &done,
|
|
|
- .nr_pages = nr,
|
|
|
+ .sb = sb,
|
|
|
+ .sync_mode = WB_SYNC_NONE,
|
|
|
+ .tagged_writepages = 1,
|
|
|
+ .done = &done,
|
|
|
+ .nr_pages = nr,
|
|
|
};
|
|
|
|
|
|
WARN_ON(!rwsem_is_locked(&sb->s_umount));
|