Generic radix trees/sparse arrays¶
Very simple and minimalistic, supporting arbitrary size entries up to PAGE_SIZE.
A genradix is defined with the type it will store, like so:
static GENRADIX(struct foo) foo_genradix;
The main operations are:
- genradix_init(radix) - initialize an empty genradix 
- genradix_free(radix) - free all memory owned by the genradix and reinitialize it 
- genradix_ptr(radix, idx) - gets a pointer to the entry at idx, returning NULL if that entry does not exist 
- genradix_ptr_alloc(radix, idx, gfp) - gets a pointer to an entry, allocating it if necessary 
- genradix_for_each(radix, iter, p) - iterate over each entry in a genradix 
The radix tree allocates one page of entries at a time, so entries may exist that were never explicitly allocated - they will be initialized to all zeroes.
Internally, a genradix is just a radix tree of pages, and indexing works in terms of byte offsets. The wrappers in this header file use sizeof on the type the radix contains to calculate a byte offset from the index - see __idx_to_offset.
generic radix tree functions¶
- 
genradix_init(_radix)¶
- initialize a genradix 
Parameters
- _radix
- genradix to initialize 
Description
Does not fail
- 
genradix_free(_radix)¶
Parameters
- _radix
- the genradix to free 
Description
After freeing, _radix will be reinitialized and empty
- 
genradix_ptr(_radix, _idx)¶
- get a pointer to a genradix entry 
Parameters
- _radix
- genradix to access 
- _idx
- index to fetch 
Description
Returns a pointer to entry at _idx, or NULL if that entry does not exist.
- 
genradix_ptr_alloc(_radix, _idx, _gfp)¶
- get a pointer to a genradix entry, allocating it if necessary 
Parameters
- _radix
- genradix to access 
- _idx
- index to fetch 
- _gfp
- gfp mask 
Description
Returns a pointer to entry at _idx, or NULL on allocation failure
- 
genradix_iter_init(_radix, _idx)¶
- initialize a genradix_iter 
Parameters
- _radix
- genradix that will be iterated over 
- _idx
- index to start iterating from 
- 
genradix_iter_peek(_iter, _radix)¶
- get first entry at or above iterator’s current position 
Parameters
- _iter
- a genradix_iter 
- _radix
- genradix being iterated over 
Description
If no more entries exist at or above _iter’s current position, returns NULL
- 
genradix_for_each(_radix, _iter, _p)¶
- iterate over entry in a genradix 
Parameters
- _radix
- genradix to iterate over 
- _iter
- a genradix_iter to track current position 
- _p
- pointer to genradix entry type 
Description
On every iteration, _p will point to the current entry, and _iter.pos will be the current entry’s index.
- 
genradix_prealloc(_radix, _nr, _gfp)¶
- preallocate entries in a generic radix tree 
Parameters
- _radix
- genradix to preallocate 
- _nr
- number of entries to preallocate 
- _gfp
- gfp mask 
Description
Returns 0 on success, -ENOMEM on failure