|
@@ -343,6 +343,8 @@ static int smaps_pte_range(pmd_t *pmd, unsigned long addr, unsigned long end,
|
|
struct page *page;
|
|
struct page *page;
|
|
int mapcount;
|
|
int mapcount;
|
|
|
|
|
|
|
|
+ split_huge_page_pmd(walk->mm, pmd);
|
|
|
|
+
|
|
pte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl);
|
|
pte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl);
|
|
for (; addr != end; pte++, addr += PAGE_SIZE) {
|
|
for (; addr != end; pte++, addr += PAGE_SIZE) {
|
|
ptent = *pte;
|
|
ptent = *pte;
|
|
@@ -467,6 +469,8 @@ static int clear_refs_pte_range(pmd_t *pmd, unsigned long addr,
|
|
spinlock_t *ptl;
|
|
spinlock_t *ptl;
|
|
struct page *page;
|
|
struct page *page;
|
|
|
|
|
|
|
|
+ split_huge_page_pmd(walk->mm, pmd);
|
|
|
|
+
|
|
pte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl);
|
|
pte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl);
|
|
for (; addr != end; pte++, addr += PAGE_SIZE) {
|
|
for (; addr != end; pte++, addr += PAGE_SIZE) {
|
|
ptent = *pte;
|
|
ptent = *pte;
|
|
@@ -623,6 +627,8 @@ static int pagemap_pte_range(pmd_t *pmd, unsigned long addr, unsigned long end,
|
|
pte_t *pte;
|
|
pte_t *pte;
|
|
int err = 0;
|
|
int err = 0;
|
|
|
|
|
|
|
|
+ split_huge_page_pmd(walk->mm, pmd);
|
|
|
|
+
|
|
/* find the first VMA at or above 'addr' */
|
|
/* find the first VMA at or above 'addr' */
|
|
vma = find_vma(walk->mm, addr);
|
|
vma = find_vma(walk->mm, addr);
|
|
for (; addr != end; addr += PAGE_SIZE) {
|
|
for (; addr != end; addr += PAGE_SIZE) {
|