diff options
author | Reyk Floeter <reyk@cvs.openbsd.org> | 2007-12-20 20:07:42 +0000 |
---|---|---|
committer | Reyk Floeter <reyk@cvs.openbsd.org> | 2007-12-20 20:07:42 +0000 |
commit | ec7125ff6c5791611f3d901b4bd4d291bf45e23c (patch) | |
tree | 3925ccc7d2cf94db006482b9bacdcd02fc1af665 /sys/net | |
parent | dee72f1e6a5d45c4b5f5c1906edeb7daa96f78e5 (diff) |
increment the match/nomatch table counters when using a table/pool in
rdr rules. this helps to get some statistics about l3 redirections.
ok henning@
Diffstat (limited to 'sys/net')
-rw-r--r-- | sys/net/pf_table.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/sys/net/pf_table.c b/sys/net/pf_table.c index 8be75b2d835..eebe03bcb7e 100644 --- a/sys/net/pf_table.c +++ b/sys/net/pf_table.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pf_table.c,v 1.71 2007/09/01 18:49:27 henning Exp $ */ +/* $OpenBSD: pf_table.c,v 1.72 2007/12/20 20:07:41 reyk Exp $ */ /* * Copyright (c) 2002 Cedric Berger @@ -2122,8 +2122,10 @@ pfr_pool_get(struct pfr_ktable *kt, int *pidx, struct pf_addr *counter, _next_block: ke = pfr_kentry_byidx(kt, idx, af); - if (ke == NULL) + if (ke == NULL) { + kt->pfrkt_nomatch++; return (1); + } pfr_prepare_network(&pfr_mask, af, ke->pfrke_net); *raddr = SUNION2PF(&ke->pfrke_sa, af); *rmask = SUNION2PF(&pfr_mask, af); @@ -2146,6 +2148,7 @@ _next_block: /* this is a single IP address - no possible nested block */ PF_ACPY(counter, addr, af); *pidx = idx; + kt->pfrkt_match++; return (0); } for (;;) { @@ -2161,6 +2164,7 @@ _next_block: /* lookup return the same block - perfect */ PF_ACPY(counter, addr, af); *pidx = idx; + kt->pfrkt_match++; return (0); } |