Commit bf6bddf1924e ("mm: introduce compaction and migration for ballooned 
pages") introduces page_count(page) into memory compaction which 
dereferences page->first_page if PageTail(page).

Introduce a store memory barrier to ensure page->first_page is properly 
initialized so that code that does page_count(page) on pages off the lru 
always have a valid p->first_page.

Reported-by: Holger Kiehl <holger.ki...@dwd.de>
Signed-off-by: David Rientjes <rient...@google.com>
---
 mm/page_alloc.c | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/mm/page_alloc.c b/mm/page_alloc.c
--- a/mm/page_alloc.c
+++ b/mm/page_alloc.c
@@ -369,9 +369,10 @@ void prep_compound_page(struct page *page, unsigned long 
order)
        __SetPageHead(page);
        for (i = 1; i < nr_pages; i++) {
                struct page *p = page + i;
-               __SetPageTail(p);
                set_page_count(p, 0);
                p->first_page = page;
+               smp_wmb();
+               __SetPageTail(p);
        }
 }
 
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to