mirror of
https://github.com/lkl/linux.git
synced 2025-12-19 08:03:01 +09:00
mm: lock vma explicitly before doing vm_flags_reset and vm_flags_reset_once
Implicit vma locking inside vm_flags_reset() and vm_flags_reset_once() is not obvious and makes it hard to understand where vma locking is happening. Also in some cases (like in dup_userfaultfd()) vma should be locked earlier than vma_flags modification. To make locking more visible, change these functions to assert that the vma write lock is taken and explicitly lock the vma beforehand. Fix userfaultfd functions which should lock the vma earlier. Link: https://lkml.kernel.org/r/20230804152724.3090321-5-surenb@google.com Suggested-by: Linus Torvalds <torvalds@linuxfoundation.org> Signed-off-by: Suren Baghdasaryan <surenb@google.com> Cc: Jann Horn <jannh@google.com> Cc: Liam R. Howlett <Liam.Howlett@oracle.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
This commit is contained in:
committed by
Andrew Morton
parent
e727bfd5e7
commit
60081bf19b
@@ -774,18 +774,22 @@ static inline void vm_flags_init(struct vm_area_struct *vma,
|
||||
ACCESS_PRIVATE(vma, __vm_flags) = flags;
|
||||
}
|
||||
|
||||
/* Use when VMA is part of the VMA tree and modifications need coordination */
|
||||
/*
|
||||
* Use when VMA is part of the VMA tree and modifications need coordination
|
||||
* Note: vm_flags_reset and vm_flags_reset_once do not lock the vma and
|
||||
* it should be locked explicitly beforehand.
|
||||
*/
|
||||
static inline void vm_flags_reset(struct vm_area_struct *vma,
|
||||
vm_flags_t flags)
|
||||
{
|
||||
vma_start_write(vma);
|
||||
vma_assert_write_locked(vma);
|
||||
vm_flags_init(vma, flags);
|
||||
}
|
||||
|
||||
static inline void vm_flags_reset_once(struct vm_area_struct *vma,
|
||||
vm_flags_t flags)
|
||||
{
|
||||
vma_start_write(vma);
|
||||
vma_assert_write_locked(vma);
|
||||
WRITE_ONCE(ACCESS_PRIVATE(vma, __vm_flags), flags);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user