diff options
author | Duan Jiong <duanj.fnst@cn.fujitsu.com> | 2014-07-31 05:54:32 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-08-01 01:04:18 -0400 |
commit | 7304fe4681634a8e0511a5922c972aa132ffb43d (patch) | |
tree | 97d39043b738e7cd135efcd242dc2430919da2da /net/ipv4/tcp_ipv4.c | |
parent | 299ee123e19889d511092347f5fc14db0f10e3a6 (diff) |
net: fix the counter ICMP_MIB_INERRORS/ICMP6_MIB_INERRORS
When dealing with ICMPv[46] Error Message, function icmp_socket_deliver()
and icmpv6_notify() do some valid checks on packet's length, but then some
protocols check packet's length redaudantly. So remove those duplicated
statements, and increase counter ICMP_MIB_INERRORS/ICMP6_MIB_INERRORS in
function icmp_socket_deliver() and icmpv6_notify() respectively.
In addition, add missed counter in udp6/udplite6 when socket is NULL.
Signed-off-by: Duan Jiong <duanj.fnst@cn.fujitsu.com>
Acked-by: Hannes Frederic Sowa <hannes@stressinduktion.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/tcp_ipv4.c')
-rw-r--r-- | net/ipv4/tcp_ipv4.c | 5 |
1 files changed, 0 insertions, 5 deletions
diff --git a/net/ipv4/tcp_ipv4.c b/net/ipv4/tcp_ipv4.c index 1edc739b9da5..d0ba39537d5c 100644 --- a/net/ipv4/tcp_ipv4.c +++ b/net/ipv4/tcp_ipv4.c | |||
@@ -344,11 +344,6 @@ void tcp_v4_err(struct sk_buff *icmp_skb, u32 info) | |||
344 | int err; | 344 | int err; |
345 | struct net *net = dev_net(icmp_skb->dev); | 345 | struct net *net = dev_net(icmp_skb->dev); |
346 | 346 | ||
347 | if (icmp_skb->len < (iph->ihl << 2) + 8) { | ||
348 | ICMP_INC_STATS_BH(net, ICMP_MIB_INERRORS); | ||
349 | return; | ||
350 | } | ||
351 | |||
352 | sk = inet_lookup(net, &tcp_hashinfo, iph->daddr, th->dest, | 347 | sk = inet_lookup(net, &tcp_hashinfo, iph->daddr, th->dest, |
353 | iph->saddr, th->source, inet_iif(icmp_skb)); | 348 | iph->saddr, th->source, inet_iif(icmp_skb)); |
354 | if (!sk) { | 349 | if (!sk) { |