From: Liam R. Howlett Date: Wed, 20 Jul 2022 02:17:59 +0000 (+0000) Subject: mm/gup: use maple tree navigation instead of linked list X-Git-Tag: howlett/maple/20220816~18 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=aa1d7edc945755b2d489290d600693aff9481545;p=users%2Fjedix%2Flinux-maple.git mm/gup: use maple tree navigation instead of linked list Use find_vma_intersection() to locate the VMAs in __mm_populate() instead of using find_vma() and the linked list. Link: https://lkml.kernel.org/r/20220504011345.662299-36-Liam.Howlett@oracle.com Link: https://lkml.kernel.org/r/20220621204632.3370049-52-Liam.Howlett@oracle.com Link: https://lkml.kernel.org/r/20220720021727.17018-52-Liam.Howlett@oracle.com Signed-off-by: Liam R. Howlett Cc: Catalin Marinas Cc: David Howells Cc: "Matthew Wilcox (Oracle)" Cc: SeongJae Park Cc: Vlastimil Babka Cc: Will Deacon Cc: Davidlohr Bueso Cc: David Hildenbrand Cc: Hulk Robot Cc: Lukas Bulwahn Cc: Sven Schnelle Cc: Yang Yingliang Signed-off-by: Andrew Morton --- diff --git a/mm/gup.c b/mm/gup.c index 732825157430..5745f2adb5cd 100644 --- a/mm/gup.c +++ b/mm/gup.c @@ -1643,10 +1643,11 @@ int __mm_populate(unsigned long start, unsigned long len, int ignore_errors) if (!locked) { locked = 1; mmap_read_lock(mm); - vma = find_vma(mm, nstart); + vma = find_vma_intersection(mm, nstart, end); } else if (nstart >= vma->vm_end) - vma = vma->vm_next; - if (!vma || vma->vm_start >= end) + vma = find_vma_intersection(mm, vma->vm_end, end); + + if (!vma) break; /* * Set [nstart; nend) to intersection of desired address