mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-12 00:00:00 +00:00
netfilter: flowtables: use fixed renew timeout on teardown
This is one of the very few external callers of ->get_timeouts(), We can use a fixed timeout instead, conntrack core will refresh this in case a new packet comes within this period. Use of ESTABLISHED timeout seems way too huge anyway. Signed-off-by: Florian Westphal <fw@strlen.de> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
This commit is contained in:
parent
6542df2f84
commit
e97d9404d5
@ -107,11 +107,12 @@ static void flow_offload_fixup_tcp(struct ip_ct_tcp *tcp)
|
||||
tcp->seen[1].td_maxwin = 0;
|
||||
}
|
||||
|
||||
#define NF_FLOWTABLE_TCP_PICKUP_TIMEOUT (120 * HZ)
|
||||
#define NF_FLOWTABLE_UDP_PICKUP_TIMEOUT (30 * HZ)
|
||||
|
||||
static void flow_offload_fixup_ct_state(struct nf_conn *ct)
|
||||
{
|
||||
const struct nf_conntrack_l4proto *l4proto;
|
||||
struct net *net = nf_ct_net(ct);
|
||||
unsigned int *timeouts;
|
||||
unsigned int timeout;
|
||||
int l4num;
|
||||
|
||||
@ -123,14 +124,10 @@ static void flow_offload_fixup_ct_state(struct nf_conn *ct)
|
||||
if (!l4proto)
|
||||
return;
|
||||
|
||||
timeouts = l4proto->get_timeouts(net);
|
||||
if (!timeouts)
|
||||
return;
|
||||
|
||||
if (l4num == IPPROTO_TCP)
|
||||
timeout = timeouts[TCP_CONNTRACK_ESTABLISHED];
|
||||
timeout = NF_FLOWTABLE_TCP_PICKUP_TIMEOUT;
|
||||
else if (l4num == IPPROTO_UDP)
|
||||
timeout = timeouts[UDP_CT_REPLIED];
|
||||
timeout = NF_FLOWTABLE_UDP_PICKUP_TIMEOUT;
|
||||
else
|
||||
return;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user