netfilter: nf_conntrack: fix racy timer handling with reliable events
authorPablo Neira Ayuso <pablo@netfilter.org>
Wed, 29 Aug 2012 16:25:49 +0000 (16:25 +0000)
committerBen Hutchings <ben@decadent.org.uk>
Tue, 30 Oct 2012 23:27:08 +0000 (23:27 +0000)
commitcc1b75d796ad050c83c95733c4220aaa04fa1304
treeaca917b1aa12dfc78c34727fffb5b09bdf766b1b
parent8c812dca4d68f3c11e6f6d28cd8e92b4282909a6
netfilter: nf_conntrack: fix racy timer handling with reliable events

commit 5b423f6a40a0327f9d40bc8b97ce9be266f74368 upstream.

Existing code assumes that del_timer returns true for alive conntrack
entries. However, this is not true if reliable events are enabled.
In that case, del_timer may return true for entries that were
just inserted in the dying list. Note that packets / ctnetlink may
hold references to conntrack entries that were just inserted to such
list.

This patch fixes the issue by adding an independent timer for
event delivery. This increases the size of the ecache extension.
Still we can revisit this later and use variable size extensions
to allocate this area on demand.

Tested-by: Oliver Smith <olipro@8.c.9.b.0.7.4.0.1.0.0.2.ip6.arpa>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Acked-by: David Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
include/net/netfilter/nf_conntrack_ecache.h
net/netfilter/nf_conntrack_core.c