netfilter: conntrack: place 'new' timeout in first location too
tcp, sctp and dccp trackers re-use the userspace ctnetlink states to index their timeout arrays, which means timeout[0] is never used. Copy the 'new' state (syn-sent, dccp-request, ..) to 0 as well so external users can simply read it off timeouts[0] without need to differentiate dccp/sctp/tcp and udp/icmp/gre/generic. The alternative is to map all array accesses to 'i - 1', but that is a much more intrusive change. Signed-off-by: Florian Westphal <fw@strlen.de> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
This commit is contained in:
Родитель
10568f6c57
Коммит
ef39078d63
|
@ -697,6 +697,8 @@ static int dccp_timeout_nlattr_to_obj(struct nlattr *tb[],
|
|||
timeouts[i] = ntohl(nla_get_be32(tb[i])) * HZ;
|
||||
}
|
||||
}
|
||||
|
||||
timeouts[CTA_TIMEOUT_DCCP_UNSPEC] = timeouts[CTA_TIMEOUT_DCCP_REQUEST];
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -827,6 +829,11 @@ static int dccp_init_net(struct net *net, u_int16_t proto)
|
|||
dn->dccp_timeout[CT_DCCP_CLOSEREQ] = 64 * HZ;
|
||||
dn->dccp_timeout[CT_DCCP_CLOSING] = 64 * HZ;
|
||||
dn->dccp_timeout[CT_DCCP_TIMEWAIT] = 2 * DCCP_MSL;
|
||||
|
||||
/* timeouts[0] is unused, make it same as SYN_SENT so
|
||||
* ->timeouts[0] contains 'new' timeout, like udp or icmp.
|
||||
*/
|
||||
dn->dccp_timeout[CT_DCCP_NONE] = dn->dccp_timeout[CT_DCCP_REQUEST];
|
||||
}
|
||||
|
||||
return dccp_kmemdup_sysctl_table(net, pn, dn);
|
||||
|
|
|
@ -613,6 +613,8 @@ static int sctp_timeout_nlattr_to_obj(struct nlattr *tb[],
|
|||
timeouts[i] = ntohl(nla_get_be32(tb[i])) * HZ;
|
||||
}
|
||||
}
|
||||
|
||||
timeouts[CTA_TIMEOUT_SCTP_UNSPEC] = timeouts[CTA_TIMEOUT_SCTP_CLOSED];
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -743,6 +745,11 @@ static int sctp_init_net(struct net *net, u_int16_t proto)
|
|||
|
||||
for (i = 0; i < SCTP_CONNTRACK_MAX; i++)
|
||||
sn->timeouts[i] = sctp_timeouts[i];
|
||||
|
||||
/* timeouts[0] is unused, init it so ->timeouts[0] contains
|
||||
* 'new' timeout, like udp or icmp.
|
||||
*/
|
||||
sn->timeouts[0] = sctp_timeouts[SCTP_CONNTRACK_CLOSED];
|
||||
}
|
||||
|
||||
return sctp_kmemdup_sysctl_table(pn, sn);
|
||||
|
|
|
@ -1301,6 +1301,7 @@ static int tcp_timeout_nlattr_to_obj(struct nlattr *tb[],
|
|||
timeouts[TCP_CONNTRACK_SYN_SENT] =
|
||||
ntohl(nla_get_be32(tb[CTA_TIMEOUT_TCP_SYN_SENT]))*HZ;
|
||||
}
|
||||
|
||||
if (tb[CTA_TIMEOUT_TCP_SYN_RECV]) {
|
||||
timeouts[TCP_CONNTRACK_SYN_RECV] =
|
||||
ntohl(nla_get_be32(tb[CTA_TIMEOUT_TCP_SYN_RECV]))*HZ;
|
||||
|
@ -1341,6 +1342,8 @@ static int tcp_timeout_nlattr_to_obj(struct nlattr *tb[],
|
|||
timeouts[TCP_CONNTRACK_UNACK] =
|
||||
ntohl(nla_get_be32(tb[CTA_TIMEOUT_TCP_UNACK]))*HZ;
|
||||
}
|
||||
|
||||
timeouts[CTA_TIMEOUT_TCP_UNSPEC] = timeouts[CTA_TIMEOUT_TCP_SYN_SENT];
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -1518,6 +1521,10 @@ static int tcp_init_net(struct net *net, u_int16_t proto)
|
|||
for (i = 0; i < TCP_CONNTRACK_TIMEOUT_MAX; i++)
|
||||
tn->timeouts[i] = tcp_timeouts[i];
|
||||
|
||||
/* timeouts[0] is unused, make it same as SYN_SENT so
|
||||
* ->timeouts[0] contains 'new' timeout, like udp or icmp.
|
||||
*/
|
||||
tn->timeouts[0] = tcp_timeouts[TCP_CONNTRACK_SYN_SENT];
|
||||
tn->tcp_loose = nf_ct_tcp_loose;
|
||||
tn->tcp_be_liberal = nf_ct_tcp_be_liberal;
|
||||
tn->tcp_max_retrans = nf_ct_tcp_max_retrans;
|
||||
|
|
Загрузка…
Ссылка в новой задаче