2004-02-10 22:15:55 +00:00
|
|
|
/*
|
2007-03-29 01:00:33 +00:00
|
|
|
* Copyright (c) 2004-2007 The Trustees of Indiana University and Indiana
|
2005-11-05 19:57:48 +00:00
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The University of Tennessee and The University
|
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
2004-11-28 20:09:25 +00:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
* University of Stuttgart. All rights reserved.
|
2005-03-24 12:43:37 +00:00
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2014-08-20 21:40:28 +00:00
|
|
|
* Copyright (c) 2014-2015 Hewlett-Packard Development Company, LP.
|
|
|
|
* All rights reserved.
|
|
|
|
* Copyright (c) 2014-2015 Mellanox Technologies, Inc.
|
|
|
|
* All rights reserved.
|
2004-11-22 01:38:40 +00:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
2004-02-10 22:15:55 +00:00
|
|
|
* $HEADER$
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** @file
|
|
|
|
*
|
2004-03-24 01:54:59 +00:00
|
|
|
* A hash table that may be indexed with either fixed length
|
|
|
|
* (e.g. uint32_t/uint64_t) or arbitrary size binary key
|
|
|
|
* values. However, only one key type may be used in a given table
|
|
|
|
* concurrently.
|
2004-02-10 22:15:55 +00:00
|
|
|
*/
|
|
|
|
|
2005-07-03 16:52:32 +00:00
|
|
|
#ifndef OPAL_HASH_TABLE_H
|
|
|
|
#define OPAL_HASH_TABLE_H
|
2004-02-10 22:15:55 +00:00
|
|
|
|
2006-02-12 01:33:29 +00:00
|
|
|
#include "opal_config.h"
|
2009-03-21 01:26:27 +00:00
|
|
|
|
|
|
|
#ifdef HAVE_STDINT_H
|
|
|
|
#include <stdint.h>
|
|
|
|
#endif
|
2005-07-03 16:22:16 +00:00
|
|
|
#include "opal/class/opal_list.h"
|
2004-02-10 22:15:55 +00:00
|
|
|
|
2009-03-17 15:11:48 +00:00
|
|
|
BEGIN_C_DECLS
|
2004-02-10 22:15:55 +00:00
|
|
|
|
2006-08-21 20:12:19 +00:00
|
|
|
OPAL_DECLSPEC OBJ_CLASS_DECLARATION(opal_hash_table_t);
|
2004-03-24 01:54:59 +00:00
|
|
|
|
2005-07-03 16:52:32 +00:00
|
|
|
struct opal_hash_table_t
|
2004-02-10 22:15:55 +00:00
|
|
|
{
|
2005-07-03 16:06:07 +00:00
|
|
|
opal_object_t super; /**< subclass of opal_object_t */
|
2014-08-20 21:40:28 +00:00
|
|
|
struct opal_hash_element_t * ht_table; /**< table of elements (opaque to users) */
|
|
|
|
size_t ht_capacity; /**< allocated size (capacity) of table */
|
|
|
|
size_t ht_size; /**< number of extant entries */
|
|
|
|
size_t ht_growth_trigger; /**< size hits this and table is grown */
|
|
|
|
int ht_density_numer, ht_density_denom; /**< max allowed density of table */
|
|
|
|
int ht_growth_numer, ht_growth_denom; /**< growth factor when grown */
|
|
|
|
const struct opal_hash_type_methods_t * ht_type_methods;
|
|
|
|
// FIXME
|
|
|
|
// Begin KLUDGE!! So ompi/debuggers/ompi_common_dll.c doesn't complain
|
2004-02-10 22:15:55 +00:00
|
|
|
size_t ht_table_size; /**< size of table */
|
|
|
|
size_t ht_mask;
|
2014-08-20 21:40:28 +00:00
|
|
|
// End KLUDGE
|
2004-02-10 22:15:55 +00:00
|
|
|
};
|
2005-07-03 16:52:32 +00:00
|
|
|
typedef struct opal_hash_table_t opal_hash_table_t;
|
2004-02-10 22:15:55 +00:00
|
|
|
|
2004-03-24 01:54:59 +00:00
|
|
|
|
2004-02-10 22:15:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Initializes the table size, must be called before using
|
|
|
|
* the table.
|
|
|
|
*
|
|
|
|
* @param table The input hash table (IN).
|
|
|
|
* @param size The size of the table, which will be rounded up
|
|
|
|
* (if required) to the next highest power of two (IN).
|
2007-03-29 01:00:33 +00:00
|
|
|
* @return OPAL error code.
|
2004-02-10 22:15:55 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_init(opal_hash_table_t* ht, size_t table_size);
|
2004-02-10 22:15:55 +00:00
|
|
|
|
2014-08-20 22:27:03 +00:00
|
|
|
/**
|
|
|
|
* Alternative form
|
|
|
|
*/
|
|
|
|
OPAL_DECLSPEC int opal_hash_table_init2(opal_hash_table_t* ht, size_t estimated_max_size,
|
|
|
|
int density_numer, int density_denom,
|
|
|
|
int growth_numer, int growth_denom);
|
2004-02-10 22:15:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the number of elements currently stored in the table.
|
|
|
|
*
|
|
|
|
* @param table The input hash table (IN).
|
|
|
|
* @return The number of elements in the table.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2005-07-03 16:52:32 +00:00
|
|
|
static inline size_t opal_hash_table_get_size(opal_hash_table_t *ht)
|
2004-02-10 22:15:55 +00:00
|
|
|
{
|
|
|
|
return ht->ht_size;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove all elements from the table.
|
|
|
|
*
|
|
|
|
* @param table The input hash table (IN).
|
2007-03-29 01:00:33 +00:00
|
|
|
* @return OPAL return code.
|
2004-02-10 22:15:55 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_remove_all(opal_hash_table_t *ht);
|
2004-02-10 22:15:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve value via uint32_t key.
|
|
|
|
*
|
|
|
|
* @param table The input hash table (IN).
|
|
|
|
* @param key The input key (IN).
|
2004-10-29 18:38:10 +00:00
|
|
|
* @param ptr The value associated with the key
|
|
|
|
* @return integer return code:
|
2006-02-12 01:33:29 +00:00
|
|
|
* - OPAL_SUCCESS if key was found
|
|
|
|
* - OPAL_ERR_NOT_FOUND if key was not found
|
|
|
|
* - OPAL_ERROR other error
|
2004-02-10 22:15:55 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_get_value_uint32(opal_hash_table_t* table, uint32_t key,
|
2014-08-20 21:40:28 +00:00
|
|
|
void** ptr);
|
2004-02-10 22:15:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set value based on uint32_t key.
|
|
|
|
*
|
|
|
|
* @param table The input hash table (IN).
|
|
|
|
* @param key The input key (IN).
|
|
|
|
* @param value The value to be associated with the key (IN).
|
2007-03-29 01:00:33 +00:00
|
|
|
* @return OPAL return code.
|
2004-02-10 22:15:55 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_set_value_uint32(opal_hash_table_t* table, uint32_t key, void* value);
|
2004-02-10 22:15:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove value based on uint32_t key.
|
|
|
|
*
|
|
|
|
* @param table The input hash table (IN).
|
|
|
|
* @param key The input key (IN).
|
2007-03-29 01:00:33 +00:00
|
|
|
* @return OPAL return code.
|
2004-02-10 22:15:55 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_remove_value_uint32(opal_hash_table_t* table, uint32_t key);
|
2004-02-10 22:15:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve value via uint64_t key.
|
|
|
|
*
|
|
|
|
* @param table The input hash table (IN).
|
|
|
|
* @param key The input key (IN).
|
2004-10-29 18:38:10 +00:00
|
|
|
* @param ptr The value associated with the key
|
|
|
|
* @return integer return code:
|
2006-02-12 01:33:29 +00:00
|
|
|
* - OPAL_SUCCESS if key was found
|
|
|
|
* - OPAL_ERR_NOT_FOUND if key was not found
|
|
|
|
* - OPAL_ERROR other error
|
2004-02-10 22:15:55 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_get_value_uint64(opal_hash_table_t *table, uint64_t key,
|
2014-08-20 21:40:28 +00:00
|
|
|
void **ptr);
|
2004-02-10 22:15:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set value based on uint64_t key.
|
|
|
|
*
|
|
|
|
* @param table The input hash table (IN).
|
|
|
|
* @param key The input key (IN).
|
|
|
|
* @param value The value to be associated with the key (IN).
|
2007-03-29 01:00:33 +00:00
|
|
|
* @return OPAL return code.
|
2004-02-10 22:15:55 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_set_value_uint64(opal_hash_table_t *table, uint64_t key, void* value);
|
2004-02-10 22:15:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove value based on uint64_t key.
|
|
|
|
*
|
|
|
|
* @param table The input hash table (IN).
|
|
|
|
* @param key The input key (IN).
|
2007-03-29 01:00:33 +00:00
|
|
|
* @return OPAL return code.
|
2004-02-10 22:15:55 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_remove_value_uint64(opal_hash_table_t *table, uint64_t key);
|
2004-02-10 22:15:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve value via arbitrary length binary key.
|
|
|
|
*
|
|
|
|
* @param table The input hash table (IN).
|
|
|
|
* @param key The input key (IN).
|
2004-10-29 18:38:10 +00:00
|
|
|
* @param ptr The value associated with the key
|
|
|
|
* @return integer return code:
|
2006-02-12 01:33:29 +00:00
|
|
|
* - OPAL_SUCCESS if key was found
|
|
|
|
* - OPAL_ERR_NOT_FOUND if key was not found
|
|
|
|
* - OPAL_ERROR other error
|
2004-02-10 22:15:55 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_get_value_ptr(opal_hash_table_t *table, const void* key,
|
2014-08-20 21:40:28 +00:00
|
|
|
size_t keylen, void **ptr);
|
2004-02-10 22:15:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set value based on arbitrary length binary key.
|
|
|
|
*
|
|
|
|
* @param table The input hash table (IN).
|
|
|
|
* @param key The input key (IN).
|
|
|
|
* @param value The value to be associated with the key (IN).
|
2007-03-29 01:00:33 +00:00
|
|
|
* @return OPAL return code.
|
2004-02-10 22:15:55 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_set_value_ptr(opal_hash_table_t *table, const void* key, size_t keylen, void* value);
|
2004-02-10 22:15:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove value based on arbitrary length binary key.
|
|
|
|
*
|
|
|
|
* @param table The input hash table (IN).
|
|
|
|
* @param key The input key (IN).
|
2007-03-29 01:00:33 +00:00
|
|
|
* @return OPAL return code.
|
2004-02-10 22:15:55 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_remove_value_ptr(opal_hash_table_t *table, const void* key, size_t keylen);
|
2004-02-10 22:15:55 +00:00
|
|
|
|
2004-03-24 01:54:59 +00:00
|
|
|
|
|
|
|
/** The following functions are only for allowing iterating through
|
|
|
|
the hash table. The calls return along with a key, a pointer to
|
|
|
|
the hash node with the current key, so that subsequent calls do
|
|
|
|
not have to traverse all over again to the key (although it may
|
|
|
|
just be a simple thing - to go to the array element and then
|
|
|
|
traverse through the individual list). But lets take out this
|
|
|
|
inefficiency too. This is similar to having an STL iterator in
|
|
|
|
functionality */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the first 32 bit key from the hash table, which can be used later to
|
|
|
|
* get the next key
|
|
|
|
* @param table The hash table pointer (IN)
|
|
|
|
* @param key The first key (OUT)
|
|
|
|
* @param value The value corresponding to this key (OUT)
|
|
|
|
* @param node The pointer to the hash table internal node which stores
|
|
|
|
* the key-value pair (this is required for subsequent calls
|
|
|
|
* to get_next_key) (OUT)
|
2007-03-29 01:00:33 +00:00
|
|
|
* @return OPAL error code
|
2004-03-24 01:54:59 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_get_first_key_uint32(opal_hash_table_t *table, uint32_t *key,
|
2014-08-20 21:40:28 +00:00
|
|
|
void **value, void **node);
|
2004-03-24 01:54:59 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the next 32 bit key from the hash table, knowing the current key
|
|
|
|
* @param table The hash table pointer (IN)
|
|
|
|
* @param key The key (OUT)
|
|
|
|
* @param value The value corresponding to this key (OUT)
|
|
|
|
* @param in_node The node pointer from previous call to either get_first
|
|
|
|
or get_next (IN)
|
|
|
|
* @param out_node The pointer to the hash table internal node which stores
|
|
|
|
* the key-value pair (this is required for subsequent calls
|
|
|
|
* to get_next_key) (OUT)
|
2007-03-29 01:00:33 +00:00
|
|
|
* @return OPAL error code
|
2004-03-24 01:54:59 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_get_next_key_uint32(opal_hash_table_t *table, uint32_t *key,
|
2014-08-20 21:40:28 +00:00
|
|
|
void **value, void *in_node,
|
|
|
|
void **out_node);
|
2004-03-24 01:54:59 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the first 64 key from the hash table, which can be used later to
|
|
|
|
* get the next key
|
|
|
|
* @param table The hash table pointer (IN)
|
|
|
|
* @param key The first key (OUT)
|
|
|
|
* @param value The value corresponding to this key (OUT)
|
|
|
|
* @param node The pointer to the hash table internal node which stores
|
|
|
|
* the key-value pair (this is required for subsequent calls
|
|
|
|
* to get_next_key) (OUT)
|
2007-03-29 01:00:33 +00:00
|
|
|
* @return OPAL error code
|
2004-03-24 01:54:59 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_get_first_key_uint64(opal_hash_table_t *table, uint64_t *key,
|
2014-08-20 21:40:28 +00:00
|
|
|
void **value, void **node);
|
2004-03-24 01:54:59 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the next 64 bit key from the hash table, knowing the current key
|
|
|
|
* @param table The hash table pointer (IN)
|
|
|
|
* @param key The key (OUT)
|
|
|
|
* @param value The value corresponding to this key (OUT)
|
|
|
|
* @param in_node The node pointer from previous call to either get_first
|
|
|
|
or get_next (IN)
|
|
|
|
* @param out_node The pointer to the hash table internal node which stores
|
|
|
|
* the key-value pair (this is required for subsequent calls
|
|
|
|
* to get_next_key) (OUT)
|
2007-03-29 01:00:33 +00:00
|
|
|
* @return OPAL error code
|
2004-03-24 01:54:59 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC int opal_hash_table_get_next_key_uint64(opal_hash_table_t *table, uint64_t *key,
|
2014-08-20 21:40:28 +00:00
|
|
|
void **value, void *in_node,
|
|
|
|
void **out_node);
|
2004-03-24 01:54:59 +00:00
|
|
|
|
2009-03-17 15:11:48 +00:00
|
|
|
END_C_DECLS
|
2004-02-10 22:15:55 +00:00
|
|
|
|
2005-07-03 16:52:32 +00:00
|
|
|
#endif /* OPAL_HASH_TABLE_H */
|