From: Christoph Lameter Date: Fri, 17 Mar 2006 07:04:07 +0000 (-0800) Subject: [PATCH] fix race in pagevec_strip? X-Git-Tag: v2.6.16~12 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=5b40dc780ed996162f3af8712eb03beb24dcdbef;p=users%2Fhch%2Fdma-mapping.git [PATCH] fix race in pagevec_strip? We can call try_to_release_page() with PagePrivate off and a valid page->mapping This may cause all sorts of trouble for the filesystem *_releasepage() handlers. XFS bombs out in that case. Lock the page before checking for page private. Signed-off-by: Christoph Lameter Cc: Nick Piggin Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds --- diff --git a/mm/swap.c b/mm/swap.c index e9ec06d845e8..b524ea90bddb 100644 --- a/mm/swap.c +++ b/mm/swap.c @@ -393,7 +393,8 @@ void pagevec_strip(struct pagevec *pvec) struct page *page = pvec->pages[i]; if (PagePrivate(page) && !TestSetPageLocked(page)) { - try_to_release_page(page, 0); + if (PagePrivate(page)) + try_to_release_page(page, 0); unlock_page(page); } }