|
@@ -1689,10 +1689,16 @@ int zap_huge_pmd(struct mmu_gather *tlb, struct vm_area_struct *vma,
|
|
|
struct page *page = pmd_page(orig_pmd);
|
|
|
page_remove_rmap(page, true);
|
|
|
VM_BUG_ON_PAGE(page_mapcount(page) < 0, page);
|
|
|
- add_mm_counter(tlb->mm, MM_ANONPAGES, -HPAGE_PMD_NR);
|
|
|
VM_BUG_ON_PAGE(!PageHead(page), page);
|
|
|
- pte_free(tlb->mm, pgtable_trans_huge_withdraw(tlb->mm, pmd));
|
|
|
- atomic_long_dec(&tlb->mm->nr_ptes);
|
|
|
+ if (PageAnon(page)) {
|
|
|
+ pgtable_t pgtable;
|
|
|
+ pgtable = pgtable_trans_huge_withdraw(tlb->mm, pmd);
|
|
|
+ pte_free(tlb->mm, pgtable);
|
|
|
+ atomic_long_dec(&tlb->mm->nr_ptes);
|
|
|
+ add_mm_counter(tlb->mm, MM_ANONPAGES, -HPAGE_PMD_NR);
|
|
|
+ } else {
|
|
|
+ add_mm_counter(tlb->mm, MM_FILEPAGES, -HPAGE_PMD_NR);
|
|
|
+ }
|
|
|
spin_unlock(ptl);
|
|
|
tlb_remove_page_size(tlb, page, HPAGE_PMD_SIZE);
|
|
|
}
|