diff options
-rw-r--r-- | fs/proc/task_mmu.c | 5 | ||||
-rw-r--r-- | mm/memcontrol.c | 4 |
2 files changed, 6 insertions, 3 deletions
diff --git a/fs/proc/task_mmu.c b/fs/proc/task_mmu.c index 9694cc28351..c283832d411 100644 --- a/fs/proc/task_mmu.c +++ b/fs/proc/task_mmu.c | |||
@@ -781,9 +781,6 @@ static int pagemap_pte_range(pmd_t *pmd, unsigned long addr, unsigned long end, | |||
781 | int err = 0; | 781 | int err = 0; |
782 | pagemap_entry_t pme = make_pme(PM_NOT_PRESENT); | 782 | pagemap_entry_t pme = make_pme(PM_NOT_PRESENT); |
783 | 783 | ||
784 | if (pmd_trans_unstable(pmd)) | ||
785 | return 0; | ||
786 | |||
787 | /* find the first VMA at or above 'addr' */ | 784 | /* find the first VMA at or above 'addr' */ |
788 | vma = find_vma(walk->mm, addr); | 785 | vma = find_vma(walk->mm, addr); |
789 | spin_lock(&walk->mm->page_table_lock); | 786 | spin_lock(&walk->mm->page_table_lock); |
@@ -802,6 +799,8 @@ static int pagemap_pte_range(pmd_t *pmd, unsigned long addr, unsigned long end, | |||
802 | return err; | 799 | return err; |
803 | } | 800 | } |
804 | 801 | ||
802 | if (pmd_trans_unstable(pmd)) | ||
803 | return 0; | ||
805 | for (; addr != end; addr += PAGE_SIZE) { | 804 | for (; addr != end; addr += PAGE_SIZE) { |
806 | 805 | ||
807 | /* check to see if we've left 'vma' behind | 806 | /* check to see if we've left 'vma' behind |
diff --git a/mm/memcontrol.c b/mm/memcontrol.c index b2ee6df0e9b..7d698df4a06 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c | |||
@@ -5306,6 +5306,8 @@ static int mem_cgroup_count_precharge_pte_range(pmd_t *pmd, | |||
5306 | return 0; | 5306 | return 0; |
5307 | } | 5307 | } |
5308 | 5308 | ||
5309 | if (pmd_trans_unstable(pmd)) | ||
5310 | return 0; | ||
5309 | pte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl); | 5311 | pte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl); |
5310 | for (; addr != end; pte++, addr += PAGE_SIZE) | 5312 | for (; addr != end; pte++, addr += PAGE_SIZE) |
5311 | if (get_mctgt_type(vma, addr, *pte, NULL)) | 5313 | if (get_mctgt_type(vma, addr, *pte, NULL)) |
@@ -5502,6 +5504,8 @@ static int mem_cgroup_move_charge_pte_range(pmd_t *pmd, | |||
5502 | return 0; | 5504 | return 0; |
5503 | } | 5505 | } |
5504 | 5506 | ||
5507 | if (pmd_trans_unstable(pmd)) | ||
5508 | return 0; | ||
5505 | retry: | 5509 | retry: |
5506 | pte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl); | 5510 | pte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl); |
5507 | for (; addr != end; addr += PAGE_SIZE) { | 5511 | for (; addr != end; addr += PAGE_SIZE) { |