40 lines
1.1 KiB
C
40 lines
1.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* Copyright 2023 Red Hat
|
|
*/
|
|
|
|
#ifndef VDO_INT_MAP_H
|
|
#define VDO_INT_MAP_H
|
|
|
|
#include <linux/compiler.h>
|
|
#include <linux/types.h>
|
|
|
|
/**
|
|
* DOC: int_map
|
|
*
|
|
* An int_map associates pointers (void *) with integer keys (u64). NULL pointer values are
|
|
* not supported.
|
|
*
|
|
* The map is implemented as hash table, which should provide constant-time insert, query, and
|
|
* remove operations, although the insert may occasionally grow the table, which is linear in the
|
|
* number of entries in the map. The table will grow as needed to hold new entries, but will not
|
|
* shrink as entries are removed.
|
|
*/
|
|
|
|
struct int_map;
|
|
|
|
int __must_check vdo_int_map_create(size_t initial_capacity, struct int_map **map_ptr);
|
|
|
|
void vdo_int_map_free(struct int_map *map);
|
|
|
|
size_t vdo_int_map_size(const struct int_map *map);
|
|
|
|
void *vdo_int_map_get(struct int_map *map, u64 key);
|
|
|
|
int __must_check vdo_int_map_put(struct int_map *map, u64 key, void *new_value,
|
|
bool update, void **old_value_ptr);
|
|
|
|
void *vdo_int_map_remove(struct int_map *map, u64 key);
|
|
|
|
#endif /* VDO_INT_MAP_H */
|