mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-07-03 12:52:52 +00:00
radix-tree: add support for multi-order iterating
This enables the macros radix_tree_for_each_slot() and friends to be used with multi-order entries. The way that this works is that we treat all entries in a given slots[] array as a single chunk. If the index given to radix_tree_next_chunk() happens to point us to a sibling entry, we will back up iter->index so that it points to the canonical entry, and that will be the place where we start our iteration. As we're processing a chunk in radix_tree_next_slot(), we process canonical entries, skip over sibling entries, and restart the chunk lookup if we find a non-sibling indirect pointer. This drops back to the radix_tree_next_chunk() code, which will re-walk the tree and look for another chunk. This allows us to properly handle multi-order entries mixed with other entries that are at various heights in the radix tree. Signed-off-by: Ross Zwisler <ross.zwisler@linux.intel.com> Signed-off-by: Matthew Wilcox <willy@linux.intel.com> Cc: Konstantin Khlebnikov <koct9i@gmail.com> Cc: Kirill Shutemov <kirill.shutemov@linux.intel.com> Cc: Jan Kara <jack@suse.com> Cc: Neil Brown <neilb@suse.de> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
7b60e9ad59
commit
21ef533931
4 changed files with 102 additions and 41 deletions
|
@ -8,10 +8,7 @@
|
|||
#include <limits.h>
|
||||
|
||||
#include "../../include/linux/compiler.h"
|
||||
|
||||
#define CONFIG_RADIX_TREE_MULTIORDER
|
||||
#define CONFIG_SHMEM
|
||||
#define CONFIG_SWAP
|
||||
#include "../../../include/linux/kconfig.h"
|
||||
|
||||
#define RADIX_TREE_MAP_SHIFT 3
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue