summaryrefslogtreecommitdiff
path: root/lib/librte_member/rte_member_ht.h
blob: 9e24ccdc246332b64ff6757e321fbc20cc5eddd2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/* SPDX-License-Identifier: BSD-3-Clause
 * Copyright(c) 2017 Intel Corporation
 */

#ifndef _RTE_MEMBER_HT_H_
#define _RTE_MEMBER_HT_H_

#ifdef __cplusplus
extern "C" {
#endif

/* Maximum number of pushes for cuckoo path in HT mode. */
#define RTE_MEMBER_MAX_PUSHES 50

typedef uint16_t member_sig_t;			/* signature size is 16 bit */

/* The bucket struct for ht setsum */
struct member_ht_bucket {
	member_sig_t sigs[RTE_MEMBER_BUCKET_ENTRIES];	/* 2-byte signature */
	member_set_t sets[RTE_MEMBER_BUCKET_ENTRIES];	/* 2-byte set */
} __rte_cache_aligned;

int
rte_member_create_ht(struct rte_member_setsum *ss,
		const struct rte_member_parameters *params);

int
rte_member_lookup_ht(const struct rte_member_setsum *setsum,
		const void *key, member_set_t *set_id);

uint32_t
rte_member_lookup_bulk_ht(const struct rte_member_setsum *setsum,
		const void **keys, uint32_t num_keys,
		member_set_t *set_ids);

uint32_t
rte_member_lookup_multi_ht(const struct rte_member_setsum *setsum,
		const void *key, uint32_t match_per_key,
		member_set_t *set_id);

uint32_t
rte_member_lookup_multi_bulk_ht(const struct rte_member_setsum *setsum,
		const void **keys, uint32_t num_keys, uint32_t match_per_key,
		uint32_t *match_count,
		member_set_t *set_ids);

int
rte_member_add_ht(const struct rte_member_setsum *setsum,
		const void *key, member_set_t set_id);

void
rte_member_free_ht(struct rte_member_setsum *setsum);

int
rte_member_delete_ht(const struct rte_member_setsum *ss, const void *key,
		member_set_t set_id);

void
rte_member_reset_ht(const struct rte_member_setsum *setsum);

#ifdef __cplusplus
}
#endif

#endif /* _RTE_MEMBER_HT_H_ */