diff options
author | Pablo Neira Ayuso <pablo@netfilter.org> | 2009-07-17 13:36:05 +0200 |
---|---|---|
committer | Pablo Neira Ayuso <pablo@netfilter.org> | 2009-07-17 13:36:05 +0200 |
commit | a1d03b775376aa8545ec9a0e89381b659e4d28ed (patch) | |
tree | dbce19e61288f5a4d31154e55a1e53553416bc72 | |
parent | 9406f29b89f6727c3db5485d109466701393b4d4 (diff) | |
download | conntrack-tools-a1d03b775376aa8545ec9a0e89381b659e4d28ed.tar.gz conntrack-tools-a1d03b775376aa8545ec9a0e89381b659e4d28ed.zip |
conntrackd: add iterators with limited steps in hash and cache types
This patch adds cache_iterate_limit() and hashtable_iterate_limit()
that allows to limit the iteration to given a number of states.
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
-rw-r--r-- | include/cache.h | 1 | ||||
-rw-r--r-- | include/hash.h | 3 | ||||
-rw-r--r-- | src/cache.c | 7 | ||||
-rw-r--r-- | src/cache_iterators.c | 16 | ||||
-rw-r--r-- | src/hash.c | 17 |
5 files changed, 31 insertions, 13 deletions
diff --git a/include/cache.h b/include/cache.h index 0b2b18d..109e6aa 100644 --- a/include/cache.h +++ b/include/cache.h @@ -114,6 +114,7 @@ void cache_stats_extended(const struct cache *c, int fd); struct cache_object *cache_data_get_object(struct cache *c, void *data); void *cache_get_extra(struct cache *, void *); void cache_iterate(struct cache *c, void *data, int (*iterate)(void *data1, void *data2)); +void cache_iterate_limit(struct cache *c, void *data, uint32_t from, uint32_t steps, int (*iterate)(void *data1, void *data2)); /* iterators */ struct nfct_handle; diff --git a/include/hash.h b/include/hash.h index 68d618b..eaa9e96 100644 --- a/include/hash.h +++ b/include/hash.h @@ -37,7 +37,8 @@ int hashtable_add(struct hashtable *table, struct hashtable_node *n, int id); void hashtable_del(struct hashtable *table, struct hashtable_node *node); int hashtable_flush(struct hashtable *table); int hashtable_iterate(struct hashtable *table, void *data, - int (*iterate)(void *data, struct hashtable_node *n)); + int (*iterate)(void *data, void *n)); +int hashtable_iterate_limit(struct hashtable *table, void *data, uint32_t from, uint32_t steps, int (*iterate)(void *data1, void *n)); unsigned int hashtable_counter(const struct hashtable *table); #endif diff --git a/src/cache.c b/src/cache.c index 1e544a2..f95bef6 100644 --- a/src/cache.c +++ b/src/cache.c @@ -423,3 +423,10 @@ void cache_iterate(struct cache *c, { hashtable_iterate(c->h, data, iterate); } + +void cache_iterate_limit(struct cache *c, void *data, + uint32_t from, uint32_t steps, + int (*iterate)(void *data1, void *data2)) +{ + hashtable_iterate_limit(c->h, data, from, steps, iterate); +} diff --git a/src/cache_iterators.c b/src/cache_iterators.c index 542ab91..b6688e9 100644 --- a/src/cache_iterators.c +++ b/src/cache_iterators.c @@ -33,12 +33,12 @@ struct __dump_container { int type; }; -static int do_dump(void *data1, struct hashtable_node *n) +static int do_dump(void *data1, void *n) { char buf[1024]; int size; struct __dump_container *container = data1; - struct cache_object *obj = (struct cache_object *)n; + struct cache_object *obj = n; char *data = obj->data; unsigned i; @@ -152,9 +152,9 @@ retry: } } -static int do_commit_related(void *data, struct hashtable_node *n) +static int do_commit_related(void *data, void *n) { - struct cache_object *obj = (struct cache_object *)n; + struct cache_object *obj = n; if (ct_is_related(obj->ct)) __do_commit_step(data, obj); @@ -163,9 +163,9 @@ static int do_commit_related(void *data, struct hashtable_node *n) return 0; } -static int do_commit_master(void *data, struct hashtable_node *n) +static int do_commit_master(void *data, void *n) { - struct cache_object *obj = (struct cache_object *)n; + struct cache_object *obj = n; if (ct_is_related(obj->ct)) return 0; @@ -207,10 +207,10 @@ void cache_commit(struct cache *c, struct nfct_handle *h) res.tv_sec, res.tv_usec); } -static int do_flush(void *data, struct hashtable_node *n) +static int do_flush(void *data, void *n) { struct cache *c = data; - struct cache_object *obj = (struct cache_object *)n; + struct cache_object *obj = n; cache_del(c, obj); cache_object_free(obj); @@ -23,6 +23,7 @@ #include <errno.h> #include <stdlib.h> #include <string.h> +#include <limits.h> struct hashtable * hashtable_create(int hashsize, int limit, @@ -111,21 +112,29 @@ int hashtable_flush(struct hashtable *table) return 0; } -int hashtable_iterate(struct hashtable *table, void *data, - int (*iterate)(void *data1, struct hashtable_node *n)) +int +hashtable_iterate_limit(struct hashtable *table, void *data, + uint32_t from, uint32_t steps, + int (*iterate)(void *data1, void *n)) { uint32_t i; struct list_head *e, *tmp; struct hashtable_node *n; - for (i=0; i < table->hashsize; i++) { + for (i=from; i < table->hashsize && i < from+steps; i++) { list_for_each_safe(e, tmp, &table->members[i]) { n = list_entry(e, struct hashtable_node, head); if (iterate(data, n) == -1) return -1; } } - return 0; + return i; +} + +int hashtable_iterate(struct hashtable *table, void *data, + int (*iterate)(void *data1, void *n)) +{ + return hashtable_iterate_limit(table, data, 0, UINT_MAX, iterate); } unsigned int hashtable_counter(const struct hashtable *table) |