Commit effa24f6 authored by Christoph Hellwig's avatar Christoph Hellwig Committed by David Sterba

btrfs: don't stop integrity writeback too early

extent_write_cache_pages stops writing pages as soon as nr_to_write hits
zero.  That is the right thing for opportunistic writeback, but incorrect
for data integrity writeback, which needs to ensure that no dirty pages
are left in the range.  Thus only stop the writeback for WB_SYNC_NONE
if nr_to_write hits 0.

This is a port of write_cache_pages changes in commit 05fe478d
("mm: write_cache_pages integrity fix").

Note that I've only trigger the problem with other changes to the btrfs
writeback code, but this condition seems worthwhile fixing anyway.

CC: stable@vger.kernel.org # 4.14+
Reviewed-by: default avatarJosef Bacik <josef@toxicpanda.com>
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarDavid Sterba <dsterba@suse.com>
[ updated comment ]
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent fc1f91b9
...@@ -2164,11 +2164,12 @@ static int extent_write_cache_pages(struct address_space *mapping, ...@@ -2164,11 +2164,12 @@ static int extent_write_cache_pages(struct address_space *mapping,
} }
/* /*
* the filesystem may choose to bump up nr_to_write. * The filesystem may choose to bump up nr_to_write.
* We have to make sure to honor the new nr_to_write * We have to make sure to honor the new nr_to_write
* at any time * at any time.
*/ */
nr_to_write_done = wbc->nr_to_write <= 0; nr_to_write_done = (wbc->sync_mode == WB_SYNC_NONE &&
wbc->nr_to_write <= 0);
} }
folio_batch_release(&fbatch); folio_batch_release(&fbatch);
cond_resched(); cond_resched();
......
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