mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-18 10:04:20 +03:00
device_mapper: move hash.[hc] to base/data-struct
This commit is contained in:
parent
962a3eb3fa
commit
61e67e51e1
@ -12,6 +12,7 @@
|
|||||||
|
|
||||||
BASE_SOURCE=\
|
BASE_SOURCE=\
|
||||||
base/data-struct/radix-tree.c \
|
base/data-struct/radix-tree.c \
|
||||||
|
base/data-struct/hash.c \
|
||||||
base/data-struct/list.c
|
base/data-struct/list.c
|
||||||
|
|
||||||
BASE_DEPENDS=$(addprefix $(top_builddir)/,$(subst .c,.d,$(BASE_SOURCE)))
|
BASE_DEPENDS=$(addprefix $(top_builddir)/,$(subst .c,.d,$(BASE_SOURCE)))
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
|
|
||||||
#include "device_mapper/misc/dmlib.h"
|
#include "device_mapper/misc/dmlib.h"
|
||||||
#include "base/memory/zalloc.h"
|
#include "base/memory/zalloc.h"
|
||||||
|
#include "hash.h"
|
||||||
|
|
||||||
struct dm_hash_node {
|
struct dm_hash_node {
|
||||||
struct dm_hash_node *next;
|
struct dm_hash_node *next;
|
94
base/data-struct/hash.h
Normal file
94
base/data-struct/hash.h
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
#ifndef BASE_DATA_STRUCT_HASH_H
|
||||||
|
#define BASE_DATA_STRUCT_HASH_H
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
//----------------------------------------------------------------
|
||||||
|
|
||||||
|
struct dm_hash_table;
|
||||||
|
struct dm_hash_node;
|
||||||
|
|
||||||
|
typedef void (*dm_hash_iterate_fn) (void *data);
|
||||||
|
|
||||||
|
struct dm_hash_table *dm_hash_create(unsigned size_hint)
|
||||||
|
__attribute__((__warn_unused_result__));
|
||||||
|
void dm_hash_destroy(struct dm_hash_table *t);
|
||||||
|
void dm_hash_wipe(struct dm_hash_table *t);
|
||||||
|
|
||||||
|
void *dm_hash_lookup(struct dm_hash_table *t, const char *key);
|
||||||
|
int dm_hash_insert(struct dm_hash_table *t, const char *key, void *data);
|
||||||
|
void dm_hash_remove(struct dm_hash_table *t, const char *key);
|
||||||
|
|
||||||
|
void *dm_hash_lookup_binary(struct dm_hash_table *t, const void *key, uint32_t len);
|
||||||
|
int dm_hash_insert_binary(struct dm_hash_table *t, const void *key, uint32_t len,
|
||||||
|
void *data);
|
||||||
|
void dm_hash_remove_binary(struct dm_hash_table *t, const void *key, uint32_t len);
|
||||||
|
|
||||||
|
unsigned dm_hash_get_num_entries(struct dm_hash_table *t);
|
||||||
|
void dm_hash_iter(struct dm_hash_table *t, dm_hash_iterate_fn f);
|
||||||
|
|
||||||
|
char *dm_hash_get_key(struct dm_hash_table *t, struct dm_hash_node *n);
|
||||||
|
void *dm_hash_get_data(struct dm_hash_table *t, struct dm_hash_node *n);
|
||||||
|
struct dm_hash_node *dm_hash_get_first(struct dm_hash_table *t);
|
||||||
|
struct dm_hash_node *dm_hash_get_next(struct dm_hash_table *t, struct dm_hash_node *n);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* dm_hash_insert() replaces the value of an existing
|
||||||
|
* entry with a matching key if one exists. Otherwise
|
||||||
|
* it adds a new entry.
|
||||||
|
*
|
||||||
|
* dm_hash_insert_with_val() inserts a new entry if
|
||||||
|
* another entry with the same key already exists.
|
||||||
|
* val_len is the size of the data being inserted.
|
||||||
|
*
|
||||||
|
* If two entries with the same key exist,
|
||||||
|
* (added using dm_hash_insert_allow_multiple), then:
|
||||||
|
* . dm_hash_lookup() returns the first one it finds, and
|
||||||
|
* dm_hash_lookup_with_val() returns the one with a matching
|
||||||
|
* val_len/val.
|
||||||
|
* . dm_hash_remove() removes the first one it finds, and
|
||||||
|
* dm_hash_remove_with_val() removes the one with a matching
|
||||||
|
* val_len/val.
|
||||||
|
*
|
||||||
|
* If a single entry with a given key exists, and it has
|
||||||
|
* zero val_len, then:
|
||||||
|
* . dm_hash_lookup() returns it
|
||||||
|
* . dm_hash_lookup_with_val(val_len=0) returns it
|
||||||
|
* . dm_hash_remove() removes it
|
||||||
|
* . dm_hash_remove_with_val(val_len=0) removes it
|
||||||
|
*
|
||||||
|
* dm_hash_lookup_with_count() is a single call that will
|
||||||
|
* both lookup a key's value and check if there is more
|
||||||
|
* than one entry with the given key.
|
||||||
|
*
|
||||||
|
* (It is not meant to retrieve all the entries with the
|
||||||
|
* given key. In the common case where a single entry exists
|
||||||
|
* for the key, it is useful to have a single call that will
|
||||||
|
* both look up the value and indicate if multiple values
|
||||||
|
* exist for the key.)
|
||||||
|
*
|
||||||
|
* dm_hash_lookup_with_count:
|
||||||
|
* . If no entries exist, the function returns NULL, and
|
||||||
|
* the count is set to 0.
|
||||||
|
* . If only one entry exists, the value of that entry is
|
||||||
|
* returned and count is set to 1.
|
||||||
|
* . If N entries exists, the value of the first entry is
|
||||||
|
* returned and count is set to N.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void *dm_hash_lookup_with_val(struct dm_hash_table *t, const char *key,
|
||||||
|
const void *val, uint32_t val_len);
|
||||||
|
void dm_hash_remove_with_val(struct dm_hash_table *t, const char *key,
|
||||||
|
const void *val, uint32_t val_len);
|
||||||
|
int dm_hash_insert_allow_multiple(struct dm_hash_table *t, const char *key,
|
||||||
|
const void *val, uint32_t val_len);
|
||||||
|
void *dm_hash_lookup_with_count(struct dm_hash_table *t, const char *key, int *count);
|
||||||
|
|
||||||
|
|
||||||
|
#define dm_hash_iterate(v, h) \
|
||||||
|
for (v = dm_hash_get_first((h)); v; \
|
||||||
|
v = dm_hash_get_next((h), v))
|
||||||
|
|
||||||
|
//----------------------------------------------------------------
|
||||||
|
|
||||||
|
#endif
|
@ -12,7 +12,6 @@
|
|||||||
|
|
||||||
DEVICE_MAPPER_SOURCE=\
|
DEVICE_MAPPER_SOURCE=\
|
||||||
device_mapper/datastruct/bitset.c \
|
device_mapper/datastruct/bitset.c \
|
||||||
device_mapper/datastruct/hash.c \
|
|
||||||
device_mapper/libdm-common.c \
|
device_mapper/libdm-common.c \
|
||||||
device_mapper/libdm-config.c \
|
device_mapper/libdm-config.c \
|
||||||
device_mapper/libdm-deptree.c \
|
device_mapper/libdm-deptree.c \
|
||||||
|
@ -32,6 +32,7 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#include "base/data-struct/list.h"
|
#include "base/data-struct/list.h"
|
||||||
|
#include "base/data-struct/hash.h"
|
||||||
|
|
||||||
#ifndef __GNUC__
|
#ifndef __GNUC__
|
||||||
# define __typeof__ typeof
|
# define __typeof__ typeof
|
||||||
@ -2248,94 +2249,6 @@ static inline unsigned hweight32(uint32_t i)
|
|||||||
return (r & 0x0000FFFF) + ((r >> 16) & 0x0000FFFF);
|
return (r & 0x0000FFFF) + ((r >> 16) & 0x0000FFFF);
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************
|
|
||||||
* hash functions
|
|
||||||
****************/
|
|
||||||
|
|
||||||
struct dm_hash_table;
|
|
||||||
struct dm_hash_node;
|
|
||||||
|
|
||||||
typedef void (*dm_hash_iterate_fn) (void *data);
|
|
||||||
|
|
||||||
struct dm_hash_table *dm_hash_create(unsigned size_hint)
|
|
||||||
__attribute__((__warn_unused_result__));
|
|
||||||
void dm_hash_destroy(struct dm_hash_table *t);
|
|
||||||
void dm_hash_wipe(struct dm_hash_table *t);
|
|
||||||
|
|
||||||
void *dm_hash_lookup(struct dm_hash_table *t, const char *key);
|
|
||||||
int dm_hash_insert(struct dm_hash_table *t, const char *key, void *data);
|
|
||||||
void dm_hash_remove(struct dm_hash_table *t, const char *key);
|
|
||||||
|
|
||||||
void *dm_hash_lookup_binary(struct dm_hash_table *t, const void *key, uint32_t len);
|
|
||||||
int dm_hash_insert_binary(struct dm_hash_table *t, const void *key, uint32_t len,
|
|
||||||
void *data);
|
|
||||||
void dm_hash_remove_binary(struct dm_hash_table *t, const void *key, uint32_t len);
|
|
||||||
|
|
||||||
unsigned dm_hash_get_num_entries(struct dm_hash_table *t);
|
|
||||||
void dm_hash_iter(struct dm_hash_table *t, dm_hash_iterate_fn f);
|
|
||||||
|
|
||||||
char *dm_hash_get_key(struct dm_hash_table *t, struct dm_hash_node *n);
|
|
||||||
void *dm_hash_get_data(struct dm_hash_table *t, struct dm_hash_node *n);
|
|
||||||
struct dm_hash_node *dm_hash_get_first(struct dm_hash_table *t);
|
|
||||||
struct dm_hash_node *dm_hash_get_next(struct dm_hash_table *t, struct dm_hash_node *n);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* dm_hash_insert() replaces the value of an existing
|
|
||||||
* entry with a matching key if one exists. Otherwise
|
|
||||||
* it adds a new entry.
|
|
||||||
*
|
|
||||||
* dm_hash_insert_with_val() inserts a new entry if
|
|
||||||
* another entry with the same key already exists.
|
|
||||||
* val_len is the size of the data being inserted.
|
|
||||||
*
|
|
||||||
* If two entries with the same key exist,
|
|
||||||
* (added using dm_hash_insert_allow_multiple), then:
|
|
||||||
* . dm_hash_lookup() returns the first one it finds, and
|
|
||||||
* dm_hash_lookup_with_val() returns the one with a matching
|
|
||||||
* val_len/val.
|
|
||||||
* . dm_hash_remove() removes the first one it finds, and
|
|
||||||
* dm_hash_remove_with_val() removes the one with a matching
|
|
||||||
* val_len/val.
|
|
||||||
*
|
|
||||||
* If a single entry with a given key exists, and it has
|
|
||||||
* zero val_len, then:
|
|
||||||
* . dm_hash_lookup() returns it
|
|
||||||
* . dm_hash_lookup_with_val(val_len=0) returns it
|
|
||||||
* . dm_hash_remove() removes it
|
|
||||||
* . dm_hash_remove_with_val(val_len=0) removes it
|
|
||||||
*
|
|
||||||
* dm_hash_lookup_with_count() is a single call that will
|
|
||||||
* both lookup a key's value and check if there is more
|
|
||||||
* than one entry with the given key.
|
|
||||||
*
|
|
||||||
* (It is not meant to retrieve all the entries with the
|
|
||||||
* given key. In the common case where a single entry exists
|
|
||||||
* for the key, it is useful to have a single call that will
|
|
||||||
* both look up the value and indicate if multiple values
|
|
||||||
* exist for the key.)
|
|
||||||
*
|
|
||||||
* dm_hash_lookup_with_count:
|
|
||||||
* . If no entries exist, the function returns NULL, and
|
|
||||||
* the count is set to 0.
|
|
||||||
* . If only one entry exists, the value of that entry is
|
|
||||||
* returned and count is set to 1.
|
|
||||||
* . If N entries exists, the value of the first entry is
|
|
||||||
* returned and count is set to N.
|
|
||||||
*/
|
|
||||||
|
|
||||||
void *dm_hash_lookup_with_val(struct dm_hash_table *t, const char *key,
|
|
||||||
const void *val, uint32_t val_len);
|
|
||||||
void dm_hash_remove_with_val(struct dm_hash_table *t, const char *key,
|
|
||||||
const void *val, uint32_t val_len);
|
|
||||||
int dm_hash_insert_allow_multiple(struct dm_hash_table *t, const char *key,
|
|
||||||
const void *val, uint32_t val_len);
|
|
||||||
void *dm_hash_lookup_with_count(struct dm_hash_table *t, const char *key, int *count);
|
|
||||||
|
|
||||||
|
|
||||||
#define dm_hash_iterate(v, h) \
|
|
||||||
for (v = dm_hash_get_first((h)); v; \
|
|
||||||
v = dm_hash_get_next((h), v))
|
|
||||||
|
|
||||||
/*********
|
/*********
|
||||||
* selinux
|
* selinux
|
||||||
*********/
|
*********/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user