Skip to content

Commit 9c17a36

Browse files
VMoolagregkh
authored andcommitted
mm: change vmf_anon_prepare() to __vmf_anon_prepare()
commit 2a058ab upstream. Some callers of vmf_anon_prepare() may not want us to release the per-VMA lock ourselves. Rename vmf_anon_prepare() to __vmf_anon_prepare() and let the callers drop the lock when desired. Also, make vmf_anon_prepare() a wrapper that releases the per-VMA lock itself for any callers that don't care. This is in preparation to fix this bug reported by syzbot: https://lore.kernel.org/linux-mm/00000000000067c20b06219fbc26@google.com/ Link: https://lkml.kernel.org/r/20240914194243.245-1-vishal.moola@gmail.com Fixes: 9acad7b ("hugetlb: use vmf_anon_prepare() instead of anon_vma_prepare()") Reported-by: syzbot+2dab93857ee95f2eeb08@syzkaller.appspotmail.com Closes: https://lore.kernel.org/linux-mm/00000000000067c20b06219fbc26@google.com/ Signed-off-by: Vishal Moola (Oracle) <vishal.moola@gmail.com> Cc: Muchun Song <muchun.song@linux.dev> 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 0496611 commit 9c17a36

2 files changed

Lines changed: 13 additions & 6 deletions

File tree

mm/internal.h

Lines changed: 10 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -310,7 +310,16 @@ static inline void wake_throttle_isolated(pg_data_t *pgdat)
310310
wake_up(wqh);
311311
}
312312

313-
vm_fault_t vmf_anon_prepare(struct vm_fault *vmf);
313+
vm_fault_t __vmf_anon_prepare(struct vm_fault *vmf);
314+
static inline vm_fault_t vmf_anon_prepare(struct vm_fault *vmf)
315+
{
316+
vm_fault_t ret = __vmf_anon_prepare(vmf);
317+
318+
if (unlikely(ret & VM_FAULT_RETRY))
319+
vma_end_read(vmf->vma);
320+
return ret;
321+
}
322+
314323
vm_fault_t do_swap_page(struct vm_fault *vmf);
315324
void folio_rotate_reclaimable(struct folio *folio);
316325
bool __folio_end_writeback(struct folio *folio);

mm/memory.c

Lines changed: 3 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -3276,7 +3276,7 @@ static inline vm_fault_t vmf_can_call_fault(const struct vm_fault *vmf)
32763276
}
32773277

32783278
/**
3279-
* vmf_anon_prepare - Prepare to handle an anonymous fault.
3279+
* __vmf_anon_prepare - Prepare to handle an anonymous fault.
32803280
* @vmf: The vm_fault descriptor passed from the fault handler.
32813281
*
32823282
* When preparing to insert an anonymous page into a VMA from a
@@ -3290,18 +3290,16 @@ static inline vm_fault_t vmf_can_call_fault(const struct vm_fault *vmf)
32903290
* Return: 0 if fault handling can proceed. Any other value should be
32913291
* returned to the caller.
32923292
*/
3293-
vm_fault_t vmf_anon_prepare(struct vm_fault *vmf)
3293+
vm_fault_t __vmf_anon_prepare(struct vm_fault *vmf)
32943294
{
32953295
struct vm_area_struct *vma = vmf->vma;
32963296
vm_fault_t ret = 0;
32973297

32983298
if (likely(vma->anon_vma))
32993299
return 0;
33003300
if (vmf->flags & FAULT_FLAG_VMA_LOCK) {
3301-
if (!mmap_read_trylock(vma->vm_mm)) {
3302-
vma_end_read(vma);
3301+
if (!mmap_read_trylock(vma->vm_mm))
33033302
return VM_FAULT_RETRY;
3304-
}
33053303
}
33063304
if (__anon_vma_prepare(vma))
33073305
ret = VM_FAULT_OOM;

0 commit comments

Comments
 (0)