Commit d5482cdf authored by Nick Piggin's avatar Nick Piggin Committed by Linus Torvalds

mm: write_cache_pages terminate quickly

Terminate the write_cache_pages loop upon encountering the first page past
end, without locking the page.  Pages cannot have their index change when
we have a reference on them (truncate, eg truncate_inode_pages_range
performs the same check without the page lock).
Signed-off-by: default avatarNick Piggin <npiggin@suse.de>
Cc: Chris Mason <chris.mason@oracle.com>
Cc: Dave Chinner <david@fromorbit.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 515f4a03
...@@ -911,15 +911,24 @@ int write_cache_pages(struct address_space *mapping, ...@@ -911,15 +911,24 @@ int write_cache_pages(struct address_space *mapping,
for (i = 0; i < nr_pages; i++) { for (i = 0; i < nr_pages; i++) {
struct page *page = pvec.pages[i]; struct page *page = pvec.pages[i];
done_index = page->index + 1;
/* /*
* At this point we hold neither mapping->tree_lock nor * At this point, the page may be truncated or
* lock on the page itself: the page may be truncated or * invalidated (changing page->mapping to NULL), or
* invalidated (changing page->mapping to NULL), or even * even swizzled back from swapper_space to tmpfs file
* swizzled back from swapper_space to tmpfs file * mapping. However, page->index will not change
* mapping * because we have a reference on the page.
*/ */
if (page->index > end) {
/*
* can't be range_cyclic (1st pass) because
* end == -1 in that case.
*/
done = 1;
break;
}
done_index = page->index + 1;
lock_page(page); lock_page(page);
/* /*
...@@ -936,15 +945,6 @@ int write_cache_pages(struct address_space *mapping, ...@@ -936,15 +945,6 @@ int write_cache_pages(struct address_space *mapping,
continue; continue;
} }
if (page->index > end) {
/*
* can't be range_cyclic (1st pass) because
* end == -1 in that case.
*/
done = 1;
goto continue_unlock;
}
if (!PageDirty(page)) { if (!PageDirty(page)) {
/* someone wrote it for us */ /* someone wrote it for us */
goto continue_unlock; goto continue_unlock;
......
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