aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mm/hugetlb.c25
1 files changed, 11 insertions, 14 deletions
diff --git a/mm/hugetlb.c b/mm/hugetlb.c
index afa057a1d3fe..b8ce6f450956 100644
--- a/mm/hugetlb.c
+++ b/mm/hugetlb.c
@@ -2331,16 +2331,23 @@ void __unmap_hugepage_range(struct vm_area_struct *vma, unsigned long start,
2331 if (huge_pmd_unshare(mm, &address, ptep)) 2331 if (huge_pmd_unshare(mm, &address, ptep))
2332 continue; 2332 continue;
2333 2333
2334 pte = huge_ptep_get(ptep);
2335 if (huge_pte_none(pte))
2336 continue;
2337
2338 /*
2339 * HWPoisoned hugepage is already unmapped and dropped reference
2340 */
2341 if (unlikely(is_hugetlb_entry_hwpoisoned(pte)))
2342 continue;
2343
2344 page = pte_page(pte);
2334 /* 2345 /*
2335 * If a reference page is supplied, it is because a specific 2346 * If a reference page is supplied, it is because a specific
2336 * page is being unmapped, not a range. Ensure the page we 2347 * page is being unmapped, not a range. Ensure the page we
2337 * are about to unmap is the actual page of interest. 2348 * are about to unmap is the actual page of interest.
2338 */ 2349 */
2339 if (ref_page) { 2350 if (ref_page) {
2340 pte = huge_ptep_get(ptep);
2341 if (huge_pte_none(pte))
2342 continue;
2343 page = pte_page(pte);
2344 if (page != ref_page) 2351 if (page != ref_page)
2345 continue; 2352 continue;
2346 2353
@@ -2353,16 +2360,6 @@ void __unmap_hugepage_range(struct vm_area_struct *vma, unsigned long start,
2353 } 2360 }
2354 2361
2355 pte = huge_ptep_get_and_clear(mm, address, ptep); 2362 pte = huge_ptep_get_and_clear(mm, address, ptep);
2356 if (huge_pte_none(pte))
2357 continue;
2358
2359 /*
2360 * HWPoisoned hugepage is already unmapped and dropped reference
2361 */
2362 if (unlikely(is_hugetlb_entry_hwpoisoned(pte)))
2363 continue;
2364
2365 page = pte_page(pte);
2366 if (pte_dirty(pte)) 2363 if (pte_dirty(pte))
2367 set_page_dirty(page); 2364 set_page_dirty(page);
2368 list_add(&page->lru, &page_list); 2365 list_add(&page->lru, &page_list);