diff options
author | Suren Baghdasaryan <surenb@google.com> | 2023-02-27 18:36:18 +0100 |
---|---|---|
committer | Andrew Morton <akpm@linux-foundation.org> | 2023-04-06 05:02:59 +0200 |
commit | 98e51a2239d9d419d819cd61a2e720ebf19a8b0a (patch) | |
tree | 5db03b809222a234cbf9ff9d0cf69ec277c9697c /mm/internal.h | |
parent | mm: write-lock VMAs before removing them from VMA tree (diff) | |
download | linux-98e51a2239d9d419d819cd61a2e720ebf19a8b0a.tar.xz linux-98e51a2239d9d419d819cd61a2e720ebf19a8b0a.zip |
mm: conditionally write-lock VMA in free_pgtables
Normally free_pgtables needs to lock affected VMAs except for the case
when VMAs were isolated under VMA write-lock. munmap() does just that,
isolating while holding appropriate locks and then downgrading mmap_lock
and dropping per-VMA locks before freeing page tables. Add a parameter to
free_pgtables for such scenario.
Link: https://lkml.kernel.org/r/20230227173632.3292573-20-surenb@google.com
Signed-off-by: Suren Baghdasaryan <surenb@google.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Diffstat (limited to 'mm/internal.h')
-rw-r--r-- | mm/internal.h | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/mm/internal.h b/mm/internal.h index 82ba61d0ed6a..73b167b59cc5 100644 --- a/mm/internal.h +++ b/mm/internal.h @@ -105,7 +105,7 @@ void folio_activate(struct folio *folio); void free_pgtables(struct mmu_gather *tlb, struct maple_tree *mt, struct vm_area_struct *start_vma, unsigned long floor, - unsigned long ceiling); + unsigned long ceiling, bool mm_wr_locked); void pmd_install(struct mm_struct *mm, pmd_t *pmd, pgtable_t *pte); struct zap_details; |