hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
/*-
|
|
|
|
* BSD LICENSE
|
|
|
|
*
|
2016-06-16 15:14:14 -07:00
|
|
|
* Copyright(c) 2010-2016 Intel Corporation. All rights reserved.
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
*
|
|
|
|
* * Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* * Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in
|
|
|
|
* the documentation and/or other materials provided with the
|
|
|
|
* distribution.
|
|
|
|
* * Neither the name of Intel Corporation nor the names of its
|
|
|
|
* contributors may be used to endorse or promote products derived
|
|
|
|
* from this software without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <sys/queue.h>
|
|
|
|
|
|
|
|
#include <rte_common.h>
|
|
|
|
#include <rte_memory.h> /* for definition of RTE_CACHE_LINE_SIZE */
|
|
|
|
#include <rte_log.h>
|
|
|
|
#include <rte_memcpy.h>
|
|
|
|
#include <rte_prefetch.h>
|
|
|
|
#include <rte_branch_prediction.h>
|
|
|
|
#include <rte_memzone.h>
|
|
|
|
#include <rte_malloc.h>
|
|
|
|
#include <rte_eal.h>
|
|
|
|
#include <rte_eal_memconfig.h>
|
|
|
|
#include <rte_per_lcore.h>
|
|
|
|
#include <rte_errno.h>
|
|
|
|
#include <rte_string_fns.h>
|
|
|
|
#include <rte_cpuflags.h>
|
|
|
|
#include <rte_log.h>
|
|
|
|
#include <rte_rwlock.h>
|
|
|
|
#include <rte_spinlock.h>
|
|
|
|
#include <rte_ring.h>
|
2015-07-11 01:18:52 +01:00
|
|
|
#include <rte_compat.h>
|
2017-06-05 14:28:43 +05:30
|
|
|
#include <rte_pause.h>
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
|
|
|
#include "rte_hash.h"
|
2016-06-16 15:14:14 -07:00
|
|
|
#include "rte_cuckoo_hash.h"
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-06-16 15:14:14 -07:00
|
|
|
#if defined(RTE_ARCH_X86)
|
|
|
|
#include "rte_cuckoo_hash_x86.h"
|
2015-11-24 00:15:35 +05:30
|
|
|
#endif
|
|
|
|
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
TAILQ_HEAD(rte_hash_list, rte_tailq_entry);
|
|
|
|
|
|
|
|
static struct rte_tailq_elem rte_hash_tailq = {
|
|
|
|
.name = "RTE_HASH",
|
|
|
|
};
|
|
|
|
EAL_REGISTER_TAILQ(rte_hash_tailq)
|
|
|
|
|
|
|
|
struct rte_hash *
|
|
|
|
rte_hash_find_existing(const char *name)
|
|
|
|
{
|
|
|
|
struct rte_hash *h = NULL;
|
|
|
|
struct rte_tailq_entry *te;
|
|
|
|
struct rte_hash_list *hash_list;
|
|
|
|
|
|
|
|
hash_list = RTE_TAILQ_CAST(rte_hash_tailq.head, rte_hash_list);
|
|
|
|
|
|
|
|
rte_rwlock_read_lock(RTE_EAL_TAILQ_RWLOCK);
|
|
|
|
TAILQ_FOREACH(te, hash_list, next) {
|
|
|
|
h = (struct rte_hash *) te->data;
|
|
|
|
if (strncmp(name, h->name, RTE_HASH_NAMESIZE) == 0)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
rte_rwlock_read_unlock(RTE_EAL_TAILQ_RWLOCK);
|
|
|
|
|
|
|
|
if (te == NULL) {
|
|
|
|
rte_errno = ENOENT;
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
return h;
|
|
|
|
}
|
|
|
|
|
2015-12-04 11:11:41 +08:00
|
|
|
void rte_hash_set_cmp_func(struct rte_hash *h, rte_hash_cmp_eq_t func)
|
|
|
|
{
|
2016-09-17 14:13:24 +04:30
|
|
|
h->cmp_jump_table_idx = KEY_CUSTOM;
|
2016-04-01 16:03:49 +01:00
|
|
|
h->rte_hash_custom_cmp_eq = func;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int
|
|
|
|
rte_hash_cmp_eq(const void *key1, const void *key2, const struct rte_hash *h)
|
|
|
|
{
|
|
|
|
if (h->cmp_jump_table_idx == KEY_CUSTOM)
|
|
|
|
return h->rte_hash_custom_cmp_eq(key1, key2, h->key_len);
|
|
|
|
else
|
|
|
|
return cmp_jump_table[h->cmp_jump_table_idx](key1, key2, h->key_len);
|
2015-12-04 11:11:41 +08:00
|
|
|
}
|
|
|
|
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
struct rte_hash *
|
|
|
|
rte_hash_create(const struct rte_hash_parameters *params)
|
|
|
|
{
|
|
|
|
struct rte_hash *h = NULL;
|
|
|
|
struct rte_tailq_entry *te = NULL;
|
|
|
|
struct rte_hash_list *hash_list;
|
|
|
|
struct rte_ring *r = NULL;
|
|
|
|
char hash_name[RTE_HASH_NAMESIZE];
|
2015-10-02 17:07:13 +01:00
|
|
|
void *k = NULL;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
void *buckets = NULL;
|
|
|
|
char ring_name[RTE_RING_NAMESIZE];
|
2015-10-30 14:37:28 +00:00
|
|
|
unsigned num_key_slots;
|
|
|
|
unsigned hw_trans_mem_support = 0;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
unsigned i;
|
|
|
|
|
|
|
|
hash_list = RTE_TAILQ_CAST(rte_hash_tailq.head, rte_hash_list);
|
|
|
|
|
|
|
|
if (params == NULL) {
|
|
|
|
RTE_LOG(ERR, HASH, "rte_hash_create has no parameters\n");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Check for valid parameters */
|
|
|
|
if ((params->entries > RTE_HASH_ENTRIES_MAX) ||
|
|
|
|
(params->entries < RTE_HASH_BUCKET_ENTRIES) ||
|
|
|
|
!rte_is_power_of_2(RTE_HASH_BUCKET_ENTRIES) ||
|
|
|
|
(params->key_len == 0)) {
|
|
|
|
rte_errno = EINVAL;
|
|
|
|
RTE_LOG(ERR, HASH, "rte_hash_create has invalid parameters\n");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2015-10-30 14:37:28 +00:00
|
|
|
/* Check extra flags field to check extra options. */
|
|
|
|
if (params->extra_flag & RTE_HASH_EXTRA_FLAGS_TRANS_MEM_SUPPORT)
|
|
|
|
hw_trans_mem_support = 1;
|
|
|
|
|
2016-04-06 15:28:00 +02:00
|
|
|
/* Store all keys and leave the first entry as a dummy entry for lookup_bulk */
|
|
|
|
if (hw_trans_mem_support)
|
|
|
|
/*
|
|
|
|
* Increase number of slots by total number of indices
|
|
|
|
* that can be stored in the lcore caches
|
|
|
|
* except for the first cache
|
|
|
|
*/
|
|
|
|
num_key_slots = params->entries + (RTE_MAX_LCORE - 1) *
|
|
|
|
LCORE_CACHE_SIZE + 1;
|
|
|
|
else
|
|
|
|
num_key_slots = params->entries + 1;
|
|
|
|
|
|
|
|
snprintf(ring_name, sizeof(ring_name), "HT_%s", params->name);
|
2016-08-26 22:30:07 +01:00
|
|
|
/* Create ring (Dummy slot index is not enqueued) */
|
|
|
|
r = rte_ring_create(ring_name, rte_align32pow2(num_key_slots - 1),
|
2016-04-06 15:28:00 +02:00
|
|
|
params->socket_id, 0);
|
|
|
|
if (r == NULL) {
|
|
|
|
RTE_LOG(ERR, HASH, "memory allocation failed\n");
|
|
|
|
goto err;
|
|
|
|
}
|
|
|
|
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
snprintf(hash_name, sizeof(hash_name), "HT_%s", params->name);
|
|
|
|
|
2016-04-06 15:28:00 +02:00
|
|
|
rte_rwlock_write_lock(RTE_EAL_TAILQ_RWLOCK);
|
|
|
|
|
|
|
|
/* guarantee there's no existing: this is normally already checked
|
|
|
|
* by ring creation above */
|
|
|
|
TAILQ_FOREACH(te, hash_list, next) {
|
|
|
|
h = (struct rte_hash *) te->data;
|
|
|
|
if (strncmp(params->name, h->name, RTE_HASH_NAMESIZE) == 0)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
h = NULL;
|
|
|
|
if (te != NULL) {
|
2016-04-06 15:27:59 +02:00
|
|
|
rte_errno = EEXIST;
|
2016-04-06 15:28:00 +02:00
|
|
|
te = NULL;
|
|
|
|
goto err_unlock;
|
2016-04-06 15:27:59 +02:00
|
|
|
}
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
|
|
|
te = rte_zmalloc("HASH_TAILQ_ENTRY", sizeof(*te), 0);
|
|
|
|
if (te == NULL) {
|
|
|
|
RTE_LOG(ERR, HASH, "tailq entry allocation failed\n");
|
2016-04-06 15:28:00 +02:00
|
|
|
goto err_unlock;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
h = (struct rte_hash *)rte_zmalloc_socket(hash_name, sizeof(struct rte_hash),
|
|
|
|
RTE_CACHE_LINE_SIZE, params->socket_id);
|
|
|
|
|
|
|
|
if (h == NULL) {
|
|
|
|
RTE_LOG(ERR, HASH, "memory allocation failed\n");
|
2016-04-06 15:28:00 +02:00
|
|
|
goto err_unlock;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
const uint32_t num_buckets = rte_align32pow2(params->entries)
|
|
|
|
/ RTE_HASH_BUCKET_ENTRIES;
|
|
|
|
|
|
|
|
buckets = rte_zmalloc_socket(NULL,
|
|
|
|
num_buckets * sizeof(struct rte_hash_bucket),
|
|
|
|
RTE_CACHE_LINE_SIZE, params->socket_id);
|
|
|
|
|
|
|
|
if (buckets == NULL) {
|
|
|
|
RTE_LOG(ERR, HASH, "memory allocation failed\n");
|
2016-04-06 15:28:00 +02:00
|
|
|
goto err_unlock;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
|
2015-07-11 01:18:52 +01:00
|
|
|
const uint32_t key_entry_size = sizeof(struct rte_hash_key) + params->key_len;
|
2015-10-30 14:37:28 +00:00
|
|
|
const uint64_t key_tbl_size = (uint64_t) key_entry_size * num_key_slots;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
|
|
|
k = rte_zmalloc_socket(NULL, key_tbl_size,
|
|
|
|
RTE_CACHE_LINE_SIZE, params->socket_id);
|
|
|
|
|
|
|
|
if (k == NULL) {
|
|
|
|
RTE_LOG(ERR, HASH, "memory allocation failed\n");
|
2016-04-06 15:28:00 +02:00
|
|
|
goto err_unlock;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
|
2015-07-17 10:17:58 +01:00
|
|
|
/*
|
|
|
|
* If x86 architecture is used, select appropriate compare function,
|
2016-06-16 15:14:14 -07:00
|
|
|
* which may use x86 intrinsics, otherwise use memcmp
|
2015-07-17 10:17:58 +01:00
|
|
|
*/
|
2016-04-01 16:03:48 +01:00
|
|
|
#if defined(RTE_ARCH_X86) || defined(RTE_ARCH_ARM64)
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
/* Select function to compare keys */
|
|
|
|
switch (params->key_len) {
|
|
|
|
case 16:
|
2016-04-01 16:03:49 +01:00
|
|
|
h->cmp_jump_table_idx = KEY_16_BYTES;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
break;
|
|
|
|
case 32:
|
2016-04-01 16:03:49 +01:00
|
|
|
h->cmp_jump_table_idx = KEY_32_BYTES;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
break;
|
|
|
|
case 48:
|
2016-04-01 16:03:49 +01:00
|
|
|
h->cmp_jump_table_idx = KEY_48_BYTES;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
break;
|
|
|
|
case 64:
|
2016-04-01 16:03:49 +01:00
|
|
|
h->cmp_jump_table_idx = KEY_64_BYTES;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
break;
|
|
|
|
case 80:
|
2016-04-01 16:03:49 +01:00
|
|
|
h->cmp_jump_table_idx = KEY_80_BYTES;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
break;
|
|
|
|
case 96:
|
2016-04-01 16:03:49 +01:00
|
|
|
h->cmp_jump_table_idx = KEY_96_BYTES;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
break;
|
|
|
|
case 112:
|
2016-04-01 16:03:49 +01:00
|
|
|
h->cmp_jump_table_idx = KEY_112_BYTES;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
break;
|
|
|
|
case 128:
|
2016-04-01 16:03:49 +01:00
|
|
|
h->cmp_jump_table_idx = KEY_128_BYTES;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
/* If key is not multiple of 16, use generic memcmp */
|
2016-04-01 16:03:49 +01:00
|
|
|
h->cmp_jump_table_idx = KEY_OTHER_BYTES;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
2015-07-17 10:17:58 +01:00
|
|
|
#else
|
2016-04-01 16:03:49 +01:00
|
|
|
h->cmp_jump_table_idx = KEY_OTHER_BYTES;
|
2015-07-17 10:17:58 +01:00
|
|
|
#endif
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2015-10-30 14:37:28 +00:00
|
|
|
if (hw_trans_mem_support) {
|
|
|
|
h->local_free_slots = rte_zmalloc_socket(NULL,
|
|
|
|
sizeof(struct lcore_cache) * RTE_MAX_LCORE,
|
|
|
|
RTE_CACHE_LINE_SIZE, params->socket_id);
|
|
|
|
}
|
|
|
|
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
/* Setup hash context */
|
|
|
|
snprintf(h->name, sizeof(h->name), "%s", params->name);
|
|
|
|
h->entries = params->entries;
|
|
|
|
h->key_len = params->key_len;
|
|
|
|
h->key_entry_size = key_entry_size;
|
|
|
|
h->hash_func_init_val = params->hash_func_init_val;
|
|
|
|
|
|
|
|
h->num_buckets = num_buckets;
|
|
|
|
h->bucket_bitmask = h->num_buckets - 1;
|
|
|
|
h->buckets = buckets;
|
|
|
|
h->hash_func = (params->hash_func == NULL) ?
|
|
|
|
DEFAULT_HASH_FUNC : params->hash_func;
|
|
|
|
h->key_store = k;
|
|
|
|
h->free_slots = r;
|
2015-10-30 14:37:28 +00:00
|
|
|
h->hw_trans_mem_support = hw_trans_mem_support;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-10-05 00:25:14 +01:00
|
|
|
#if defined(RTE_ARCH_X86)
|
|
|
|
if (rte_cpu_get_flag_enabled(RTE_CPUFLAG_AVX2))
|
|
|
|
h->sig_cmp_fn = RTE_HASH_COMPARE_AVX2;
|
|
|
|
else if (rte_cpu_get_flag_enabled(RTE_CPUFLAG_SSE2))
|
|
|
|
h->sig_cmp_fn = RTE_HASH_COMPARE_SSE;
|
|
|
|
else
|
|
|
|
#endif
|
|
|
|
h->sig_cmp_fn = RTE_HASH_COMPARE_SCALAR;
|
|
|
|
|
2016-06-16 15:14:14 -07:00
|
|
|
/* Turn on multi-writer only with explicit flat from user and TM
|
|
|
|
* support.
|
|
|
|
*/
|
|
|
|
if (params->extra_flag & RTE_HASH_EXTRA_FLAGS_MULTI_WRITER_ADD) {
|
|
|
|
if (h->hw_trans_mem_support) {
|
|
|
|
h->add_key = ADD_KEY_MULTIWRITER_TM;
|
|
|
|
} else {
|
|
|
|
h->add_key = ADD_KEY_MULTIWRITER;
|
|
|
|
h->multiwriter_lock = rte_malloc(NULL,
|
|
|
|
sizeof(rte_spinlock_t),
|
|
|
|
LCORE_CACHE_SIZE);
|
|
|
|
rte_spinlock_init(h->multiwriter_lock);
|
|
|
|
}
|
|
|
|
} else
|
|
|
|
h->add_key = ADD_KEY_SINGLEWRITER;
|
|
|
|
|
|
|
|
/* Populate free slots ring. Entry zero is reserved for key misses. */
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
for (i = 1; i < params->entries + 1; i++)
|
|
|
|
rte_ring_sp_enqueue(r, (void *)((uintptr_t) i));
|
|
|
|
|
|
|
|
te->data = (void *) h;
|
|
|
|
TAILQ_INSERT_TAIL(hash_list, te, next);
|
|
|
|
rte_rwlock_write_unlock(RTE_EAL_TAILQ_RWLOCK);
|
|
|
|
|
|
|
|
return h;
|
2016-04-06 15:28:00 +02:00
|
|
|
err_unlock:
|
|
|
|
rte_rwlock_write_unlock(RTE_EAL_TAILQ_RWLOCK);
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
err:
|
2016-04-06 15:28:00 +02:00
|
|
|
rte_ring_free(r);
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
rte_free(te);
|
|
|
|
rte_free(h);
|
|
|
|
rte_free(buckets);
|
|
|
|
rte_free(k);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
rte_hash_free(struct rte_hash *h)
|
|
|
|
{
|
|
|
|
struct rte_tailq_entry *te;
|
|
|
|
struct rte_hash_list *hash_list;
|
|
|
|
|
|
|
|
if (h == NULL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
hash_list = RTE_TAILQ_CAST(rte_hash_tailq.head, rte_hash_list);
|
|
|
|
|
|
|
|
rte_rwlock_write_lock(RTE_EAL_TAILQ_RWLOCK);
|
|
|
|
|
|
|
|
/* find out tailq entry */
|
|
|
|
TAILQ_FOREACH(te, hash_list, next) {
|
|
|
|
if (te->data == (void *) h)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (te == NULL) {
|
|
|
|
rte_rwlock_write_unlock(RTE_EAL_TAILQ_RWLOCK);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
TAILQ_REMOVE(hash_list, te, next);
|
|
|
|
|
|
|
|
rte_rwlock_write_unlock(RTE_EAL_TAILQ_RWLOCK);
|
|
|
|
|
2015-10-30 14:37:28 +00:00
|
|
|
if (h->hw_trans_mem_support)
|
|
|
|
rte_free(h->local_free_slots);
|
|
|
|
|
2016-06-16 15:14:14 -07:00
|
|
|
if (h->add_key == ADD_KEY_MULTIWRITER)
|
|
|
|
rte_free(h->multiwriter_lock);
|
2015-10-02 17:07:13 +01:00
|
|
|
rte_ring_free(h->free_slots);
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
rte_free(h->key_store);
|
|
|
|
rte_free(h->buckets);
|
|
|
|
rte_free(h);
|
|
|
|
rte_free(te);
|
|
|
|
}
|
|
|
|
|
|
|
|
hash_sig_t
|
|
|
|
rte_hash_hash(const struct rte_hash *h, const void *key)
|
|
|
|
{
|
|
|
|
/* calc hash result by key */
|
|
|
|
return h->hash_func(key, h->key_len, h->hash_func_init_val);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Calc the secondary hash value from the primary hash value of a given key */
|
|
|
|
static inline hash_sig_t
|
|
|
|
rte_hash_secondary_hash(const hash_sig_t primary_hash)
|
|
|
|
{
|
|
|
|
static const unsigned all_bits_shift = 12;
|
|
|
|
static const unsigned alt_bits_xor = 0x5bd1e995;
|
|
|
|
|
|
|
|
uint32_t tag = primary_hash >> all_bits_shift;
|
|
|
|
|
2016-01-27 21:58:30 +08:00
|
|
|
return primary_hash ^ ((tag + 1) * alt_bits_xor);
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
|
2015-07-11 01:18:51 +01:00
|
|
|
void
|
|
|
|
rte_hash_reset(struct rte_hash *h)
|
|
|
|
{
|
|
|
|
void *ptr;
|
|
|
|
unsigned i;
|
|
|
|
|
|
|
|
if (h == NULL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
memset(h->buckets, 0, h->num_buckets * sizeof(struct rte_hash_bucket));
|
|
|
|
memset(h->key_store, 0, h->key_entry_size * (h->entries + 1));
|
|
|
|
|
|
|
|
/* clear the free ring */
|
|
|
|
while (rte_ring_dequeue(h->free_slots, &ptr) == 0)
|
|
|
|
rte_pause();
|
|
|
|
|
|
|
|
/* Repopulate the free slots ring. Entry zero is reserved for key misses */
|
|
|
|
for (i = 1; i < h->entries + 1; i++)
|
|
|
|
rte_ring_sp_enqueue(h->free_slots, (void *)((uintptr_t) i));
|
2015-10-30 14:37:28 +00:00
|
|
|
|
|
|
|
if (h->hw_trans_mem_support) {
|
|
|
|
/* Reset local caches per lcore */
|
|
|
|
for (i = 0; i < RTE_MAX_LCORE; i++)
|
|
|
|
h->local_free_slots[i].len = 0;
|
|
|
|
}
|
2015-07-11 01:18:51 +01:00
|
|
|
}
|
|
|
|
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
/* Search for an entry that can be pushed to its alternative location */
|
|
|
|
static inline int
|
|
|
|
make_space_bucket(const struct rte_hash *h, struct rte_hash_bucket *bkt)
|
|
|
|
{
|
2016-10-12 01:50:13 +01:00
|
|
|
static unsigned int nr_pushes;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
unsigned i, j;
|
|
|
|
int ret;
|
|
|
|
uint32_t next_bucket_idx;
|
|
|
|
struct rte_hash_bucket *next_bkt[RTE_HASH_BUCKET_ENTRIES];
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Push existing item (search for bucket with space in
|
|
|
|
* alternative locations) to its alternative location
|
|
|
|
*/
|
|
|
|
for (i = 0; i < RTE_HASH_BUCKET_ENTRIES; i++) {
|
|
|
|
/* Search for space in alternative locations */
|
2016-10-05 00:25:13 +01:00
|
|
|
next_bucket_idx = bkt->sig_alt[i] & h->bucket_bitmask;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
next_bkt[i] = &h->buckets[next_bucket_idx];
|
|
|
|
for (j = 0; j < RTE_HASH_BUCKET_ENTRIES; j++) {
|
2016-08-26 22:30:09 +01:00
|
|
|
if (next_bkt[i]->key_idx[j] == EMPTY_SLOT)
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (j != RTE_HASH_BUCKET_ENTRIES)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Alternative location has spare room (end of recursive function) */
|
|
|
|
if (i != RTE_HASH_BUCKET_ENTRIES) {
|
2016-10-05 00:25:13 +01:00
|
|
|
next_bkt[i]->sig_alt[j] = bkt->sig_current[i];
|
|
|
|
next_bkt[i]->sig_current[j] = bkt->sig_alt[i];
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
next_bkt[i]->key_idx[j] = bkt->key_idx[i];
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Pick entry that has not been pushed yet */
|
|
|
|
for (i = 0; i < RTE_HASH_BUCKET_ENTRIES; i++)
|
|
|
|
if (bkt->flag[i] == 0)
|
|
|
|
break;
|
|
|
|
|
|
|
|
/* All entries have been pushed, so entry cannot be added */
|
2016-10-12 01:50:13 +01:00
|
|
|
if (i == RTE_HASH_BUCKET_ENTRIES || nr_pushes > RTE_HASH_MAX_PUSHES)
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
return -ENOSPC;
|
|
|
|
|
|
|
|
/* Set flag to indicate that this entry is going to be pushed */
|
|
|
|
bkt->flag[i] = 1;
|
2016-10-12 01:50:13 +01:00
|
|
|
|
|
|
|
nr_pushes++;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
/* Need room in alternative bucket to insert the pushed entry */
|
|
|
|
ret = make_space_bucket(h, next_bkt[i]);
|
|
|
|
/*
|
|
|
|
* After recursive function.
|
|
|
|
* Clear flags and insert the pushed entry
|
|
|
|
* in its alternative location if successful,
|
|
|
|
* or return error
|
|
|
|
*/
|
|
|
|
bkt->flag[i] = 0;
|
2016-10-12 01:50:13 +01:00
|
|
|
nr_pushes = 0;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
if (ret >= 0) {
|
2016-10-05 00:25:13 +01:00
|
|
|
next_bkt[i]->sig_alt[ret] = bkt->sig_current[i];
|
|
|
|
next_bkt[i]->sig_current[ret] = bkt->sig_alt[i];
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
next_bkt[i]->key_idx[ret] = bkt->key_idx[i];
|
|
|
|
return i;
|
|
|
|
} else
|
|
|
|
return ret;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2015-10-30 14:37:28 +00:00
|
|
|
/*
|
|
|
|
* Function called to enqueue back an index in the cache/ring,
|
|
|
|
* as slot has not being used and it can be used in the
|
|
|
|
* next addition attempt.
|
|
|
|
*/
|
|
|
|
static inline void
|
|
|
|
enqueue_slot_back(const struct rte_hash *h,
|
|
|
|
struct lcore_cache *cached_free_slots,
|
|
|
|
void *slot_id)
|
|
|
|
{
|
|
|
|
if (h->hw_trans_mem_support) {
|
|
|
|
cached_free_slots->objs[cached_free_slots->len] = slot_id;
|
|
|
|
cached_free_slots->len++;
|
|
|
|
} else
|
|
|
|
rte_ring_sp_enqueue(h->free_slots, slot_id);
|
|
|
|
}
|
|
|
|
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
static inline int32_t
|
|
|
|
__rte_hash_add_key_with_hash(const struct rte_hash *h, const void *key,
|
2015-07-11 01:18:52 +01:00
|
|
|
hash_sig_t sig, void *data)
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
{
|
|
|
|
hash_sig_t alt_hash;
|
|
|
|
uint32_t prim_bucket_idx, sec_bucket_idx;
|
|
|
|
unsigned i;
|
|
|
|
struct rte_hash_bucket *prim_bkt, *sec_bkt;
|
2015-07-11 01:18:52 +01:00
|
|
|
struct rte_hash_key *new_k, *k, *keys = h->key_store;
|
2015-10-30 14:37:28 +00:00
|
|
|
void *slot_id = NULL;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
uint32_t new_idx;
|
|
|
|
int ret;
|
2015-10-30 14:37:28 +00:00
|
|
|
unsigned n_slots;
|
|
|
|
unsigned lcore_id;
|
|
|
|
struct lcore_cache *cached_free_slots = NULL;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-06-16 15:14:14 -07:00
|
|
|
if (h->add_key == ADD_KEY_MULTIWRITER)
|
|
|
|
rte_spinlock_lock(h->multiwriter_lock);
|
|
|
|
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
prim_bucket_idx = sig & h->bucket_bitmask;
|
|
|
|
prim_bkt = &h->buckets[prim_bucket_idx];
|
|
|
|
rte_prefetch0(prim_bkt);
|
|
|
|
|
|
|
|
alt_hash = rte_hash_secondary_hash(sig);
|
|
|
|
sec_bucket_idx = alt_hash & h->bucket_bitmask;
|
|
|
|
sec_bkt = &h->buckets[sec_bucket_idx];
|
|
|
|
rte_prefetch0(sec_bkt);
|
|
|
|
|
|
|
|
/* Get a new slot for storing the new key */
|
2015-10-30 14:37:28 +00:00
|
|
|
if (h->hw_trans_mem_support) {
|
|
|
|
lcore_id = rte_lcore_id();
|
|
|
|
cached_free_slots = &h->local_free_slots[lcore_id];
|
|
|
|
/* Try to get a free slot from the local cache */
|
|
|
|
if (cached_free_slots->len == 0) {
|
|
|
|
/* Need to get another burst of free slots from global ring */
|
|
|
|
n_slots = rte_ring_mc_dequeue_burst(h->free_slots,
|
2017-03-29 16:21:25 +01:00
|
|
|
cached_free_slots->objs,
|
|
|
|
LCORE_CACHE_SIZE, NULL);
|
2015-10-30 14:37:28 +00:00
|
|
|
if (n_slots == 0)
|
|
|
|
return -ENOSPC;
|
|
|
|
|
|
|
|
cached_free_slots->len += n_slots;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Get a free slot from the local cache */
|
|
|
|
cached_free_slots->len--;
|
|
|
|
slot_id = cached_free_slots->objs[cached_free_slots->len];
|
|
|
|
} else {
|
|
|
|
if (rte_ring_sc_dequeue(h->free_slots, &slot_id) != 0)
|
|
|
|
return -ENOSPC;
|
|
|
|
}
|
|
|
|
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
new_k = RTE_PTR_ADD(keys, (uintptr_t)slot_id * h->key_entry_size);
|
|
|
|
rte_prefetch0(new_k);
|
|
|
|
new_idx = (uint32_t)((uintptr_t) slot_id);
|
|
|
|
|
|
|
|
/* Check if key is already inserted in primary location */
|
|
|
|
for (i = 0; i < RTE_HASH_BUCKET_ENTRIES; i++) {
|
2016-10-05 00:25:13 +01:00
|
|
|
if (prim_bkt->sig_current[i] == sig &&
|
|
|
|
prim_bkt->sig_alt[i] == alt_hash) {
|
2015-07-11 01:18:52 +01:00
|
|
|
k = (struct rte_hash_key *) ((char *)keys +
|
|
|
|
prim_bkt->key_idx[i] * h->key_entry_size);
|
2016-04-01 16:03:49 +01:00
|
|
|
if (rte_hash_cmp_eq(key, k->key, h) == 0) {
|
2015-10-30 14:37:28 +00:00
|
|
|
/* Enqueue index of free slot back in the ring. */
|
|
|
|
enqueue_slot_back(h, cached_free_slots, slot_id);
|
2015-07-11 01:18:52 +01:00
|
|
|
/* Update data */
|
|
|
|
k->pdata = data;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
/*
|
|
|
|
* Return index where key is stored,
|
2017-06-07 10:35:06 +05:30
|
|
|
* subtracting the first dummy index
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
*/
|
2016-01-27 21:58:30 +08:00
|
|
|
return prim_bkt->key_idx[i] - 1;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Check if key is already inserted in secondary location */
|
|
|
|
for (i = 0; i < RTE_HASH_BUCKET_ENTRIES; i++) {
|
2016-10-05 00:25:13 +01:00
|
|
|
if (sec_bkt->sig_alt[i] == sig &&
|
|
|
|
sec_bkt->sig_current[i] == alt_hash) {
|
2015-07-11 01:18:52 +01:00
|
|
|
k = (struct rte_hash_key *) ((char *)keys +
|
|
|
|
sec_bkt->key_idx[i] * h->key_entry_size);
|
2016-04-01 16:03:49 +01:00
|
|
|
if (rte_hash_cmp_eq(key, k->key, h) == 0) {
|
2015-10-30 14:37:28 +00:00
|
|
|
/* Enqueue index of free slot back in the ring. */
|
|
|
|
enqueue_slot_back(h, cached_free_slots, slot_id);
|
2015-07-11 01:18:52 +01:00
|
|
|
/* Update data */
|
|
|
|
k->pdata = data;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
/*
|
|
|
|
* Return index where key is stored,
|
2017-06-07 10:35:06 +05:30
|
|
|
* subtracting the first dummy index
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
*/
|
2016-01-27 21:58:30 +08:00
|
|
|
return sec_bkt->key_idx[i] - 1;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Copy key */
|
2015-07-11 01:18:52 +01:00
|
|
|
rte_memcpy(new_k->key, key, h->key_len);
|
|
|
|
new_k->pdata = data;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-06-16 15:14:14 -07:00
|
|
|
#if defined(RTE_ARCH_X86) /* currently only x86 support HTM */
|
|
|
|
if (h->add_key == ADD_KEY_MULTIWRITER_TM) {
|
|
|
|
ret = rte_hash_cuckoo_insert_mw_tm(prim_bkt,
|
|
|
|
sig, alt_hash, new_idx);
|
|
|
|
if (ret >= 0)
|
|
|
|
return new_idx - 1;
|
|
|
|
|
|
|
|
/* Primary bucket full, need to make space for new entry */
|
|
|
|
ret = rte_hash_cuckoo_make_space_mw_tm(h, prim_bkt, sig,
|
|
|
|
alt_hash, new_idx);
|
|
|
|
|
|
|
|
if (ret >= 0)
|
|
|
|
return new_idx - 1;
|
|
|
|
|
|
|
|
/* Also search secondary bucket to get better occupancy */
|
|
|
|
ret = rte_hash_cuckoo_make_space_mw_tm(h, sec_bkt, sig,
|
|
|
|
alt_hash, new_idx);
|
|
|
|
|
|
|
|
if (ret >= 0)
|
|
|
|
return new_idx - 1;
|
|
|
|
} else {
|
|
|
|
#endif
|
|
|
|
for (i = 0; i < RTE_HASH_BUCKET_ENTRIES; i++) {
|
|
|
|
/* Check if slot is available */
|
2016-08-26 22:30:09 +01:00
|
|
|
if (likely(prim_bkt->key_idx[i] == EMPTY_SLOT)) {
|
2016-10-05 00:25:13 +01:00
|
|
|
prim_bkt->sig_current[i] = sig;
|
|
|
|
prim_bkt->sig_alt[i] = alt_hash;
|
2016-06-16 15:14:14 -07:00
|
|
|
prim_bkt->key_idx[i] = new_idx;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (i != RTE_HASH_BUCKET_ENTRIES) {
|
|
|
|
if (h->add_key == ADD_KEY_MULTIWRITER)
|
|
|
|
rte_spinlock_unlock(h->multiwriter_lock);
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
return new_idx - 1;
|
|
|
|
}
|
|
|
|
|
2016-06-16 15:14:14 -07:00
|
|
|
/* Primary bucket full, need to make space for new entry
|
|
|
|
* After recursive function.
|
|
|
|
* Insert the new entry in the position of the pushed entry
|
|
|
|
* if successful or return error and
|
|
|
|
* store the new slot back in the ring
|
|
|
|
*/
|
|
|
|
ret = make_space_bucket(h, prim_bkt);
|
|
|
|
if (ret >= 0) {
|
2016-10-05 00:25:13 +01:00
|
|
|
prim_bkt->sig_current[ret] = sig;
|
|
|
|
prim_bkt->sig_alt[ret] = alt_hash;
|
2016-06-16 15:14:14 -07:00
|
|
|
prim_bkt->key_idx[ret] = new_idx;
|
|
|
|
if (h->add_key == ADD_KEY_MULTIWRITER)
|
|
|
|
rte_spinlock_unlock(h->multiwriter_lock);
|
|
|
|
return new_idx - 1;
|
|
|
|
}
|
|
|
|
#if defined(RTE_ARCH_X86)
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
2016-06-16 15:14:14 -07:00
|
|
|
#endif
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
/* Error in addition, store new slot back in the ring and return error */
|
2015-10-30 14:37:28 +00:00
|
|
|
enqueue_slot_back(h, cached_free_slots, (void *)((uintptr_t) new_idx));
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-06-16 15:14:14 -07:00
|
|
|
if (h->add_key == ADD_KEY_MULTIWRITER)
|
|
|
|
rte_spinlock_unlock(h->multiwriter_lock);
|
2015-10-30 14:37:28 +00:00
|
|
|
return ret;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int32_t
|
|
|
|
rte_hash_add_key_with_hash(const struct rte_hash *h,
|
|
|
|
const void *key, hash_sig_t sig)
|
|
|
|
{
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (key == NULL)), -EINVAL);
|
2015-07-11 01:18:52 +01:00
|
|
|
return __rte_hash_add_key_with_hash(h, key, sig, 0);
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int32_t
|
|
|
|
rte_hash_add_key(const struct rte_hash *h, const void *key)
|
|
|
|
{
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (key == NULL)), -EINVAL);
|
2015-07-11 01:18:52 +01:00
|
|
|
return __rte_hash_add_key_with_hash(h, key, rte_hash_hash(h, key), 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
rte_hash_add_key_with_hash_data(const struct rte_hash *h,
|
|
|
|
const void *key, hash_sig_t sig, void *data)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (key == NULL)), -EINVAL);
|
|
|
|
ret = __rte_hash_add_key_with_hash(h, key, sig, data);
|
|
|
|
if (ret >= 0)
|
|
|
|
return 0;
|
|
|
|
else
|
|
|
|
return ret;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
|
2015-07-11 01:18:52 +01:00
|
|
|
int
|
|
|
|
rte_hash_add_key_data(const struct rte_hash *h, const void *key, void *data)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (key == NULL)), -EINVAL);
|
|
|
|
|
|
|
|
ret = __rte_hash_add_key_with_hash(h, key, rte_hash_hash(h, key), data);
|
|
|
|
if (ret >= 0)
|
|
|
|
return 0;
|
|
|
|
else
|
|
|
|
return ret;
|
|
|
|
}
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
static inline int32_t
|
|
|
|
__rte_hash_lookup_with_hash(const struct rte_hash *h, const void *key,
|
2015-07-11 01:18:52 +01:00
|
|
|
hash_sig_t sig, void **data)
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
{
|
|
|
|
uint32_t bucket_idx;
|
|
|
|
hash_sig_t alt_hash;
|
|
|
|
unsigned i;
|
|
|
|
struct rte_hash_bucket *bkt;
|
2015-07-11 01:18:52 +01:00
|
|
|
struct rte_hash_key *k, *keys = h->key_store;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
|
|
|
bucket_idx = sig & h->bucket_bitmask;
|
|
|
|
bkt = &h->buckets[bucket_idx];
|
|
|
|
|
|
|
|
/* Check if key is in primary location */
|
|
|
|
for (i = 0; i < RTE_HASH_BUCKET_ENTRIES; i++) {
|
2016-10-05 00:25:13 +01:00
|
|
|
if (bkt->sig_current[i] == sig &&
|
2016-08-26 22:30:09 +01:00
|
|
|
bkt->key_idx[i] != EMPTY_SLOT) {
|
2015-07-11 01:18:52 +01:00
|
|
|
k = (struct rte_hash_key *) ((char *)keys +
|
|
|
|
bkt->key_idx[i] * h->key_entry_size);
|
2016-04-01 16:03:49 +01:00
|
|
|
if (rte_hash_cmp_eq(key, k->key, h) == 0) {
|
2015-07-11 01:18:52 +01:00
|
|
|
if (data != NULL)
|
|
|
|
*data = k->pdata;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
/*
|
|
|
|
* Return index where key is stored,
|
2017-06-07 10:35:06 +05:30
|
|
|
* subtracting the first dummy index
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
*/
|
2016-01-27 21:58:30 +08:00
|
|
|
return bkt->key_idx[i] - 1;
|
2015-07-11 01:18:52 +01:00
|
|
|
}
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Calculate secondary hash */
|
|
|
|
alt_hash = rte_hash_secondary_hash(sig);
|
|
|
|
bucket_idx = alt_hash & h->bucket_bitmask;
|
|
|
|
bkt = &h->buckets[bucket_idx];
|
|
|
|
|
|
|
|
/* Check if key is in secondary location */
|
|
|
|
for (i = 0; i < RTE_HASH_BUCKET_ENTRIES; i++) {
|
2016-10-05 00:25:13 +01:00
|
|
|
if (bkt->sig_current[i] == alt_hash &&
|
|
|
|
bkt->sig_alt[i] == sig) {
|
2015-07-11 01:18:52 +01:00
|
|
|
k = (struct rte_hash_key *) ((char *)keys +
|
|
|
|
bkt->key_idx[i] * h->key_entry_size);
|
2016-04-01 16:03:49 +01:00
|
|
|
if (rte_hash_cmp_eq(key, k->key, h) == 0) {
|
2015-07-11 01:18:52 +01:00
|
|
|
if (data != NULL)
|
|
|
|
*data = k->pdata;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
/*
|
|
|
|
* Return index where key is stored,
|
2017-06-07 10:35:06 +05:30
|
|
|
* subtracting the first dummy index
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
*/
|
2016-01-27 21:58:30 +08:00
|
|
|
return bkt->key_idx[i] - 1;
|
2015-07-11 01:18:52 +01:00
|
|
|
}
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return -ENOENT;
|
|
|
|
}
|
|
|
|
|
|
|
|
int32_t
|
|
|
|
rte_hash_lookup_with_hash(const struct rte_hash *h,
|
|
|
|
const void *key, hash_sig_t sig)
|
|
|
|
{
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (key == NULL)), -EINVAL);
|
2015-07-11 01:18:52 +01:00
|
|
|
return __rte_hash_lookup_with_hash(h, key, sig, NULL);
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int32_t
|
|
|
|
rte_hash_lookup(const struct rte_hash *h, const void *key)
|
|
|
|
{
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (key == NULL)), -EINVAL);
|
2015-07-11 01:18:52 +01:00
|
|
|
return __rte_hash_lookup_with_hash(h, key, rte_hash_hash(h, key), NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
rte_hash_lookup_with_hash_data(const struct rte_hash *h,
|
|
|
|
const void *key, hash_sig_t sig, void **data)
|
|
|
|
{
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (key == NULL)), -EINVAL);
|
|
|
|
return __rte_hash_lookup_with_hash(h, key, sig, data);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
rte_hash_lookup_data(const struct rte_hash *h, const void *key, void **data)
|
|
|
|
{
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (key == NULL)), -EINVAL);
|
|
|
|
return __rte_hash_lookup_with_hash(h, key, rte_hash_hash(h, key), data);
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
|
2015-10-30 14:37:28 +00:00
|
|
|
static inline void
|
|
|
|
remove_entry(const struct rte_hash *h, struct rte_hash_bucket *bkt, unsigned i)
|
|
|
|
{
|
|
|
|
unsigned lcore_id, n_slots;
|
|
|
|
struct lcore_cache *cached_free_slots;
|
|
|
|
|
2016-10-05 00:25:13 +01:00
|
|
|
bkt->sig_current[i] = NULL_SIGNATURE;
|
|
|
|
bkt->sig_alt[i] = NULL_SIGNATURE;
|
2015-10-30 14:37:28 +00:00
|
|
|
if (h->hw_trans_mem_support) {
|
|
|
|
lcore_id = rte_lcore_id();
|
|
|
|
cached_free_slots = &h->local_free_slots[lcore_id];
|
|
|
|
/* Cache full, need to free it. */
|
|
|
|
if (cached_free_slots->len == LCORE_CACHE_SIZE) {
|
|
|
|
/* Need to enqueue the free slots in global ring. */
|
|
|
|
n_slots = rte_ring_mp_enqueue_burst(h->free_slots,
|
|
|
|
cached_free_slots->objs,
|
2017-03-29 16:21:24 +01:00
|
|
|
LCORE_CACHE_SIZE, NULL);
|
2015-10-30 14:37:28 +00:00
|
|
|
cached_free_slots->len -= n_slots;
|
|
|
|
}
|
|
|
|
/* Put index of new free slot in cache. */
|
|
|
|
cached_free_slots->objs[cached_free_slots->len] =
|
|
|
|
(void *)((uintptr_t)bkt->key_idx[i]);
|
|
|
|
cached_free_slots->len++;
|
|
|
|
} else {
|
|
|
|
rte_ring_sp_enqueue(h->free_slots,
|
|
|
|
(void *)((uintptr_t)bkt->key_idx[i]));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
static inline int32_t
|
|
|
|
__rte_hash_del_key_with_hash(const struct rte_hash *h, const void *key,
|
|
|
|
hash_sig_t sig)
|
|
|
|
{
|
|
|
|
uint32_t bucket_idx;
|
|
|
|
hash_sig_t alt_hash;
|
|
|
|
unsigned i;
|
|
|
|
struct rte_hash_bucket *bkt;
|
2015-07-11 01:18:52 +01:00
|
|
|
struct rte_hash_key *k, *keys = h->key_store;
|
hash: fix false zero signature key hit lookup
This commit fixes a corner case scenario. When a key is deleted,
its signature in the hash table gets clear, which should prevent
a lookup of that same key, unless the signature of the key is all zeroes.
In that case, there will be a match, and key would be compared against
the key that is in the table (which does not get cleared,
as the performance penalty would be high), resulting in a wrong hit.
To prevent this from happening, the key index associated to that entry
should be set to zero when deleting it, so in case that same key
is looked up just after a deletion, it will point to the dummy key slot,
which guarantees a miss.
Fixes: 48a399119619 ("hash: replace with cuckoo hash implementation")
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Saikrishna Edupuganti <saikrishna.edupuganti@intel.com>
2016-08-26 22:30:08 +01:00
|
|
|
int32_t ret;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
|
|
|
bucket_idx = sig & h->bucket_bitmask;
|
|
|
|
bkt = &h->buckets[bucket_idx];
|
|
|
|
|
|
|
|
/* Check if key is in primary location */
|
|
|
|
for (i = 0; i < RTE_HASH_BUCKET_ENTRIES; i++) {
|
2016-10-05 00:25:13 +01:00
|
|
|
if (bkt->sig_current[i] == sig &&
|
2016-08-26 22:30:09 +01:00
|
|
|
bkt->key_idx[i] != EMPTY_SLOT) {
|
2015-07-11 01:18:52 +01:00
|
|
|
k = (struct rte_hash_key *) ((char *)keys +
|
|
|
|
bkt->key_idx[i] * h->key_entry_size);
|
2016-04-01 16:03:49 +01:00
|
|
|
if (rte_hash_cmp_eq(key, k->key, h) == 0) {
|
2015-10-30 14:37:28 +00:00
|
|
|
remove_entry(h, bkt, i);
|
|
|
|
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
/*
|
|
|
|
* Return index where key is stored,
|
2017-06-07 10:35:06 +05:30
|
|
|
* subtracting the first dummy index
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
*/
|
hash: fix false zero signature key hit lookup
This commit fixes a corner case scenario. When a key is deleted,
its signature in the hash table gets clear, which should prevent
a lookup of that same key, unless the signature of the key is all zeroes.
In that case, there will be a match, and key would be compared against
the key that is in the table (which does not get cleared,
as the performance penalty would be high), resulting in a wrong hit.
To prevent this from happening, the key index associated to that entry
should be set to zero when deleting it, so in case that same key
is looked up just after a deletion, it will point to the dummy key slot,
which guarantees a miss.
Fixes: 48a399119619 ("hash: replace with cuckoo hash implementation")
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Saikrishna Edupuganti <saikrishna.edupuganti@intel.com>
2016-08-26 22:30:08 +01:00
|
|
|
ret = bkt->key_idx[i] - 1;
|
2016-08-26 22:30:09 +01:00
|
|
|
bkt->key_idx[i] = EMPTY_SLOT;
|
hash: fix false zero signature key hit lookup
This commit fixes a corner case scenario. When a key is deleted,
its signature in the hash table gets clear, which should prevent
a lookup of that same key, unless the signature of the key is all zeroes.
In that case, there will be a match, and key would be compared against
the key that is in the table (which does not get cleared,
as the performance penalty would be high), resulting in a wrong hit.
To prevent this from happening, the key index associated to that entry
should be set to zero when deleting it, so in case that same key
is looked up just after a deletion, it will point to the dummy key slot,
which guarantees a miss.
Fixes: 48a399119619 ("hash: replace with cuckoo hash implementation")
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Saikrishna Edupuganti <saikrishna.edupuganti@intel.com>
2016-08-26 22:30:08 +01:00
|
|
|
return ret;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Calculate secondary hash */
|
|
|
|
alt_hash = rte_hash_secondary_hash(sig);
|
|
|
|
bucket_idx = alt_hash & h->bucket_bitmask;
|
|
|
|
bkt = &h->buckets[bucket_idx];
|
|
|
|
|
|
|
|
/* Check if key is in secondary location */
|
|
|
|
for (i = 0; i < RTE_HASH_BUCKET_ENTRIES; i++) {
|
2016-10-05 00:25:13 +01:00
|
|
|
if (bkt->sig_current[i] == alt_hash &&
|
2016-08-26 22:30:09 +01:00
|
|
|
bkt->key_idx[i] != EMPTY_SLOT) {
|
2015-07-11 01:18:52 +01:00
|
|
|
k = (struct rte_hash_key *) ((char *)keys +
|
|
|
|
bkt->key_idx[i] * h->key_entry_size);
|
2016-04-01 16:03:49 +01:00
|
|
|
if (rte_hash_cmp_eq(key, k->key, h) == 0) {
|
2015-10-30 14:37:28 +00:00
|
|
|
remove_entry(h, bkt, i);
|
|
|
|
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
/*
|
|
|
|
* Return index where key is stored,
|
2017-06-07 10:35:06 +05:30
|
|
|
* subtracting the first dummy index
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
*/
|
hash: fix false zero signature key hit lookup
This commit fixes a corner case scenario. When a key is deleted,
its signature in the hash table gets clear, which should prevent
a lookup of that same key, unless the signature of the key is all zeroes.
In that case, there will be a match, and key would be compared against
the key that is in the table (which does not get cleared,
as the performance penalty would be high), resulting in a wrong hit.
To prevent this from happening, the key index associated to that entry
should be set to zero when deleting it, so in case that same key
is looked up just after a deletion, it will point to the dummy key slot,
which guarantees a miss.
Fixes: 48a399119619 ("hash: replace with cuckoo hash implementation")
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Saikrishna Edupuganti <saikrishna.edupuganti@intel.com>
2016-08-26 22:30:08 +01:00
|
|
|
ret = bkt->key_idx[i] - 1;
|
2016-08-26 22:30:09 +01:00
|
|
|
bkt->key_idx[i] = EMPTY_SLOT;
|
hash: fix false zero signature key hit lookup
This commit fixes a corner case scenario. When a key is deleted,
its signature in the hash table gets clear, which should prevent
a lookup of that same key, unless the signature of the key is all zeroes.
In that case, there will be a match, and key would be compared against
the key that is in the table (which does not get cleared,
as the performance penalty would be high), resulting in a wrong hit.
To prevent this from happening, the key index associated to that entry
should be set to zero when deleting it, so in case that same key
is looked up just after a deletion, it will point to the dummy key slot,
which guarantees a miss.
Fixes: 48a399119619 ("hash: replace with cuckoo hash implementation")
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Saikrishna Edupuganti <saikrishna.edupuganti@intel.com>
2016-08-26 22:30:08 +01:00
|
|
|
return ret;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return -ENOENT;
|
|
|
|
}
|
|
|
|
|
|
|
|
int32_t
|
|
|
|
rte_hash_del_key_with_hash(const struct rte_hash *h,
|
|
|
|
const void *key, hash_sig_t sig)
|
|
|
|
{
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (key == NULL)), -EINVAL);
|
|
|
|
return __rte_hash_del_key_with_hash(h, key, sig);
|
|
|
|
}
|
|
|
|
|
|
|
|
int32_t
|
|
|
|
rte_hash_del_key(const struct rte_hash *h, const void *key)
|
|
|
|
{
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (key == NULL)), -EINVAL);
|
|
|
|
return __rte_hash_del_key_with_hash(h, key, rte_hash_hash(h, key));
|
|
|
|
}
|
|
|
|
|
2016-07-04 10:59:52 +02:00
|
|
|
int
|
|
|
|
rte_hash_get_key_with_position(const struct rte_hash *h, const int32_t position,
|
|
|
|
void **key)
|
|
|
|
{
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (key == NULL)), -EINVAL);
|
|
|
|
|
|
|
|
struct rte_hash_key *k, *keys = h->key_store;
|
|
|
|
k = (struct rte_hash_key *) ((char *) keys + (position + 1) *
|
|
|
|
h->key_entry_size);
|
|
|
|
*key = k->key;
|
|
|
|
|
|
|
|
if (position !=
|
|
|
|
__rte_hash_lookup_with_hash(h, *key, rte_hash_hash(h, *key),
|
|
|
|
NULL)) {
|
|
|
|
return -ENOENT;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
static inline void
|
2016-10-05 00:25:15 +01:00
|
|
|
compare_signatures(uint32_t *prim_hash_matches, uint32_t *sec_hash_matches,
|
2016-10-05 00:25:14 +01:00
|
|
|
const struct rte_hash_bucket *prim_bkt,
|
|
|
|
const struct rte_hash_bucket *sec_bkt,
|
|
|
|
hash_sig_t prim_hash, hash_sig_t sec_hash,
|
|
|
|
enum rte_hash_sig_compare_function sig_cmp_fn)
|
|
|
|
{
|
|
|
|
unsigned int i;
|
|
|
|
|
|
|
|
switch (sig_cmp_fn) {
|
|
|
|
#ifdef RTE_MACHINE_CPUFLAG_AVX2
|
|
|
|
case RTE_HASH_COMPARE_AVX2:
|
2016-10-05 00:25:15 +01:00
|
|
|
*prim_hash_matches = _mm256_movemask_ps((__m256)_mm256_cmpeq_epi32(
|
2016-10-05 00:25:14 +01:00
|
|
|
_mm256_load_si256(
|
|
|
|
(__m256i const *)prim_bkt->sig_current),
|
|
|
|
_mm256_set1_epi32(prim_hash)));
|
2016-10-05 00:25:15 +01:00
|
|
|
*sec_hash_matches = _mm256_movemask_ps((__m256)_mm256_cmpeq_epi32(
|
2016-10-05 00:25:14 +01:00
|
|
|
_mm256_load_si256(
|
|
|
|
(__m256i const *)sec_bkt->sig_current),
|
|
|
|
_mm256_set1_epi32(sec_hash)));
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
#ifdef RTE_MACHINE_CPUFLAG_SSE2
|
|
|
|
case RTE_HASH_COMPARE_SSE:
|
|
|
|
/* Compare the first 4 signatures in the bucket */
|
2016-10-05 00:25:15 +01:00
|
|
|
*prim_hash_matches = _mm_movemask_ps((__m128)_mm_cmpeq_epi16(
|
2016-10-05 00:25:14 +01:00
|
|
|
_mm_load_si128(
|
|
|
|
(__m128i const *)prim_bkt->sig_current),
|
|
|
|
_mm_set1_epi32(prim_hash)));
|
|
|
|
*prim_hash_matches |= (_mm_movemask_ps((__m128)_mm_cmpeq_epi16(
|
|
|
|
_mm_load_si128(
|
|
|
|
(__m128i const *)&prim_bkt->sig_current[4]),
|
|
|
|
_mm_set1_epi32(prim_hash)))) << 4;
|
|
|
|
/* Compare the first 4 signatures in the bucket */
|
2016-10-05 00:25:15 +01:00
|
|
|
*sec_hash_matches = _mm_movemask_ps((__m128)_mm_cmpeq_epi16(
|
2016-10-05 00:25:14 +01:00
|
|
|
_mm_load_si128(
|
|
|
|
(__m128i const *)sec_bkt->sig_current),
|
|
|
|
_mm_set1_epi32(sec_hash)));
|
|
|
|
*sec_hash_matches |= (_mm_movemask_ps((__m128)_mm_cmpeq_epi16(
|
|
|
|
_mm_load_si128(
|
|
|
|
(__m128i const *)&sec_bkt->sig_current[4]),
|
|
|
|
_mm_set1_epi32(sec_hash)))) << 4;
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
default:
|
|
|
|
for (i = 0; i < RTE_HASH_BUCKET_ENTRIES; i++) {
|
|
|
|
*prim_hash_matches |=
|
|
|
|
((prim_hash == prim_bkt->sig_current[i]) << i);
|
|
|
|
*sec_hash_matches |=
|
|
|
|
((sec_hash == sec_bkt->sig_current[i]) << i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
#define PREFETCH_OFFSET 4
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
static inline void
|
2016-10-05 00:25:15 +01:00
|
|
|
__rte_hash_lookup_bulk(const struct rte_hash *h, const void **keys,
|
|
|
|
int32_t num_keys, int32_t *positions,
|
|
|
|
uint64_t *hit_mask, void *data[])
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
{
|
2016-10-05 00:25:15 +01:00
|
|
|
uint64_t hits = 0;
|
|
|
|
int32_t i;
|
|
|
|
uint32_t prim_hash[RTE_HASH_LOOKUP_BULK_MAX];
|
|
|
|
uint32_t sec_hash[RTE_HASH_LOOKUP_BULK_MAX];
|
|
|
|
const struct rte_hash_bucket *primary_bkt[RTE_HASH_LOOKUP_BULK_MAX];
|
|
|
|
const struct rte_hash_bucket *secondary_bkt[RTE_HASH_LOOKUP_BULK_MAX];
|
|
|
|
uint32_t prim_hitmask[RTE_HASH_LOOKUP_BULK_MAX] = {0};
|
|
|
|
uint32_t sec_hitmask[RTE_HASH_LOOKUP_BULK_MAX] = {0};
|
|
|
|
|
|
|
|
/* Prefetch first keys */
|
|
|
|
for (i = 0; i < PREFETCH_OFFSET && i < num_keys; i++)
|
|
|
|
rte_prefetch0(keys[i]);
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
/*
|
|
|
|
* Prefetch rest of the keys, calculate primary and
|
|
|
|
* secondary bucket and prefetch them
|
|
|
|
*/
|
|
|
|
for (i = 0; i < (num_keys - PREFETCH_OFFSET); i++) {
|
|
|
|
rte_prefetch0(keys[i + PREFETCH_OFFSET]);
|
2016-10-05 00:25:14 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
prim_hash[i] = rte_hash_hash(h, keys[i]);
|
|
|
|
sec_hash[i] = rte_hash_secondary_hash(prim_hash[i]);
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
primary_bkt[i] = &h->buckets[prim_hash[i] & h->bucket_bitmask];
|
|
|
|
secondary_bkt[i] = &h->buckets[sec_hash[i] & h->bucket_bitmask];
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
rte_prefetch0(primary_bkt[i]);
|
|
|
|
rte_prefetch0(secondary_bkt[i]);
|
|
|
|
}
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
/* Calculate and prefetch rest of the buckets */
|
|
|
|
for (; i < num_keys; i++) {
|
|
|
|
prim_hash[i] = rte_hash_hash(h, keys[i]);
|
|
|
|
sec_hash[i] = rte_hash_secondary_hash(prim_hash[i]);
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
primary_bkt[i] = &h->buckets[prim_hash[i] & h->bucket_bitmask];
|
|
|
|
secondary_bkt[i] = &h->buckets[sec_hash[i] & h->bucket_bitmask];
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
rte_prefetch0(primary_bkt[i]);
|
|
|
|
rte_prefetch0(secondary_bkt[i]);
|
|
|
|
}
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
/* Compare signatures and prefetch key slot of first hit */
|
|
|
|
for (i = 0; i < num_keys; i++) {
|
|
|
|
compare_signatures(&prim_hitmask[i], &sec_hitmask[i],
|
|
|
|
primary_bkt[i], secondary_bkt[i],
|
|
|
|
prim_hash[i], sec_hash[i], h->sig_cmp_fn);
|
|
|
|
|
|
|
|
if (prim_hitmask[i]) {
|
|
|
|
uint32_t first_hit = __builtin_ctzl(prim_hitmask[i]);
|
|
|
|
uint32_t key_idx = primary_bkt[i]->key_idx[first_hit];
|
|
|
|
const struct rte_hash_key *key_slot =
|
|
|
|
(const struct rte_hash_key *)(
|
|
|
|
(const char *)h->key_store +
|
|
|
|
key_idx * h->key_entry_size);
|
|
|
|
rte_prefetch0(key_slot);
|
|
|
|
continue;
|
|
|
|
}
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
if (sec_hitmask[i]) {
|
|
|
|
uint32_t first_hit = __builtin_ctzl(sec_hitmask[i]);
|
|
|
|
uint32_t key_idx = secondary_bkt[i]->key_idx[first_hit];
|
|
|
|
const struct rte_hash_key *key_slot =
|
|
|
|
(const struct rte_hash_key *)(
|
|
|
|
(const char *)h->key_store +
|
|
|
|
key_idx * h->key_entry_size);
|
|
|
|
rte_prefetch0(key_slot);
|
|
|
|
}
|
|
|
|
}
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
/* Compare keys, first hits in primary first */
|
|
|
|
for (i = 0; i < num_keys; i++) {
|
|
|
|
positions[i] = -ENOENT;
|
|
|
|
while (prim_hitmask[i]) {
|
|
|
|
uint32_t hit_index = __builtin_ctzl(prim_hitmask[i]);
|
|
|
|
|
|
|
|
uint32_t key_idx = primary_bkt[i]->key_idx[hit_index];
|
|
|
|
const struct rte_hash_key *key_slot =
|
|
|
|
(const struct rte_hash_key *)(
|
|
|
|
(const char *)h->key_store +
|
|
|
|
key_idx * h->key_entry_size);
|
|
|
|
/*
|
|
|
|
* If key index is 0, do not compare key,
|
|
|
|
* as it is checking the dummy slot
|
|
|
|
*/
|
|
|
|
if (!!key_idx & !rte_hash_cmp_eq(key_slot->key, keys[i], h)) {
|
|
|
|
if (data != NULL)
|
|
|
|
data[i] = key_slot->pdata;
|
2015-07-11 01:18:52 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
hits |= 1ULL << i;
|
|
|
|
positions[i] = key_idx - 1;
|
|
|
|
goto next_key;
|
|
|
|
}
|
|
|
|
prim_hitmask[i] &= ~(1 << (hit_index));
|
|
|
|
}
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
while (sec_hitmask[i]) {
|
|
|
|
uint32_t hit_index = __builtin_ctzl(sec_hitmask[i]);
|
|
|
|
|
|
|
|
uint32_t key_idx = secondary_bkt[i]->key_idx[hit_index];
|
|
|
|
const struct rte_hash_key *key_slot =
|
|
|
|
(const struct rte_hash_key *)(
|
|
|
|
(const char *)h->key_store +
|
|
|
|
key_idx * h->key_entry_size);
|
|
|
|
/*
|
|
|
|
* If key index is 0, do not compare key,
|
|
|
|
* as it is checking the dummy slot
|
|
|
|
*/
|
|
|
|
|
|
|
|
if (!!key_idx & !rte_hash_cmp_eq(key_slot->key, keys[i], h)) {
|
|
|
|
if (data != NULL)
|
|
|
|
data[i] = key_slot->pdata;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
hits |= 1ULL << i;
|
|
|
|
positions[i] = key_idx - 1;
|
|
|
|
goto next_key;
|
2015-07-11 01:18:52 +01:00
|
|
|
}
|
2016-10-05 00:25:15 +01:00
|
|
|
sec_hitmask[i] &= ~(1 << (hit_index));
|
|
|
|
}
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
|
2016-10-05 00:25:15 +01:00
|
|
|
next_key:
|
|
|
|
continue;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
2015-07-11 01:18:52 +01:00
|
|
|
|
|
|
|
if (hit_mask != NULL)
|
|
|
|
*hit_mask = hits;
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
rte_hash_lookup_bulk(const struct rte_hash *h, const void **keys,
|
|
|
|
uint32_t num_keys, int32_t *positions)
|
|
|
|
{
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (keys == NULL) || (num_keys == 0) ||
|
|
|
|
(num_keys > RTE_HASH_LOOKUP_BULK_MAX) ||
|
|
|
|
(positions == NULL)), -EINVAL);
|
|
|
|
|
2015-07-11 01:18:52 +01:00
|
|
|
__rte_hash_lookup_bulk(h, keys, num_keys, positions, NULL, NULL);
|
hash: replace with cuckoo hash implementation
This patch replaces the existing hash library with another approach,
using the Cuckoo Hash method to resolve collisions (open addressing),
which pushes items from a full bucket when a new entry tries
to be added in it, storing the evicted entry in an alternative location,
using a secondary hash function.
This gives the user the ability to store more entries when a bucket
is full, in comparison with the previous implementation.
Therefore, the unit test has been updated, as some scenarios have changed
(such as the previous removed restriction).
Also note that the API has not been changed, although new fields
have been added in the rte_hash structure (structure is internal now).
The main change when creating a new table is that the number of entries
per bucket is fixed now, so its parameter is ignored now
(still there to maintain the same parameters structure).
The hash unit test has been updated to reflect these changes.
As a last note, the maximum burst size in lookup_burst function
hash been increased to 64, to improve performance.
Signed-off-by: Pablo de Lara <pablo.de.lara.guarch@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2015-07-11 01:18:50 +01:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2015-07-11 01:18:52 +01:00
|
|
|
int
|
|
|
|
rte_hash_lookup_bulk_data(const struct rte_hash *h, const void **keys,
|
|
|
|
uint32_t num_keys, uint64_t *hit_mask, void *data[])
|
|
|
|
{
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (keys == NULL) || (num_keys == 0) ||
|
|
|
|
(num_keys > RTE_HASH_LOOKUP_BULK_MAX) ||
|
|
|
|
(hit_mask == NULL)), -EINVAL);
|
|
|
|
|
|
|
|
int32_t positions[num_keys];
|
|
|
|
|
|
|
|
__rte_hash_lookup_bulk(h, keys, num_keys, positions, hit_mask, data);
|
|
|
|
|
|
|
|
/* Return number of hits */
|
|
|
|
return __builtin_popcountl(*hit_mask);
|
|
|
|
}
|
|
|
|
|
2015-07-11 01:18:53 +01:00
|
|
|
int32_t
|
|
|
|
rte_hash_iterate(const struct rte_hash *h, const void **key, void **data, uint32_t *next)
|
|
|
|
{
|
|
|
|
uint32_t bucket_idx, idx, position;
|
|
|
|
struct rte_hash_key *next_key;
|
|
|
|
|
|
|
|
RETURN_IF_TRUE(((h == NULL) || (next == NULL)), -EINVAL);
|
|
|
|
|
|
|
|
const uint32_t total_entries = h->num_buckets * RTE_HASH_BUCKET_ENTRIES;
|
|
|
|
/* Out of bounds */
|
|
|
|
if (*next >= total_entries)
|
|
|
|
return -ENOENT;
|
|
|
|
|
|
|
|
/* Calculate bucket and index of current iterator */
|
|
|
|
bucket_idx = *next / RTE_HASH_BUCKET_ENTRIES;
|
|
|
|
idx = *next % RTE_HASH_BUCKET_ENTRIES;
|
|
|
|
|
|
|
|
/* If current position is empty, go to the next one */
|
2016-08-26 22:30:09 +01:00
|
|
|
while (h->buckets[bucket_idx].key_idx[idx] == EMPTY_SLOT) {
|
2015-07-11 01:18:53 +01:00
|
|
|
(*next)++;
|
|
|
|
/* End of table */
|
|
|
|
if (*next == total_entries)
|
|
|
|
return -ENOENT;
|
|
|
|
bucket_idx = *next / RTE_HASH_BUCKET_ENTRIES;
|
|
|
|
idx = *next % RTE_HASH_BUCKET_ENTRIES;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Get position of entry in key table */
|
|
|
|
position = h->buckets[bucket_idx].key_idx[idx];
|
|
|
|
next_key = (struct rte_hash_key *) ((char *)h->key_store +
|
|
|
|
position * h->key_entry_size);
|
|
|
|
/* Return key and data */
|
|
|
|
*key = next_key->key;
|
|
|
|
*data = next_key->pdata;
|
|
|
|
|
|
|
|
/* Increment iterator */
|
|
|
|
(*next)++;
|
|
|
|
|
2016-01-27 21:58:30 +08:00
|
|
|
return position - 1;
|
2015-07-11 01:18:53 +01:00
|
|
|
}
|