Skip to content

Commit bfba8e5

Browse files
Jérôme Glissegregkh
authored andcommitted
mm/thp: fix call to mmu_notifier in set_pmd_migration_entry() v2
Inside set_pmd_migration_entry() we are holding page table locks and thus we can not sleep so we can not call invalidate_range_start/end() So remove call to mmu_notifier_invalidate_range_start/end() because they are call inside the function calling set_pmd_migration_entry() (see try_to_unmap_one()). Link: http://lkml.kernel.org/r/20181012181056.7864-1-jglisse@redhat.com Signed-off-by: Jérôme Glisse <jglisse@redhat.com> Reported-by: Andrea Arcangeli <aarcange@redhat.com> Reviewed-by: Zi Yan <zi.yan@cs.rutgers.edu> Acked-by: Michal Hocko <mhocko@kernel.org> Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: Kirill A. Shutemov <kirill.shutemov@linux.intel.com> Cc: "H. Peter Anvin" <hpa@zytor.com> Cc: Anshuman Khandual <khandual@linux.vnet.ibm.com> Cc: Dave Hansen <dave.hansen@intel.com> Cc: David Nellans <dnellans@nvidia.com> Cc: Ingo Molnar <mingo@elte.hu> Cc: Mel Gorman <mgorman@techsingularity.net> Cc: Minchan Kim <minchan@kernel.org> Cc: Naoya Horiguchi <n-horiguchi@ah.jp.nec.com> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Vlastimil Babka <vbabka@suse.cz> Cc: <stable@vger.kernel.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent 7aa867d commit bfba8e5

File tree

1 file changed

+0
-6
lines changed

1 file changed

+0
-6
lines changed

mm/huge_memory.c

Lines changed: 0 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -2885,9 +2885,6 @@ void set_pmd_migration_entry(struct page_vma_mapped_walk *pvmw,
28852885
if (!(pvmw->pmd && !pvmw->pte))
28862886
return;
28872887

2888-
mmu_notifier_invalidate_range_start(mm, address,
2889-
address + HPAGE_PMD_SIZE);
2890-
28912888
flush_cache_range(vma, address, address + HPAGE_PMD_SIZE);
28922889
pmdval = *pvmw->pmd;
28932890
pmdp_invalidate(vma, address, pvmw->pmd);
@@ -2900,9 +2897,6 @@ void set_pmd_migration_entry(struct page_vma_mapped_walk *pvmw,
29002897
set_pmd_at(mm, address, pvmw->pmd, pmdswp);
29012898
page_remove_rmap(page, true);
29022899
put_page(page);
2903-
2904-
mmu_notifier_invalidate_range_end(mm, address,
2905-
address + HPAGE_PMD_SIZE);
29062900
}
29072901

29082902
void remove_migration_pmd(struct page_vma_mapped_walk *pvmw, struct page *new)

0 commit comments

Comments
 (0)