summaryrefslogtreecommitdiff
path: root/src/traffic_stats.c
diff options
context:
space:
mode:
authorPablo Neira Ayuso <pablo@netfilter.org>2008-12-21 19:47:03 +0100
committerPablo Neira Ayuso <pablo@netfilter.org>2008-12-21 19:47:03 +0100
commit3641d2351ab42bef56e341ccca007331410822f2 (patch)
tree23ed80337fed1e57af1199da4a11238a32ffeab4 /src/traffic_stats.c
parent036a0a65c6a3ba95cff48035a25e0bdba6aa0452 (diff)
downloadconntrack-tools-3641d2351ab42bef56e341ccca007331410822f2.tar.gz
conntrack-tools-3641d2351ab42bef56e341ccca007331410822f2.zip
src: add run-time statistics via `-s runtime'
This patch adds run-time statistics that you can check via `conntrackd -s runtime'. This information is useful for trouble-shooting. This patch replaces several log messages that can be triggered in runtime. The idea behind this patch is to avoid log message flooding under errors. Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'src/traffic_stats.c')
-rw-r--r--src/traffic_stats.c16
1 files changed, 8 insertions, 8 deletions
diff --git a/src/traffic_stats.c b/src/traffic_stats.c
index 9e40d53..52ca09a 100644
--- a/src/traffic_stats.c
+++ b/src/traffic_stats.c
@@ -21,13 +21,13 @@
void update_traffic_stats(struct nf_conntrack *ct)
{
- STATE(bytes)[NFCT_DIR_ORIGINAL] +=
+ STATE(stats).bytes[NFCT_DIR_ORIGINAL] +=
nfct_get_attr_u32(ct, ATTR_ORIG_COUNTER_BYTES);
- STATE(bytes)[NFCT_DIR_REPLY] +=
+ STATE(stats).bytes[NFCT_DIR_REPLY] +=
nfct_get_attr_u32(ct, ATTR_REPL_COUNTER_BYTES);
- STATE(packets)[NFCT_DIR_ORIGINAL] +=
+ STATE(stats).packets[NFCT_DIR_ORIGINAL] +=
nfct_get_attr_u32(ct, ATTR_ORIG_COUNTER_PACKETS);
- STATE(packets)[NFCT_DIR_REPLY] +=
+ STATE(stats).packets[NFCT_DIR_REPLY] +=
nfct_get_attr_u32(ct, ATTR_REPL_COUNTER_PACKETS);
}
@@ -35,10 +35,10 @@ void dump_traffic_stats(int fd)
{
char buf[512];
int size;
- uint64_t bytes = STATE(bytes)[NFCT_DIR_ORIGINAL] +
- STATE(bytes)[NFCT_DIR_REPLY];
- uint64_t packets = STATE(packets)[NFCT_DIR_ORIGINAL] +
- STATE(packets)[NFCT_DIR_REPLY];
+ uint64_t bytes = STATE(stats).bytes[NFCT_DIR_ORIGINAL] +
+ STATE(stats).bytes[NFCT_DIR_REPLY];
+ uint64_t packets = STATE(stats).packets[NFCT_DIR_ORIGINAL] +
+ STATE(stats).packets[NFCT_DIR_REPLY];
size = sprintf(buf, "traffic processed:\n");
size += sprintf(buf+size, "%20llu Bytes ", (unsigned long long)bytes);