diff options
Diffstat (limited to 'mm/hugetlb.c')
-rw-r--r-- | mm/hugetlb.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/mm/hugetlb.c b/mm/hugetlb.c index ad713e2d61bc..7acd12503f73 100644 --- a/mm/hugetlb.c +++ b/mm/hugetlb.c | |||
@@ -576,6 +576,7 @@ static void prep_compound_gigantic_page(struct page *page, unsigned long order) | |||
576 | __SetPageHead(page); | 576 | __SetPageHead(page); |
577 | for (i = 1; i < nr_pages; i++, p = mem_map_next(p, page, i)) { | 577 | for (i = 1; i < nr_pages; i++, p = mem_map_next(p, page, i)) { |
578 | __SetPageTail(p); | 578 | __SetPageTail(p); |
579 | set_page_count(p, 0); | ||
579 | p->first_page = page; | 580 | p->first_page = page; |
580 | } | 581 | } |
581 | } | 582 | } |
@@ -900,7 +901,6 @@ retry: | |||
900 | h->resv_huge_pages += delta; | 901 | h->resv_huge_pages += delta; |
901 | ret = 0; | 902 | ret = 0; |
902 | 903 | ||
903 | spin_unlock(&hugetlb_lock); | ||
904 | /* Free the needed pages to the hugetlb pool */ | 904 | /* Free the needed pages to the hugetlb pool */ |
905 | list_for_each_entry_safe(page, tmp, &surplus_list, lru) { | 905 | list_for_each_entry_safe(page, tmp, &surplus_list, lru) { |
906 | if ((--needed) < 0) | 906 | if ((--needed) < 0) |
@@ -914,6 +914,7 @@ retry: | |||
914 | VM_BUG_ON(page_count(page)); | 914 | VM_BUG_ON(page_count(page)); |
915 | enqueue_huge_page(h, page); | 915 | enqueue_huge_page(h, page); |
916 | } | 916 | } |
917 | spin_unlock(&hugetlb_lock); | ||
917 | 918 | ||
918 | /* Free unnecessary surplus pages to the buddy allocator */ | 919 | /* Free unnecessary surplus pages to the buddy allocator */ |
919 | free: | 920 | free: |
@@ -2422,6 +2423,8 @@ retry_avoidcopy: | |||
2422 | * anon_vma prepared. | 2423 | * anon_vma prepared. |
2423 | */ | 2424 | */ |
2424 | if (unlikely(anon_vma_prepare(vma))) { | 2425 | if (unlikely(anon_vma_prepare(vma))) { |
2426 | page_cache_release(new_page); | ||
2427 | page_cache_release(old_page); | ||
2425 | /* Caller expects lock to be held */ | 2428 | /* Caller expects lock to be held */ |
2426 | spin_lock(&mm->page_table_lock); | 2429 | spin_lock(&mm->page_table_lock); |
2427 | return VM_FAULT_OOM; | 2430 | return VM_FAULT_OOM; |