diff options
| author | Patrick McHardy <kaber@trash.net> | 2008-01-31 04:36:31 -0800 | 
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2008-01-31 19:27:51 -0800 | 
| commit | 47d9504543817b0aa908a37a335b90c30704a100 (patch) | |
| tree | 09718fcb2485e82b2151bcfa4621fa83b8367cbf /net | |
| parent | 1d670fdc8c14780b8e0ad915ad3bb13b2fd9223b (diff) | |
| download | linux-47d9504543817b0aa908a37a335b90c30704a100.tar.bz2 | |
[NETFILTER]: nf_conntrack: fix accounting with fixed timeouts
Don't skip accounting for conntracks with the FIXED_TIMEOUT bit.
Signed-off-by: Patrick McHardy <kaber@trash.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
| -rw-r--r-- | net/netfilter/nf_conntrack_core.c | 7 | 
1 files changed, 3 insertions, 4 deletions
| diff --git a/net/netfilter/nf_conntrack_core.c b/net/netfilter/nf_conntrack_core.c index 7b1f7e80f2f8..aa042c489685 100644 --- a/net/netfilter/nf_conntrack_core.c +++ b/net/netfilter/nf_conntrack_core.c @@ -776,10 +776,8 @@ void __nf_ct_refresh_acct(struct nf_conn *ct,  	write_lock_bh(&nf_conntrack_lock);  	/* Only update if this is not a fixed timeout */ -	if (test_bit(IPS_FIXED_TIMEOUT_BIT, &ct->status)) { -		write_unlock_bh(&nf_conntrack_lock); -		return; -	} +	if (test_bit(IPS_FIXED_TIMEOUT_BIT, &ct->status)) +		goto acct;  	/* If not in hash table, timer will not be active yet */  	if (!nf_ct_is_confirmed(ct)) { @@ -799,6 +797,7 @@ void __nf_ct_refresh_acct(struct nf_conn *ct,  		}  	} +acct:  #ifdef CONFIG_NF_CT_ACCT  	if (do_acct) {  		ct->counters[CTINFO2DIR(ctinfo)].packets++; |