Hash table that consists of smaller hash tables. More...
#include "util/storage/lruhash.h"
Data Structures | |
struct | slabhash |
Hash table formed from several smaller ones. More... | |
struct | slabhash_testkey |
test structure contains test key More... | |
struct | slabhash_testdata |
test structure contains test data More... | |
Macros | |
#define | HASH_DEFAULT_SLABS 4 |
default number of slabs | |
Functions | |
struct slabhash * | slabhash_create (size_t numtables, size_t start_size, size_t maxmem, lruhash_sizefunc_type sizefunc, lruhash_compfunc_type compfunc, lruhash_delkeyfunc_type delkeyfunc, lruhash_deldatafunc_type deldatafunc, void *arg) |
Create new slabbed hash table. More... | |
void | slabhash_delete (struct slabhash *table) |
Delete hash table. More... | |
void | slabhash_clear (struct slabhash *table) |
Clear hash table. More... | |
void | slabhash_insert (struct slabhash *table, hashvalue_type hash, struct lruhash_entry *entry, void *data, void *cb_override) |
Insert a new element into the hashtable, uses lruhash_insert. More... | |
struct lruhash_entry * | slabhash_lookup (struct slabhash *table, hashvalue_type hash, void *key, int wr) |
Lookup an entry in the hashtable. More... | |
void | slabhash_remove (struct slabhash *table, hashvalue_type hash, void *key) |
Remove entry from hashtable. More... | |
void | slabhash_status (struct slabhash *table, const char *id, int extended) |
Output debug info to the log as to state of the hash table. More... | |
size_t | slabhash_get_size (struct slabhash *table) |
Retrieve slab hash total size. More... | |
int | slabhash_is_size (struct slabhash *table, size_t size, size_t slabs) |
See if slabhash is of given (size, slabs) configuration. More... | |
void | slabhash_update_space_used (struct slabhash *table, hashvalue_type hash, void *cb_override, int diff_size) |
Update the size of an element in the hashtable, uses lruhash_update_space_used. More... | |
size_t | slabhash_get_mem (struct slabhash *table) |
Retrieve slab hash current memory use. More... | |
struct lruhash * | slabhash_gettable (struct slabhash *table, hashvalue_type hash) |
Get lruhash table for a given hash value. More... | |
void | slabhash_setmarkdel (struct slabhash *table, lruhash_markdelfunc_type md) |
Set markdel function. More... | |
void | slabhash_traverse (struct slabhash *table, int wr, void(*func)(struct lruhash_entry *, void *), void *arg) |
Traverse a slabhash. More... | |
size_t | count_slabhash_entries (struct slabhash *table) |
void | get_slabhash_stats (struct slabhash *table, long long *entries_count, long long *max_collisions) |
Retrieves number of items in slabhash and the current max collision level. More... | |
size_t | test_slabhash_sizefunc (void *, void *) |
test sizefunc for lruhash | |
int | test_slabhash_compfunc (void *, void *) |
test comparefunc for lruhash | |
void | test_slabhash_delkey (void *, void *) |
test delkey for lruhash | |
void | test_slabhash_deldata (void *, void *) |
test deldata for lruhash | |
Hash table that consists of smaller hash tables.
It cannot grow, but that gives it the ability to have multiple locks. Also this means there are multiple LRU lists.
struct slabhash* slabhash_create | ( | size_t | numtables, |
size_t | start_size, | ||
size_t | maxmem, | ||
lruhash_sizefunc_type | sizefunc, | ||
lruhash_compfunc_type | compfunc, | ||
lruhash_delkeyfunc_type | delkeyfunc, | ||
lruhash_deldatafunc_type | deldatafunc, | ||
void * | arg | ||
) |
Create new slabbed hash table.
numtables | number of hash tables to use, other parameters used to initialize these smaller hashtables. |
start_size | size of hashtable array at start, must be power of 2. |
maxmem | maximum amount of memory this table is allowed to use. so every table gets maxmem/numtables to use for itself. |
sizefunc | calculates memory usage of entries. |
compfunc | compares entries, 0 on equality. |
delkeyfunc | deletes key. |
deldatafunc | deletes data. |
arg | user argument that is passed to user function calls. |
References slabhash::array, lruhash::compfunc, lruhash::deldatafunc, lruhash::delkeyfunc, log_assert, lruhash_create(), slabhash::mask, slabhash::shift, slabhash::size, lruhash::sizefunc, and slabhash_delete().
Referenced by context_finalize(), daemon_apply_cfg(), infra_create(), key_cache_create(), rrset_cache_create(), and slabhash_test().
void slabhash_delete | ( | struct slabhash * | table | ) |
Delete hash table.
Entries are all deleted.
table | to delete. |
References slabhash::array, lruhash_delete(), and slabhash::size.
Referenced by context_finalize(), daemon_apply_cfg(), daemon_delete(), infra_delete(), key_cache_delete(), rrset_cache_delete(), slabhash_create(), and slabhash_test().
void slabhash_clear | ( | struct slabhash * | table | ) |
Clear hash table.
Entries are all deleted.
table | to make empty. |
References slabhash::array, lruhash_clear(), and slabhash::size.
Referenced by daemon_apply_cfg(), daemon_cleanup(), do_flush_infra(), libworker_alloc_cleanup(), test_long_table(), and worker_alloc_cleanup().
void slabhash_insert | ( | struct slabhash * | table, |
hashvalue_type | hash, | ||
struct lruhash_entry * | entry, | ||
void * | data, | ||
void * | cb_override | ||
) |
Insert a new element into the hashtable, uses lruhash_insert.
If key is already present data pointer in that entry is updated.
table | hash table. |
hash | hash value. User calculates the hash. |
entry | identifies the entry. If key already present, this entry->key is deleted immediately. But entry->data is set to NULL before deletion, and put into the existing entry. The data is then freed. |
data | the data. |
cb_override | if not NULL overrides the cb_arg for deletefunc. |
References slabhash::array, lruhash_insert(), and slab_idx().
Referenced by dns_cache_store_msg(), dnsc_nonce_cache_insert(), dnsc_shared_secret_cache_insert(), infra_create_ratedata(), infra_edns_update(), infra_host(), infra_rtt_update(), infra_set_lame(), key_cache_insert(), rrset_cache_update(), test_short_table(), testadd(), and testadd_unlim().
struct lruhash_entry* slabhash_lookup | ( | struct slabhash * | table, |
hashvalue_type | hash, | ||
void * | key, | ||
int | wr | ||
) |
Lookup an entry in the hashtable.
Uses lruhash_lookup. At the end of the function you hold a (read/write)lock on the entry. The LRU is updated for the entry (if found).
table | hash table. |
hash | hash of key. |
key | what to look for, compared against entries in overflow chain. the hash value must be set, and must work with compare function. |
wr | set to true if you desire a writelock on the entry. with a writelock you can update the data part. |
References slabhash::array, lruhash_entry::hash, lruhash_entry::key, lruhash_lookup(), and slab_idx().
Referenced by dns_cache_lookup(), dnsc_nonces_lookup(), dnsc_shared_secrets_lookup(), infra_find_ip_ratedata(), infra_find_ratedata(), infra_lookup_nottl(), invalidateQueryInCache(), key_cache_search(), mesh_serve_expired_lookup(), msg_cache_lookup(), rrset_cache_lookup(), rrset_cache_update(), rrset_check_sec_status(), rrset_update_sec_status(), test_short_table(), testlookup(), and testlookup_unlim().
void slabhash_remove | ( | struct slabhash * | table, |
hashvalue_type | hash, | ||
void * | key | ||
) |
Remove entry from hashtable.
Does nothing if not found in hashtable. Delfunc is called for the entry. Uses lruhash_remove.
table | hash table. |
hash | hash of key. |
key | what to look for. |
References slabhash::array, lruhash_entry::hash, lruhash_entry::key, lruhash_remove(), and slab_idx().
Referenced by do_cache_remove(), key_cache_remove(), msg_cache_remove(), rrset_cache_remove(), test_short_table(), testremove(), and testremove_unlim().
void slabhash_status | ( | struct slabhash * | table, |
const char * | id, | ||
int | extended | ||
) |
Output debug info to the log as to state of the hash table.
table | hash table. |
id | string printed with table to identify the hash table. |
extended | set to true to print statistics on overflow bin lengths. |
References slabhash::array, log_info(), lruhash_status(), slabhash::mask, slabhash::shift, and slabhash::size.
Referenced by test_long_table(), test_thr_main(), and test_threaded_table().
size_t slabhash_get_size | ( | struct slabhash * | table | ) |
Retrieve slab hash total size.
table | hash table. |
References slabhash::array, lruhash::lock, slabhash::size, and lruhash::space_max.
Referenced by slabhash_is_size().
int slabhash_is_size | ( | struct slabhash * | table, |
size_t | size, | ||
size_t | slabs | ||
) |
See if slabhash is of given (size, slabs) configuration.
table | hash table |
size | max size to test for |
slabs | slab count to test for. |
References slabhash::size, and slabhash_get_size().
Referenced by context_finalize(), daemon_apply_cfg(), infra_adjust(), and rrset_cache_adjust().
void slabhash_update_space_used | ( | struct slabhash * | table, |
hashvalue_type | hash, | ||
void * | cb_override, | ||
int | diff_size | ||
) |
Update the size of an element in the hashtable, uses lruhash_update_space_used.
table | hash table. |
hash | hash value. User calculates the hash. |
cb_override | if not NULL overrides the cb_arg for deletefunc. |
diff_size | difference in size to the hash table storage. |
References slabhash::array, lruhash_entry::hash, lruhash_update_space_used(), and slab_idx().
size_t slabhash_get_mem | ( | struct slabhash * | table | ) |
Retrieve slab hash current memory use.
table | hash table. |
References slabhash::array, lruhash_get_mem(), lruhash::size, and slabhash::size.
Referenced by infra_get_mem(), key_cache_get_mem(), and print_mem().
struct lruhash* slabhash_gettable | ( | struct slabhash * | table, |
hashvalue_type | hash | ||
) |
Get lruhash table for a given hash value.
table | slabbed hash table. |
hash | hash value. |
References slabhash::array, and slab_idx().
Referenced by rrset_cache_touch().
void slabhash_setmarkdel | ( | struct slabhash * | table, |
lruhash_markdelfunc_type | md | ||
) |
Set markdel function.
table | slabbed hash table. |
md | markdel function ptr. |
References slabhash::array, lruhash_setmarkdel(), and slabhash::size.
Referenced by rrset_cache_create().
void slabhash_traverse | ( | struct slabhash * | table, |
int | wr, | ||
void(*)(struct lruhash_entry *, void *) | func, | ||
void * | arg | ||
) |
Traverse a slabhash.
table | slabbed hash table. |
wr | if true, writelock is obtained, otherwise readlock. |
func | function to call for every element. |
arg | user argument to function. |
References slabhash::array, lruhash_traverse(), and slabhash::size.
Referenced by do_dump_infra(), do_flush_bogus(), do_flush_infra(), do_flush_negative(), do_flush_zone(), and do_ratelimit_list().
void get_slabhash_stats | ( | struct slabhash * | table, |
long long * | entries_count, | ||
long long * | max_collisions | ||
) |
Retrieves number of items in slabhash and the current max collision level.
table | slabbed hash table. |
entries_count | where to save the current number of elements. |
max_collisions | where to save the current max collisions level. |
References slabhash::array, lruhash::lock, lruhash::max_collisions, lruhash::num, and slabhash::size.
Referenced by server_stats_compile().