Commit 35d8deb8 authored by Yi-Hung Wei's avatar Yi-Hung Wei Committed by Pablo Neira Ayuso

netfilter: conncount: Support count only use case

Currently, nf_conncount_count() counts the number of connections that
matches key and inserts a conntrack 'tuple' with the same key into the
accounting data structure.  This patch supports another use case that only
counts the number of connections where 'tuple' is not provided.  Therefore,
proper changes are made on nf_conncount_count() to support the case where
'tuple' is NULL.  This could be useful for querying statistics or
debugging purpose.
Signed-off-by: default avatarYi-Hung Wei <yihung.wei@gmail.com>
Acked-by: default avatarFlorian Westphal <fw@strlen.de>
Signed-off-by: default avatarPablo Neira Ayuso <pablo@netfilter.org>
parent 6aec2087
...@@ -104,7 +104,7 @@ static unsigned int check_hlist(struct net *net, ...@@ -104,7 +104,7 @@ static unsigned int check_hlist(struct net *net,
struct nf_conn *found_ct; struct nf_conn *found_ct;
unsigned int length = 0; unsigned int length = 0;
*addit = true; *addit = tuple ? true : false;
/* check the saved connections */ /* check the saved connections */
hlist_for_each_entry_safe(conn, n, head, node) { hlist_for_each_entry_safe(conn, n, head, node) {
...@@ -117,7 +117,7 @@ static unsigned int check_hlist(struct net *net, ...@@ -117,7 +117,7 @@ static unsigned int check_hlist(struct net *net,
found_ct = nf_ct_tuplehash_to_ctrack(found); found_ct = nf_ct_tuplehash_to_ctrack(found);
if (nf_ct_tuple_equal(&conn->tuple, tuple)) { if (tuple && nf_ct_tuple_equal(&conn->tuple, tuple)) {
/* /*
* Just to be sure we have it only once in the list. * Just to be sure we have it only once in the list.
* We should not see tuples twice unless someone hooks * We should not see tuples twice unless someone hooks
...@@ -220,6 +220,9 @@ count_tree(struct net *net, struct rb_root *root, ...@@ -220,6 +220,9 @@ count_tree(struct net *net, struct rb_root *root,
goto restart; goto restart;
} }
if (!tuple)
return 0;
/* no match, need to insert new node */ /* no match, need to insert new node */
rbconn = kmem_cache_alloc(conncount_rb_cachep, GFP_ATOMIC); rbconn = kmem_cache_alloc(conncount_rb_cachep, GFP_ATOMIC);
if (rbconn == NULL) if (rbconn == NULL)
...@@ -242,6 +245,9 @@ count_tree(struct net *net, struct rb_root *root, ...@@ -242,6 +245,9 @@ count_tree(struct net *net, struct rb_root *root,
return 1; return 1;
} }
/* Count and return number of conntrack entries in 'net' with particular 'key'.
* If 'tuple' is not null, insert it into the accounting data structure.
*/
unsigned int nf_conncount_count(struct net *net, unsigned int nf_conncount_count(struct net *net,
struct nf_conncount_data *data, struct nf_conncount_data *data,
const u32 *key, const u32 *key,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment