mm: replace vma prio_tree with an interval tree
Implement an interval tree as a replacement for the VMA prio_tree. The algorithms are similar to lib/interval_tree.c; however that code can't be directly reused as the interval endpoints are not explicitly stored in the VMA. So instead, the common algorithm is moved into a template and the details (node type, how to get interval endpoints from the node, etc) are filled in using the C preprocessor. Once the interval tree functions are available, using them as a replacement to the VMA prio tree is a relatively simple, mechanical job. Signed-off-by:Michel Lespinasse <walken@google.com> Cc: Rik van Riel <riel@redhat.com> Cc: Hillf Danton <dhillf@gmail.com> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Catalin Marinas <catalin.marinas@arm.com> Cc: Andrea Arcangeli <aarcange@redhat.com> Cc: David Woodhouse <dwmw2@infradead.org> Signed-off-by:
Andrew Morton <akpm@linux-foundation.org> Signed-off-by:
Linus Torvalds <torvalds@linux-foundation.org>
Showing
- arch/arm/mm/fault-armv.c 1 addition, 2 deletionsarch/arm/mm/fault-armv.c
- arch/arm/mm/flush.c 1 addition, 2 deletionsarch/arm/mm/flush.c
- arch/parisc/kernel/cache.c 1 addition, 2 deletionsarch/parisc/kernel/cache.c
- arch/x86/mm/hugetlbpage.c 1 addition, 2 deletionsarch/x86/mm/hugetlbpage.c
- fs/hugetlbfs/inode.c 4 additions, 5 deletionsfs/hugetlbfs/inode.c
- fs/inode.c 1 addition, 1 deletionfs/inode.c
- include/linux/fs.h 3 additions, 3 deletionsinclude/linux/fs.h
- include/linux/interval_tree_tmpl.h 215 additions, 0 deletionsinclude/linux/interval_tree_tmpl.h
- include/linux/mm.h 17 additions, 13 deletionsinclude/linux/mm.h
- include/linux/mm_types.h 5 additions, 9 deletionsinclude/linux/mm_types.h
- kernel/events/uprobes.c 1 addition, 2 deletionskernel/events/uprobes.c
- kernel/fork.c 1 addition, 1 deletionkernel/fork.c
- lib/interval_tree.c 10 additions, 156 deletionslib/interval_tree.c
- lib/prio_tree.c 2 additions, 17 deletionslib/prio_tree.c
- mm/Makefile 2 additions, 2 deletionsmm/Makefile
- mm/filemap_xip.c 1 addition, 2 deletionsmm/filemap_xip.c
- mm/fremap.c 1 addition, 1 deletionmm/fremap.c
- mm/hugetlb.c 1 addition, 2 deletionsmm/hugetlb.c
- mm/interval_tree.c 61 additions, 0 deletionsmm/interval_tree.c
- mm/memory-failure.c 1 addition, 2 deletionsmm/memory-failure.c
Loading
Please register or sign in to comment