Commit 14a86f75 authored by Nitin Gupta's avatar Nitin Gupta Committed by Greg Kroah-Hartman

sparc64: Fix gup_huge_pmd


[ Upstream commit dbd2667a ]

The function assumes that each PMD points to head of a
huge page. This is not correct as a PMD can point to
start of any 8M region with a, say 256M, hugepage. The
fix ensures that it points to the correct head of any PMD
huge page.

Cc: Julian Calaby <julian.calaby@gmail.com>
Signed-off-by: default avatarNitin Gupta <nitin.m.gupta@oracle.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 7b3b294b
...@@ -78,8 +78,8 @@ static int gup_huge_pmd(pmd_t *pmdp, pmd_t pmd, unsigned long addr, ...@@ -78,8 +78,8 @@ static int gup_huge_pmd(pmd_t *pmdp, pmd_t pmd, unsigned long addr,
return 0; return 0;
refs = 0; refs = 0;
head = pmd_page(pmd); page = pmd_page(pmd) + ((addr & ~PMD_MASK) >> PAGE_SHIFT);
page = head + ((addr & ~PMD_MASK) >> PAGE_SHIFT); head = compound_head(page);
do { do {
VM_BUG_ON(compound_head(page) != head); VM_BUG_ON(compound_head(page) != head);
pages[*nr] = page; pages[*nr] = page;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment