Commit 0e8c7d0f authored by Christoph Lameter's avatar Christoph Lameter Committed by Linus Torvalds

page migration: fix NR_FILE_PAGES accounting

NR_FILE_PAGES must be accounted for depending on the zone that the page
belongs to.  If we replace the page in the radix tree then we may have to
shift the count to another zone.
Suggested-by: default avatarEthan Solomita <solo@google.com>
Eventually-typed-in-by: default avatarChristoph Lameter <clameter@sgi.com>
Cc: Martin Bligh <mbligh@mbligh.org>
Cc: <stable@kernel.org>
Signed-off-by: default avatarChristoph Lameter <clameter@sgi.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 10ccaf4b
...@@ -297,7 +297,7 @@ static int migrate_page_move_mapping(struct address_space *mapping, ...@@ -297,7 +297,7 @@ static int migrate_page_move_mapping(struct address_space *mapping,
void **pslot; void **pslot;
if (!mapping) { if (!mapping) {
/* Anonymous page */ /* Anonymous page without mapping */
if (page_count(page) != 1) if (page_count(page) != 1)
return -EAGAIN; return -EAGAIN;
return 0; return 0;
...@@ -333,6 +333,19 @@ static int migrate_page_move_mapping(struct address_space *mapping, ...@@ -333,6 +333,19 @@ static int migrate_page_move_mapping(struct address_space *mapping,
*/ */
__put_page(page); __put_page(page);
/*
* If moved to a different zone then also account
* the page for that zone. Other VM counters will be
* taken care of when we establish references to the
* new page and drop references to the old page.
*
* Note that anonymous pages are accounted for
* via NR_FILE_PAGES and NR_ANON_PAGES if they
* are mapped to swap space.
*/
__dec_zone_page_state(page, NR_FILE_PAGES);
__inc_zone_page_state(newpage, NR_FILE_PAGES);
write_unlock_irq(&mapping->tree_lock); write_unlock_irq(&mapping->tree_lock);
return 0; return 0;
......
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