thp: decrement refcount on huge zero page if it is split
authorKirill A. Shutemov <kirill.shutemov@linux.intel.com>
Tue, 8 Sep 2015 21:59:28 +0000 (14:59 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Tue, 8 Sep 2015 22:35:28 +0000 (15:35 -0700)
The DAX code neglected to put the refcount on the huge zero page.
Also we must notify on splits.

Signed-off-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
Signed-off-by: Matthew Wilcox <willy@linux.intel.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
mm/huge_memory.c

index 5df0d1597c15efec46df5835fb6b6d0c04fd30a7..7510b6f683e9799bc2a773414f8c5606c179f69b 100644 (file)
@@ -2978,7 +2978,9 @@ again:
        if (unlikely(!pmd_trans_huge(*pmd)))
                goto unlock;
        if (vma_is_dax(vma)) {
-               pmdp_huge_clear_flush(vma, haddr, pmd);
+               pmd_t _pmd = pmdp_huge_clear_flush_notify(vma, haddr, pmd);
+               if (is_huge_zero_pmd(_pmd))
+                       put_huge_zero_page();
        } else if (is_huge_zero_pmd(*pmd)) {
                __split_huge_zero_page_pmd(vma, haddr, pmd);
        } else {