diff options
author | /C=EU/ST=EU/CN=Pablo Neira Ayuso/emailAddress=pablo@netfilter.org </C=EU/ST=EU/CN=Pablo Neira Ayuso/emailAddress=pablo@netfilter.org> | 2008-01-15 14:35:06 +0000 |
---|---|---|
committer | /C=EU/ST=EU/CN=Pablo Neira Ayuso/emailAddress=pablo@netfilter.org </C=EU/ST=EU/CN=Pablo Neira Ayuso/emailAddress=pablo@netfilter.org> | 2008-01-15 14:35:06 +0000 |
commit | c60b7e984e8907f15439d07e88dad8a23c86cf2b (patch) | |
tree | 631ae6b93f450f1d8b0f50744d2693a985c37084 | |
parent | 83bcf7f49c07e952868099b5027199c8f7ea3c1a (diff) | |
download | conntrack-tools-c60b7e984e8907f15439d07e88dad8a23c86cf2b.tar.gz conntrack-tools-c60b7e984e8907f15439d07e88dad8a23c86cf2b.zip |
use list_del_init() and list_empty() to check if a node is in the list
-rw-r--r-- | ChangeLog | 1 | ||||
-rw-r--r-- | src/sync-ftfw.c | 15 |
2 files changed, 8 insertions, 8 deletions
@@ -42,6 +42,7 @@ o wake up the daemon iff there are real events to handle instead of polling o add support for tagged vlan interfaces in the config file, e.g. eth0.1 o improve alarm framework based on suggestions from Max Kellerman o constify queue_iterate() +o use list_del_init() and list_empty() to check if a node is in the list Max Kellermann <max@duempel.org>: diff --git a/src/sync-ftfw.c b/src/sync-ftfw.c index 2d79293..ce58466 100644 --- a/src/sync-ftfw.c +++ b/src/sync-ftfw.c @@ -50,6 +50,7 @@ struct cache_ftfw { static void cache_ftfw_add(struct us_conntrack *u, void *data) { struct cache_ftfw *cn = data; + /* These nodes are not inserted in the list */ INIT_LIST_HEAD(&cn->rs_list); INIT_LIST_HEAD(&cn->tx_list); } @@ -58,10 +59,11 @@ static void cache_ftfw_del(struct us_conntrack *u, void *data) { struct cache_ftfw *cn = data; - if (cn->rs_list.next == &cn->rs_list && - cn->rs_list.prev == &cn->rs_list) + /* this node is already out of the list */ + if (list_empty(&cn->rs_list)) return; + /* no need for list_del_init since the entry is destroyed */ list_del(&cn->rs_list); } @@ -208,8 +210,7 @@ static void rs_list_empty(struct cache *c, unsigned int from, unsigned int to) u = cache_get_conntrack(STATE_SYNC(internal), cn); if (between(cn->seq, from, to)) { dp("queue: deleting from queue (seq=%u)\n", cn->seq); - list_del(&cn->rs_list); - INIT_LIST_HEAD(&cn->rs_list); + list_del_init(&cn->rs_list); } } } @@ -277,8 +278,7 @@ static void ftfw_send(struct nethdr *net, struct us_conntrack *u) cn->rs_list.prev == &cn->rs_list) goto insert; - list_del(&cn->rs_list); - INIT_LIST_HEAD(&cn->rs_list); + list_del_init(&cn->rs_list); insert: cn->seq = net->seq; list_add(&cn->rs_list, &rs_list); @@ -320,8 +320,7 @@ static int tx_list_xmit(struct list_head *i, struct us_conntrack *u) ntohl(net->seq), ntohs(net->flags), ntohs(net->len)); - list_del(i); - INIT_LIST_HEAD(i); + list_del_init(i); tx_list_len--; ret = mcast_buffered_send_netmsg(STATE_SYNC(mcast_client), net, len); |