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