5#ifndef _RTE_FBK_HASH_H_
6#define _RTE_FBK_HASH_H_
30#ifndef RTE_FBK_HASH_INIT_VAL_DEFAULT
32#define RTE_FBK_HASH_INIT_VAL_DEFAULT 0xFFFFFFFF
36#define RTE_FBK_HASH_ENTRIES_MAX (1 << 20)
39#define RTE_FBK_HASH_ENTRIES_PER_BUCKET_MAX 256
42#define RTE_FBK_HASH_NAMESIZE 32
118 uint32_t
key, uint16_t
value, uint32_t bucket)
126 const uint64_t new_entry = ((uint64_t)(
key) << 32) |
127 ((uint64_t)(
value) << 16) |
185 uint32_t
key, uint32_t bucket)
248 uint32_t
key, uint32_t bucket)
293 memset(ht->
t, 0,
sizeof(ht->
t[0]) * ht->
entries);
#define RTE_FBK_HASH_NAMESIZE
static int rte_fbk_hash_add_key_with_bucket(struct rte_fbk_hash_table *ht, uint32_t key, uint16_t value, uint32_t bucket)
static int rte_fbk_hash_add_key(struct rte_fbk_hash_table *ht, uint32_t key, uint16_t value)
void rte_fbk_hash_free(struct rte_fbk_hash_table *ht)
static int rte_fbk_hash_lookup_with_bucket(const struct rte_fbk_hash_table *ht, uint32_t key, uint32_t bucket)
static int rte_fbk_hash_delete_key_with_bucket(struct rte_fbk_hash_table *ht, uint32_t key, uint32_t bucket)
struct rte_fbk_hash_table * rte_fbk_hash_find_existing(const char *name)
static int rte_fbk_hash_lookup(const struct rte_fbk_hash_table *ht, uint32_t key)
static int rte_fbk_hash_delete_key(struct rte_fbk_hash_table *ht, uint32_t key)
uint32_t(* rte_fbk_hash_fn)(uint32_t key, uint32_t init_val)
static uint32_t rte_fbk_hash_get_bucket(const struct rte_fbk_hash_table *ht, uint32_t key)
static void rte_fbk_hash_clear_all(struct rte_fbk_hash_table *ht)
static double rte_fbk_hash_get_load_factor(struct rte_fbk_hash_table *ht)
rte_fbk_hash_fn hash_func
uint32_t entries_per_bucket
rte_fbk_hash_fn hash_func
union rte_fbk_hash_entry t[]
char name[RTE_FBK_HASH_NAMESIZE]
uint32_t entries_per_bucket
struct rte_fbk_hash_entry::@196 entry