Linux Kernel  3.7.1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
Data Structures | Macros | Functions
radix-tree.c File Reference
#include <linux/errno.h>
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/export.h>
#include <linux/radix-tree.h>
#include <linux/percpu.h>
#include <linux/slab.h>
#include <linux/notifier.h>
#include <linux/cpu.h>
#include <linux/string.h>
#include <linux/bitops.h>
#include <linux/rcupdate.h>

Go to the source code of this file.

Data Structures

struct  radix_tree_node
 
struct  radix_tree_preload
 

Macros

#define RADIX_TREE_MAP_SHIFT   3 /* For more stressful testing */
 
#define RADIX_TREE_MAP_SIZE   (1UL << RADIX_TREE_MAP_SHIFT)
 
#define RADIX_TREE_MAP_MASK   (RADIX_TREE_MAP_SIZE-1)
 
#define RADIX_TREE_TAG_LONGS   ((RADIX_TREE_MAP_SIZE + BITS_PER_LONG - 1) / BITS_PER_LONG)
 
#define RADIX_TREE_INDEX_BITS   (8 /* CHAR_BIT */ * sizeof(unsigned long))
 
#define RADIX_TREE_MAX_PATH
 
#define RADIX_TREE_PRELOAD_SIZE   (RADIX_TREE_MAX_PATH * 2 - 1)
 

Functions

int radix_tree_preload (gfp_t gfp_mask)
 
 EXPORT_SYMBOL (radix_tree_preload)
 
int radix_tree_insert (struct radix_tree_root *root, unsigned long index, void *item)
 
 EXPORT_SYMBOL (radix_tree_insert)
 
void ** radix_tree_lookup_slot (struct radix_tree_root *root, unsigned long index)
 
 EXPORT_SYMBOL (radix_tree_lookup_slot)
 
voidradix_tree_lookup (struct radix_tree_root *root, unsigned long index)
 
 EXPORT_SYMBOL (radix_tree_lookup)
 
voidradix_tree_tag_set (struct radix_tree_root *root, unsigned long index, unsigned int tag)
 
 EXPORT_SYMBOL (radix_tree_tag_set)
 
voidradix_tree_tag_clear (struct radix_tree_root *root, unsigned long index, unsigned int tag)
 
 EXPORT_SYMBOL (radix_tree_tag_clear)
 
int radix_tree_tag_get (struct radix_tree_root *root, unsigned long index, unsigned int tag)
 
 EXPORT_SYMBOL (radix_tree_tag_get)
 
void ** radix_tree_next_chunk (struct radix_tree_root *root, struct radix_tree_iter *iter, unsigned flags)
 
 EXPORT_SYMBOL (radix_tree_next_chunk)
 
unsigned long radix_tree_range_tag_if_tagged (struct radix_tree_root *root, unsigned long *first_indexp, unsigned long last_index, unsigned long nr_to_tag, unsigned int iftag, unsigned int settag)
 
 EXPORT_SYMBOL (radix_tree_range_tag_if_tagged)
 
unsigned long radix_tree_next_hole (struct radix_tree_root *root, unsigned long index, unsigned long max_scan)
 
 EXPORT_SYMBOL (radix_tree_next_hole)
 
unsigned long radix_tree_prev_hole (struct radix_tree_root *root, unsigned long index, unsigned long max_scan)
 
 EXPORT_SYMBOL (radix_tree_prev_hole)
 
unsigned int radix_tree_gang_lookup (struct radix_tree_root *root, void **results, unsigned long first_index, unsigned int max_items)
 
 EXPORT_SYMBOL (radix_tree_gang_lookup)
 
unsigned int radix_tree_gang_lookup_slot (struct radix_tree_root *root, void ***results, unsigned long *indices, unsigned long first_index, unsigned int max_items)
 
 EXPORT_SYMBOL (radix_tree_gang_lookup_slot)
 
unsigned int radix_tree_gang_lookup_tag (struct radix_tree_root *root, void **results, unsigned long first_index, unsigned int max_items, unsigned int tag)
 
 EXPORT_SYMBOL (radix_tree_gang_lookup_tag)
 
unsigned int radix_tree_gang_lookup_tag_slot (struct radix_tree_root *root, void ***results, unsigned long first_index, unsigned int max_items, unsigned int tag)
 
 EXPORT_SYMBOL (radix_tree_gang_lookup_tag_slot)
 
unsigned long radix_tree_locate_item (struct radix_tree_root *root, void *item)
 
voidradix_tree_delete (struct radix_tree_root *root, unsigned long index)
 
 EXPORT_SYMBOL (radix_tree_delete)
 
int radix_tree_tagged (struct radix_tree_root *root, unsigned int tag)
 
 EXPORT_SYMBOL (radix_tree_tagged)
 
void __init radix_tree_init (void)
 

Macro Definition Documentation

#define RADIX_TREE_INDEX_BITS   (8 /* CHAR_BIT */ * sizeof(unsigned long))

Definition at line 60 of file radix-tree.c.

#define RADIX_TREE_MAP_MASK   (RADIX_TREE_MAP_SIZE-1)

Definition at line 44 of file radix-tree.c.

#define RADIX_TREE_MAP_SHIFT   3 /* For more stressful testing */

Definition at line 40 of file radix-tree.c.

#define RADIX_TREE_MAP_SIZE   (1UL << RADIX_TREE_MAP_SHIFT)

Definition at line 43 of file radix-tree.c.

#define RADIX_TREE_MAX_PATH
Value:

Definition at line 61 of file radix-tree.c.

#define RADIX_TREE_PRELOAD_SIZE   (RADIX_TREE_MAX_PATH * 2 - 1)

Definition at line 86 of file radix-tree.c.

#define RADIX_TREE_TAG_LONGS   ((RADIX_TREE_MAP_SIZE + BITS_PER_LONG - 1) / BITS_PER_LONG)

Definition at line 46 of file radix-tree.c.

Function Documentation

EXPORT_SYMBOL ( radix_tree_preload  )
EXPORT_SYMBOL ( radix_tree_insert  )
EXPORT_SYMBOL ( radix_tree_lookup_slot  )
EXPORT_SYMBOL ( radix_tree_lookup  )
EXPORT_SYMBOL ( radix_tree_tag_set  )
EXPORT_SYMBOL ( radix_tree_tag_clear  )
EXPORT_SYMBOL ( radix_tree_tag_get  )
EXPORT_SYMBOL ( radix_tree_next_chunk  )
EXPORT_SYMBOL ( radix_tree_range_tag_if_tagged  )
EXPORT_SYMBOL ( radix_tree_next_hole  )
EXPORT_SYMBOL ( radix_tree_prev_hole  )
EXPORT_SYMBOL ( radix_tree_gang_lookup  )
EXPORT_SYMBOL ( radix_tree_gang_lookup_slot  )
EXPORT_SYMBOL ( radix_tree_gang_lookup_tag  )
EXPORT_SYMBOL ( radix_tree_gang_lookup_tag_slot  )
EXPORT_SYMBOL ( radix_tree_delete  )
EXPORT_SYMBOL ( radix_tree_tagged  )
void* radix_tree_delete ( struct radix_tree_root root,
unsigned long  index 
)

radix_tree_delete - delete an item from a radix tree : radix tree root : index key

Remove the item at from the radix tree rooted at .

Returns the address of the deleted item, or NULL if it was not present.

Definition at line 1309 of file radix-tree.c.

unsigned int radix_tree_gang_lookup ( struct radix_tree_root root,
void **  results,
unsigned long  first_index,
unsigned int  max_items 
)

radix_tree_gang_lookup - perform multiple lookup on a radix tree : radix tree root : where the results of the lookup are placed : start the lookup from this key : place up to this many items at *results

Performs an index-ascending scan of the tree for present items. Places them at * and returns the number of items which were placed at *.

The implementation is naive.

Like radix_tree_lookup, radix_tree_gang_lookup may be called under rcu_read_lock. In this case, rather than the returned results being an atomic snapshot of the tree at a single point in time, the semantics of an RCU protected gang lookup are as though multiple radix_tree_lookups have been issued in individual locks, and results stored in 'results'.

Definition at line 1007 of file radix-tree.c.

unsigned int radix_tree_gang_lookup_slot ( struct radix_tree_root root,
void ***  results,
unsigned long indices,
unsigned long  first_index,
unsigned int  max_items 
)

radix_tree_gang_lookup_slot - perform multiple slot lookup on radix tree : radix tree root : where the results of the lookup are placed : where their indices should be placed (but usually NULL) : start the lookup from this key : place up to this many items at *results

Performs an index-ascending scan of the tree for present items. Places their slots at * and returns the number of items which were placed at *.

The implementation is naive.

Like radix_tree_gang_lookup as far as RCU and locking goes. Slots must be dereferenced with radix_tree_deref_slot, and if using only RCU protection, radix_tree_deref_slot may fail requiring a retry.

Definition at line 1048 of file radix-tree.c.

unsigned int radix_tree_gang_lookup_tag ( struct radix_tree_root root,
void **  results,
unsigned long  first_index,
unsigned int  max_items,
unsigned int  tag 
)

radix_tree_gang_lookup_tag - perform multiple lookup on a radix tree based on a tag : radix tree root : where the results of the lookup are placed : start the lookup from this key : place up to this many items at *results : the tag index (< RADIX_TREE_MAX_TAGS)

Performs an index-ascending scan of the tree for present items which have the tag indexed by set. Places the items at * and returns the number of items which were placed at *.

Definition at line 1085 of file radix-tree.c.

unsigned int radix_tree_gang_lookup_tag_slot ( struct radix_tree_root root,
void ***  results,
unsigned long  first_index,
unsigned int  max_items,
unsigned int  tag 
)

radix_tree_gang_lookup_tag_slot - perform multiple slot lookup on a radix tree based on a tag : radix tree root : where the results of the lookup are placed : start the lookup from this key : place up to this many items at *results : the tag index (< RADIX_TREE_MAX_TAGS)

Performs an index-ascending scan of the tree for present items which have the tag indexed by set. Places the slots at * and returns the number of slots which were placed at *.

Definition at line 1122 of file radix-tree.c.

void __init radix_tree_init ( void  )

Definition at line 1447 of file radix-tree.c.

int radix_tree_insert ( struct radix_tree_root root,
unsigned long  index,
void item 
)

radix_tree_insert - insert into a radix tree : radix tree root : index key : item to insert

Insert an item into the radix tree at position .

Definition at line 360 of file radix-tree.c.

unsigned long radix_tree_locate_item ( struct radix_tree_root root,
void item 
)

Definition at line 1230 of file radix-tree.c.

void* radix_tree_lookup ( struct radix_tree_root root,
unsigned long  index 
)

radix_tree_lookup - perform lookup operation on a radix tree : radix tree root : index key

Lookup the item at the position in the radix tree .

This function can be called under rcu_read_lock, however the caller must manage lifetimes of leaf nodes (eg. RCU may also be used to free them safely). No RCU barriers are required to access or modify the returned item, however.

Definition at line 495 of file radix-tree.c.

void** radix_tree_lookup_slot ( struct radix_tree_root root,
unsigned long  index 
)

radix_tree_lookup_slot - lookup a slot in a radix tree : radix tree root : index key

Returns: the slot corresponding to the position in the radix tree . This is useful for update-if-exists operations.

This function can be called under rcu_read_lock iff the slot is not modified by radix_tree_replace_slot, otherwise it must be called exclusive from other writers. Any dereference of the slot must be done using radix_tree_deref_slot.

Definition at line 477 of file radix-tree.c.

void** radix_tree_next_chunk ( struct radix_tree_root root,
struct radix_tree_iter iter,
unsigned  flags 
)

radix_tree_next_chunk - find next chunk of slots for iteration

: radix tree root : iterator state : RADIX_TREE_ITER_* flags and tag index Returns: pointer to chunk first slot, or NULL if iteration is over

Definition at line 674 of file radix-tree.c.

unsigned long radix_tree_next_hole ( struct radix_tree_root root,
unsigned long  index,
unsigned long  max_scan 
)

radix_tree_next_hole - find the next hole (not-present entry) : tree root : index key : maximum range to search

Search the set [index, min(index+max_scan-1, MAX_INDEX)] for the lowest indexed hole.

Returns: the index of the hole if found, otherwise returns an index outside of the set specified (in which case 'return - index >= max_scan' will be true). In rare cases of index wrap-around, 0 will be returned.

radix_tree_next_hole may be called under rcu_read_lock. However, like radix_tree_gang_lookup, this will not atomically search a snapshot of the tree at a single point in time. For example, if a hole is created at index 5, then subsequently a hole is created at index 10, radix_tree_next_hole covering both indexes may return 10 if called under rcu_read_lock.

Definition at line 933 of file radix-tree.c.

int radix_tree_preload ( gfp_t  gfp_mask)

Definition at line 267 of file radix-tree.c.

unsigned long radix_tree_prev_hole ( struct radix_tree_root root,
unsigned long  index,
unsigned long  max_scan 
)

radix_tree_prev_hole - find the prev hole (not-present entry) : tree root : index key : maximum range to search

Search backwards in the range [max(index-max_scan+1, 0), index] for the first hole.

Returns: the index of the hole if found, otherwise returns an index outside of the set specified (in which case 'index - return >= max_scan' will be true). In rare cases of wrap-around, ULONG_MAX will be returned.

radix_tree_next_hole may be called under rcu_read_lock. However, like radix_tree_gang_lookup, this will not atomically search a snapshot of the tree at a single point in time. For example, if a hole is created at index 10, then subsequently a hole is created at index 5, radix_tree_prev_hole covering both indexes may return 5 if called under rcu_read_lock.

Definition at line 970 of file radix-tree.c.

unsigned long radix_tree_range_tag_if_tagged ( struct radix_tree_root root,
unsigned long first_indexp,
unsigned long  last_index,
unsigned long  nr_to_tag,
unsigned int  iftag,
unsigned int  settag 
)

radix_tree_range_tag_if_tagged - for each item in given range set given tag if item has another tag set : radix tree root : pointer to a starting index of a range to scan : last index of a range to scan : maximum number items to tag : tag index to test : tag index to set if tested tag is set

This function scans range of radix tree from first_index to last_index (inclusive). For each item in the range if iftag is set, the function sets also settag. The function stops either after tagging nr_to_tag items or after reaching last_index.

The tags must be set from the leaf level only and propagated back up the path to the root. We must do this so that we resolve the full path before setting any tags on intermediate nodes. If we set tags as we descend, then we can get to the leaf node and find that the index that has the iftag set is outside the range we are scanning. This reults in dangling tags and can lead to problems with later tag operations (e.g. livelocks on lookups).

The function returns number of leaves where the tag was set and sets *first_indexp to the first unscanned index. WARNING! *first_indexp can wrap if last_index is ULONG_MAX. Caller must be prepared to handle that.

Definition at line 809 of file radix-tree.c.

void* radix_tree_tag_clear ( struct radix_tree_root root,
unsigned long  index,
unsigned int  tag 
)

radix_tree_tag_clear - clear a tag on a radix tree node : radix tree root : index key : tag index

Clear the search tag (which must be < RADIX_TREE_MAX_TAGS) corresponding to in the radix tree. If this causes the leaf node to have no tags set then clear the tag in the next-to-leaf node, etc.

Returns the address of the tagged item on success, else NULL. ie: has the same return value and semantics as radix_tree_lookup().

Definition at line 560 of file radix-tree.c.

int radix_tree_tag_get ( struct radix_tree_root root,
unsigned long  index,
unsigned int  tag 
)

radix_tree_tag_get - get a tag on a radix tree node : radix tree root : index key : tag index (< RADIX_TREE_MAX_TAGS)

Return values:

0: tag not present or not set 1: tag set

Note that the return value of this function may not be relied on, even if the RCU lock is held, unless tag modification and node deletion are excluded from concurrency.

Definition at line 624 of file radix-tree.c.

void* radix_tree_tag_set ( struct radix_tree_root root,
unsigned long  index,
unsigned int  tag 
)

radix_tree_tag_set - set a tag on a radix tree node : radix tree root : index key : tag index

Set the search tag (which must be < RADIX_TREE_MAX_TAGS) corresponding to in the radix tree. From the root all the way down to the leaf node.

Returns the address of the tagged item. Setting a tag on a not-present item is a bug.

Definition at line 514 of file radix-tree.c.

int radix_tree_tagged ( struct radix_tree_root root,
unsigned int  tag 
)

radix_tree_tagged - test whether any items in the tree are tagged : radix tree root : tag to test

Definition at line 1395 of file radix-tree.c.