diff options
author | Hillf Danton <dhillf@gmail.com> | 2011-10-31 20:09:38 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-10-31 20:30:50 -0400 |
commit | 0089e4853ae1ac161fae5137170971ccb6f4f152 (patch) | |
tree | 6e23993f320cd6b0d45a5fb4832188cd2092efe2 /mm | |
parent | df9d6985be2a7e7683c46e4c6ea608fc69f02b45 (diff) |
mm/huge_memory: fix copying user highpage
The THP copy-on-write handler falls back to regular-sized pages for a huge
page replacement upon allocation failure or if THP has been individually
disabled in the target VMA. The loop responsible for copying page-sized
chunks accidentally uses multiples of PAGE_SHIFT instead of PAGE_SIZE as
the virtual address arg for copy_user_highpage().
Signed-off-by: Hillf Danton <dhillf@gmail.com>
Acked-by: Johannes Weiner <jweiner@redhat.com>
Reviewed-by: Andrea Arcangeli <aarcange@redhat.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm')
-rw-r--r-- | mm/huge_memory.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/mm/huge_memory.c b/mm/huge_memory.c index 44f57631cd7c..ef954384f53a 100644 --- a/mm/huge_memory.c +++ b/mm/huge_memory.c | |||
@@ -830,7 +830,7 @@ static int do_huge_pmd_wp_page_fallback(struct mm_struct *mm, | |||
830 | 830 | ||
831 | for (i = 0; i < HPAGE_PMD_NR; i++) { | 831 | for (i = 0; i < HPAGE_PMD_NR; i++) { |
832 | copy_user_highpage(pages[i], page + i, | 832 | copy_user_highpage(pages[i], page + i, |
833 | haddr + PAGE_SHIFT*i, vma); | 833 | haddr + PAGE_SIZE * i, vma); |
834 | __SetPageUptodate(pages[i]); | 834 | __SetPageUptodate(pages[i]); |
835 | cond_resched(); | 835 | cond_resched(); |
836 | } | 836 | } |