[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1201069357.32059.13.camel@sli10-desk.sh.intel.com>
Date: Wed, 23 Jan 2008 14:22:37 +0800
From: Shaohua Li <shaohua.li@...el.com>
To: lkml <linux-kernel@...r.kernel.org>
Cc: Andrew Morton <akpm@...ux-foundation.org>,
clameter <clameter@....com>
Subject: [RFC] some page can't be migrated
Anonymous page might have fs-private metadata, the page is truncated. As
the page hasn't mapping, page migration refuse to migrate the page. It
appears the page is only freed in page reclaim and if zone watermark is
low, the page is never freed, as a result migration always fail. I
thought we could free the metadata so such page can be freed in
migration and make migration more reliable?
Thanks,
Shaohua
diff --git a/mm/migrate.c b/mm/migrate.c
index 6a207e8..6bc38f7 100644
--- a/mm/migrate.c
+++ b/mm/migrate.c
@@ -633,6 +633,17 @@ static int unmap_and_move(new_page_t get_new_page, unsigned long private,
goto unlock;
wait_on_page_writeback(page);
}
+
+ /*
+ * See truncate_complete_page(). Anonymous page might have
+ * fs-private metadata, the page is truncated. Such page can't be
+ * migrated. Try to free metadata, so the page can be freed.
+ */
+ if (!page->mapping && !PageAnon(page) && PagePrivate(page)) {
+ try_to_release_page(page, GFP_KERNEL);
+ goto unlock;
+ }
+
/*
* By try_to_unmap(), page->mapcount goes down to 0 here. In this case,
* we cannot notice that anon_vma is freed while we migrates a page.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists