From 9b277eb21f1f04b96cb0b5860ae2288bd2fcd353 Mon Sep 17 00:00:00 2001 From: David Miller Date: Mon, 8 Oct 2012 16:34:26 -0700 Subject: [PATCH] --- yaml --- r: 332486 b: refs/heads/master c: f5c8ad47284ca01dafc37da5a72bb9644174d387 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/mm/huge_memory.c | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/[refs] b/[refs] index 95e48272da00..5558e66a3b39 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: b113da65785d5f3f9ff1451ec0fe43d6d76da25b +refs/heads/master: f5c8ad47284ca01dafc37da5a72bb9644174d387 diff --git a/trunk/mm/huge_memory.c b/trunk/mm/huge_memory.c index 68a3c93036f6..a863af26c79c 100644 --- a/trunk/mm/huge_memory.c +++ b/trunk/mm/huge_memory.c @@ -1024,9 +1024,10 @@ int zap_huge_pmd(struct mmu_gather *tlb, struct vm_area_struct *vma, if (__pmd_trans_huge_lock(pmd, vma) == 1) { struct page *page; pgtable_t pgtable; + pmd_t orig_pmd; pgtable = pgtable_trans_huge_withdraw(tlb->mm); - page = pmd_page(*pmd); - pmd_clear(pmd); + orig_pmd = pmdp_get_and_clear(tlb->mm, addr, pmd); + page = pmd_page(orig_pmd); tlb_remove_pmd_tlb_entry(tlb, pmd, addr); page_remove_rmap(page); VM_BUG_ON(page_mapcount(page) < 0);