aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/uapi/linux/snmp.h5
-rw-r--r--net/ipv4/icmp.c4
-rw-r--r--net/ipv4/ip_input.c4
-rw-r--r--net/ipv4/proc.c10
-rw-r--r--net/ipv4/tcp_input.c1
-rw-r--r--net/ipv4/tcp_ipv4.c14
-rw-r--r--net/ipv4/tcp_output.c3
-rw-r--r--net/ipv4/udp.c11
-rw-r--r--net/ipv6/icmp.c4
-rw-r--r--net/ipv6/proc.c4
-rw-r--r--net/ipv6/tcp_ipv6.c19
-rw-r--r--net/ipv6/udp.c21
12 files changed, 72 insertions, 28 deletions
diff --git a/include/uapi/linux/snmp.h b/include/uapi/linux/snmp.h
index fefdec91c68b..df2e8b4f9c03 100644
--- a/include/uapi/linux/snmp.h
+++ b/include/uapi/linux/snmp.h
@@ -50,6 +50,7 @@ enum
50 IPSTATS_MIB_OUTMCASTOCTETS, /* OutMcastOctets */ 50 IPSTATS_MIB_OUTMCASTOCTETS, /* OutMcastOctets */
51 IPSTATS_MIB_INBCASTOCTETS, /* InBcastOctets */ 51 IPSTATS_MIB_INBCASTOCTETS, /* InBcastOctets */
52 IPSTATS_MIB_OUTBCASTOCTETS, /* OutBcastOctets */ 52 IPSTATS_MIB_OUTBCASTOCTETS, /* OutBcastOctets */
53 IPSTATS_MIB_CSUMERRORS, /* InCsumErrors */
53 __IPSTATS_MIB_MAX 54 __IPSTATS_MIB_MAX
54}; 55};
55 56
@@ -87,6 +88,7 @@ enum
87 ICMP_MIB_OUTTIMESTAMPREPS, /* OutTimestampReps */ 88 ICMP_MIB_OUTTIMESTAMPREPS, /* OutTimestampReps */
88 ICMP_MIB_OUTADDRMASKS, /* OutAddrMasks */ 89 ICMP_MIB_OUTADDRMASKS, /* OutAddrMasks */
89 ICMP_MIB_OUTADDRMASKREPS, /* OutAddrMaskReps */ 90 ICMP_MIB_OUTADDRMASKREPS, /* OutAddrMaskReps */
91 ICMP_MIB_CSUMERRORS, /* InCsumErrors */
90 __ICMP_MIB_MAX 92 __ICMP_MIB_MAX
91}; 93};
92 94
@@ -103,6 +105,7 @@ enum
103 ICMP6_MIB_INERRORS, /* InErrors */ 105 ICMP6_MIB_INERRORS, /* InErrors */
104 ICMP6_MIB_OUTMSGS, /* OutMsgs */ 106 ICMP6_MIB_OUTMSGS, /* OutMsgs */
105 ICMP6_MIB_OUTERRORS, /* OutErrors */ 107 ICMP6_MIB_OUTERRORS, /* OutErrors */
108 ICMP6_MIB_CSUMERRORS, /* InCsumErrors */
106 __ICMP6_MIB_MAX 109 __ICMP6_MIB_MAX
107}; 110};
108 111
@@ -130,6 +133,7 @@ enum
130 TCP_MIB_RETRANSSEGS, /* RetransSegs */ 133 TCP_MIB_RETRANSSEGS, /* RetransSegs */
131 TCP_MIB_INERRS, /* InErrs */ 134 TCP_MIB_INERRS, /* InErrs */
132 TCP_MIB_OUTRSTS, /* OutRsts */ 135 TCP_MIB_OUTRSTS, /* OutRsts */
136 TCP_MIB_CSUMERRORS, /* InCsumErrors */
133 __TCP_MIB_MAX 137 __TCP_MIB_MAX
134}; 138};
135 139
@@ -147,6 +151,7 @@ enum
147 UDP_MIB_OUTDATAGRAMS, /* OutDatagrams */ 151 UDP_MIB_OUTDATAGRAMS, /* OutDatagrams */
148 UDP_MIB_RCVBUFERRORS, /* RcvbufErrors */ 152 UDP_MIB_RCVBUFERRORS, /* RcvbufErrors */
149 UDP_MIB_SNDBUFERRORS, /* SndbufErrors */ 153 UDP_MIB_SNDBUFERRORS, /* SndbufErrors */
154 UDP_MIB_CSUMERRORS, /* InCsumErrors */
150 __UDP_MIB_MAX 155 __UDP_MIB_MAX
151}; 156};
152 157
diff --git a/net/ipv4/icmp.c b/net/ipv4/icmp.c
index 3ac5dff79627..76e10b47e053 100644
--- a/net/ipv4/icmp.c
+++ b/net/ipv4/icmp.c
@@ -881,7 +881,7 @@ int icmp_rcv(struct sk_buff *skb)
881 case CHECKSUM_NONE: 881 case CHECKSUM_NONE:
882 skb->csum = 0; 882 skb->csum = 0;
883 if (__skb_checksum_complete(skb)) 883 if (__skb_checksum_complete(skb))
884 goto error; 884 goto csum_error;
885 } 885 }
886 886
887 if (!pskb_pull(skb, sizeof(*icmph))) 887 if (!pskb_pull(skb, sizeof(*icmph)))
@@ -929,6 +929,8 @@ int icmp_rcv(struct sk_buff *skb)
929drop: 929drop:
930 kfree_skb(skb); 930 kfree_skb(skb);
931 return 0; 931 return 0;
932csum_error:
933 ICMP_INC_STATS_BH(net, ICMP_MIB_CSUMERRORS);
932error: 934error:
933 ICMP_INC_STATS_BH(net, ICMP_MIB_INERRORS); 935 ICMP_INC_STATS_BH(net, ICMP_MIB_INERRORS);
934 goto drop; 936 goto drop;
diff --git a/net/ipv4/ip_input.c b/net/ipv4/ip_input.c
index 2bdf802e28e2..3da817b89e9b 100644
--- a/net/ipv4/ip_input.c
+++ b/net/ipv4/ip_input.c
@@ -419,7 +419,7 @@ int ip_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt,
419 iph = ip_hdr(skb); 419 iph = ip_hdr(skb);
420 420
421 if (unlikely(ip_fast_csum((u8 *)iph, iph->ihl))) 421 if (unlikely(ip_fast_csum((u8 *)iph, iph->ihl)))
422 goto inhdr_error; 422 goto csum_error;
423 423
424 len = ntohs(iph->tot_len); 424 len = ntohs(iph->tot_len);
425 if (skb->len < len) { 425 if (skb->len < len) {
@@ -446,6 +446,8 @@ int ip_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt,
446 return NF_HOOK(NFPROTO_IPV4, NF_INET_PRE_ROUTING, skb, dev, NULL, 446 return NF_HOOK(NFPROTO_IPV4, NF_INET_PRE_ROUTING, skb, dev, NULL,
447 ip_rcv_finish); 447 ip_rcv_finish);
448 448
449csum_error:
450 IP_INC_STATS_BH(dev_net(dev), IPSTATS_MIB_CSUMERRORS);
449inhdr_error: 451inhdr_error:
450 IP_INC_STATS_BH(dev_net(dev), IPSTATS_MIB_INHDRERRORS); 452 IP_INC_STATS_BH(dev_net(dev), IPSTATS_MIB_INHDRERRORS);
451drop: 453drop:
diff --git a/net/ipv4/proc.c b/net/ipv4/proc.c
index 6da51d55d03a..2a5bf86d2415 100644
--- a/net/ipv4/proc.c
+++ b/net/ipv4/proc.c
@@ -125,6 +125,7 @@ static const struct snmp_mib snmp4_ipextstats_list[] = {
125 SNMP_MIB_ITEM("OutMcastOctets", IPSTATS_MIB_OUTMCASTOCTETS), 125 SNMP_MIB_ITEM("OutMcastOctets", IPSTATS_MIB_OUTMCASTOCTETS),
126 SNMP_MIB_ITEM("InBcastOctets", IPSTATS_MIB_INBCASTOCTETS), 126 SNMP_MIB_ITEM("InBcastOctets", IPSTATS_MIB_INBCASTOCTETS),
127 SNMP_MIB_ITEM("OutBcastOctets", IPSTATS_MIB_OUTBCASTOCTETS), 127 SNMP_MIB_ITEM("OutBcastOctets", IPSTATS_MIB_OUTBCASTOCTETS),
128 SNMP_MIB_ITEM("InCsumErrors", IPSTATS_MIB_CSUMERRORS),
128 SNMP_MIB_SENTINEL 129 SNMP_MIB_SENTINEL
129}; 130};
130 131
@@ -162,6 +163,7 @@ static const struct snmp_mib snmp4_tcp_list[] = {
162 SNMP_MIB_ITEM("RetransSegs", TCP_MIB_RETRANSSEGS), 163 SNMP_MIB_ITEM("RetransSegs", TCP_MIB_RETRANSSEGS),
163 SNMP_MIB_ITEM("InErrs", TCP_MIB_INERRS), 164 SNMP_MIB_ITEM("InErrs", TCP_MIB_INERRS),
164 SNMP_MIB_ITEM("OutRsts", TCP_MIB_OUTRSTS), 165 SNMP_MIB_ITEM("OutRsts", TCP_MIB_OUTRSTS),
166 SNMP_MIB_ITEM("InCsumErrors", TCP_MIB_CSUMERRORS),
165 SNMP_MIB_SENTINEL 167 SNMP_MIB_SENTINEL
166}; 168};
167 169
@@ -172,6 +174,7 @@ static const struct snmp_mib snmp4_udp_list[] = {
172 SNMP_MIB_ITEM("OutDatagrams", UDP_MIB_OUTDATAGRAMS), 174 SNMP_MIB_ITEM("OutDatagrams", UDP_MIB_OUTDATAGRAMS),
173 SNMP_MIB_ITEM("RcvbufErrors", UDP_MIB_RCVBUFERRORS), 175 SNMP_MIB_ITEM("RcvbufErrors", UDP_MIB_RCVBUFERRORS),
174 SNMP_MIB_ITEM("SndbufErrors", UDP_MIB_SNDBUFERRORS), 176 SNMP_MIB_ITEM("SndbufErrors", UDP_MIB_SNDBUFERRORS),
177 SNMP_MIB_ITEM("InCsumErrors", UDP_MIB_CSUMERRORS),
175 SNMP_MIB_SENTINEL 178 SNMP_MIB_SENTINEL
176}; 179};
177 180
@@ -322,15 +325,16 @@ static void icmp_put(struct seq_file *seq)
322 struct net *net = seq->private; 325 struct net *net = seq->private;
323 atomic_long_t *ptr = net->mib.icmpmsg_statistics->mibs; 326 atomic_long_t *ptr = net->mib.icmpmsg_statistics->mibs;
324 327
325 seq_puts(seq, "\nIcmp: InMsgs InErrors"); 328 seq_puts(seq, "\nIcmp: InMsgs InErrors InCsumErrors");
326 for (i=0; icmpmibmap[i].name != NULL; i++) 329 for (i=0; icmpmibmap[i].name != NULL; i++)
327 seq_printf(seq, " In%s", icmpmibmap[i].name); 330 seq_printf(seq, " In%s", icmpmibmap[i].name);
328 seq_printf(seq, " OutMsgs OutErrors"); 331 seq_printf(seq, " OutMsgs OutErrors");
329 for (i=0; icmpmibmap[i].name != NULL; i++) 332 for (i=0; icmpmibmap[i].name != NULL; i++)
330 seq_printf(seq, " Out%s", icmpmibmap[i].name); 333 seq_printf(seq, " Out%s", icmpmibmap[i].name);
331 seq_printf(seq, "\nIcmp: %lu %lu", 334 seq_printf(seq, "\nIcmp: %lu %lu %lu",
332 snmp_fold_field((void __percpu **) net->mib.icmp_statistics, ICMP_MIB_INMSGS), 335 snmp_fold_field((void __percpu **) net->mib.icmp_statistics, ICMP_MIB_INMSGS),
333 snmp_fold_field((void __percpu **) net->mib.icmp_statistics, ICMP_MIB_INERRORS)); 336 snmp_fold_field((void __percpu **) net->mib.icmp_statistics, ICMP_MIB_INERRORS),
337 snmp_fold_field((void __percpu **) net->mib.icmp_statistics, ICMP_MIB_CSUMERRORS));
334 for (i=0; icmpmibmap[i].name != NULL; i++) 338 for (i=0; icmpmibmap[i].name != NULL; i++)
335 seq_printf(seq, " %lu", 339 seq_printf(seq, " %lu",
336 atomic_long_read(ptr + icmpmibmap[i].index)); 340 atomic_long_read(ptr + icmpmibmap[i].index));
diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c
index aafd052865ba..08bbe6096528 100644
--- a/net/ipv4/tcp_input.c
+++ b/net/ipv4/tcp_input.c
@@ -5273,6 +5273,7 @@ step5:
5273 return 0; 5273 return 0;
5274 5274
5275csum_error: 5275csum_error:
5276 TCP_INC_STATS_BH(sock_net(sk), TCP_MIB_CSUMERRORS);
5276 TCP_INC_STATS_BH(sock_net(sk), TCP_MIB_INERRS); 5277 TCP_INC_STATS_BH(sock_net(sk), TCP_MIB_INERRS);
5277 5278
5278discard: 5279discard:
diff --git a/net/ipv4/tcp_ipv4.c b/net/ipv4/tcp_ipv4.c
index 2278669b1d85..8ea975164596 100644
--- a/net/ipv4/tcp_ipv4.c
+++ b/net/ipv4/tcp_ipv4.c
@@ -1866,6 +1866,7 @@ discard:
1866 return 0; 1866 return 0;
1867 1867
1868csum_err: 1868csum_err:
1869 TCP_INC_STATS_BH(sock_net(sk), TCP_MIB_CSUMERRORS);
1869 TCP_INC_STATS_BH(sock_net(sk), TCP_MIB_INERRS); 1870 TCP_INC_STATS_BH(sock_net(sk), TCP_MIB_INERRS);
1870 goto discard; 1871 goto discard;
1871} 1872}
@@ -1985,7 +1986,7 @@ int tcp_v4_rcv(struct sk_buff *skb)
1985 * provided case of th->doff==0 is eliminated. 1986 * provided case of th->doff==0 is eliminated.
1986 * So, we defer the checks. */ 1987 * So, we defer the checks. */
1987 if (!skb_csum_unnecessary(skb) && tcp_v4_checksum_init(skb)) 1988 if (!skb_csum_unnecessary(skb) && tcp_v4_checksum_init(skb))
1988 goto bad_packet; 1989 goto csum_error;
1989 1990
1990 th = tcp_hdr(skb); 1991 th = tcp_hdr(skb);
1991 iph = ip_hdr(skb); 1992 iph = ip_hdr(skb);
@@ -2051,6 +2052,8 @@ no_tcp_socket:
2051 goto discard_it; 2052 goto discard_it;
2052 2053
2053 if (skb->len < (th->doff << 2) || tcp_checksum_complete(skb)) { 2054 if (skb->len < (th->doff << 2) || tcp_checksum_complete(skb)) {
2055csum_error:
2056 TCP_INC_STATS_BH(net, TCP_MIB_CSUMERRORS);
2054bad_packet: 2057bad_packet:
2055 TCP_INC_STATS_BH(net, TCP_MIB_INERRS); 2058 TCP_INC_STATS_BH(net, TCP_MIB_INERRS);
2056 } else { 2059 } else {
@@ -2072,10 +2075,13 @@ do_time_wait:
2072 goto discard_it; 2075 goto discard_it;
2073 } 2076 }
2074 2077
2075 if (skb->len < (th->doff << 2) || tcp_checksum_complete(skb)) { 2078 if (skb->len < (th->doff << 2)) {
2076 TCP_INC_STATS_BH(net, TCP_MIB_INERRS);
2077 inet_twsk_put(inet_twsk(sk)); 2079 inet_twsk_put(inet_twsk(sk));
2078 goto discard_it; 2080 goto bad_packet;
2081 }
2082 if (tcp_checksum_complete(skb)) {
2083 inet_twsk_put(inet_twsk(sk));
2084 goto csum_error;
2079 } 2085 }
2080 switch (tcp_timewait_state_process(inet_twsk(sk), skb, th)) { 2086 switch (tcp_timewait_state_process(inet_twsk(sk), skb, th)) {
2081 case TCP_TW_SYN: { 2087 case TCP_TW_SYN: {
diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c
index b735c23a961d..536d40929ba6 100644
--- a/net/ipv4/tcp_output.c
+++ b/net/ipv4/tcp_output.c
@@ -80,8 +80,9 @@ static void tcp_event_new_data_sent(struct sock *sk, const struct sk_buff *skb)
80 80
81 tp->packets_out += tcp_skb_pcount(skb); 81 tp->packets_out += tcp_skb_pcount(skb);
82 if (!prior_packets || icsk->icsk_pending == ICSK_TIME_EARLY_RETRANS || 82 if (!prior_packets || icsk->icsk_pending == ICSK_TIME_EARLY_RETRANS ||
83 icsk->icsk_pending == ICSK_TIME_LOSS_PROBE) 83 icsk->icsk_pending == ICSK_TIME_LOSS_PROBE) {
84 tcp_rearm_rto(sk); 84 tcp_rearm_rto(sk);
85 }
85} 86}
86 87
87/* SND.NXT, if window was not shrunk. 88/* SND.NXT, if window was not shrunk.
diff --git a/net/ipv4/udp.c b/net/ipv4/udp.c
index 2722db024a0b..3159d16441d0 100644
--- a/net/ipv4/udp.c
+++ b/net/ipv4/udp.c
@@ -1131,6 +1131,8 @@ static unsigned int first_packet_length(struct sock *sk)
1131 spin_lock_bh(&rcvq->lock); 1131 spin_lock_bh(&rcvq->lock);
1132 while ((skb = skb_peek(rcvq)) != NULL && 1132 while ((skb = skb_peek(rcvq)) != NULL &&
1133 udp_lib_checksum_complete(skb)) { 1133 udp_lib_checksum_complete(skb)) {
1134 UDP_INC_STATS_BH(sock_net(sk), UDP_MIB_CSUMERRORS,
1135 IS_UDPLITE(sk));
1134 UDP_INC_STATS_BH(sock_net(sk), UDP_MIB_INERRORS, 1136 UDP_INC_STATS_BH(sock_net(sk), UDP_MIB_INERRORS,
1135 IS_UDPLITE(sk)); 1137 IS_UDPLITE(sk));
1136 atomic_inc(&sk->sk_drops); 1138 atomic_inc(&sk->sk_drops);
@@ -1286,8 +1288,10 @@ out:
1286 1288
1287csum_copy_err: 1289csum_copy_err:
1288 slow = lock_sock_fast(sk); 1290 slow = lock_sock_fast(sk);
1289 if (!skb_kill_datagram(sk, skb, flags)) 1291 if (!skb_kill_datagram(sk, skb, flags)) {
1292 UDP_INC_STATS_USER(sock_net(sk), UDP_MIB_CSUMERRORS, is_udplite);
1290 UDP_INC_STATS_USER(sock_net(sk), UDP_MIB_INERRORS, is_udplite); 1293 UDP_INC_STATS_USER(sock_net(sk), UDP_MIB_INERRORS, is_udplite);
1294 }
1291 unlock_sock_fast(sk, slow); 1295 unlock_sock_fast(sk, slow);
1292 1296
1293 if (noblock) 1297 if (noblock)
@@ -1513,7 +1517,7 @@ int udp_queue_rcv_skb(struct sock *sk, struct sk_buff *skb)
1513 1517
1514 if (rcu_access_pointer(sk->sk_filter) && 1518 if (rcu_access_pointer(sk->sk_filter) &&
1515 udp_lib_checksum_complete(skb)) 1519 udp_lib_checksum_complete(skb))
1516 goto drop; 1520 goto csum_error;
1517 1521
1518 1522
1519 if (sk_rcvqueues_full(sk, skb, sk->sk_rcvbuf)) 1523 if (sk_rcvqueues_full(sk, skb, sk->sk_rcvbuf))
@@ -1533,6 +1537,8 @@ int udp_queue_rcv_skb(struct sock *sk, struct sk_buff *skb)
1533 1537
1534 return rc; 1538 return rc;
1535 1539
1540csum_error:
1541 UDP_INC_STATS_BH(sock_net(sk), UDP_MIB_CSUMERRORS, is_udplite);
1536drop: 1542drop:
1537 UDP_INC_STATS_BH(sock_net(sk), UDP_MIB_INERRORS, is_udplite); 1543 UDP_INC_STATS_BH(sock_net(sk), UDP_MIB_INERRORS, is_udplite);
1538 atomic_inc(&sk->sk_drops); 1544 atomic_inc(&sk->sk_drops);
@@ -1749,6 +1755,7 @@ csum_error:
1749 proto == IPPROTO_UDPLITE ? "Lite" : "", 1755 proto == IPPROTO_UDPLITE ? "Lite" : "",
1750 &saddr, ntohs(uh->source), &daddr, ntohs(uh->dest), 1756 &saddr, ntohs(uh->source), &daddr, ntohs(uh->dest),
1751 ulen); 1757 ulen);
1758 UDP_INC_STATS_BH(net, UDP_MIB_CSUMERRORS, proto == IPPROTO_UDPLITE);
1752drop: 1759drop:
1753 UDP_INC_STATS_BH(net, UDP_MIB_INERRORS, proto == IPPROTO_UDPLITE); 1760 UDP_INC_STATS_BH(net, UDP_MIB_INERRORS, proto == IPPROTO_UDPLITE);
1754 kfree_skb(skb); 1761 kfree_skb(skb);
diff --git a/net/ipv6/icmp.c b/net/ipv6/icmp.c
index 2a53a790514d..b4ff0a42b8c7 100644
--- a/net/ipv6/icmp.c
+++ b/net/ipv6/icmp.c
@@ -699,7 +699,7 @@ static int icmpv6_rcv(struct sk_buff *skb)
699 if (__skb_checksum_complete(skb)) { 699 if (__skb_checksum_complete(skb)) {
700 LIMIT_NETDEBUG(KERN_DEBUG "ICMPv6 checksum failed [%pI6 > %pI6]\n", 700 LIMIT_NETDEBUG(KERN_DEBUG "ICMPv6 checksum failed [%pI6 > %pI6]\n",
701 saddr, daddr); 701 saddr, daddr);
702 goto discard_it; 702 goto csum_error;
703 } 703 }
704 } 704 }
705 705
@@ -785,6 +785,8 @@ static int icmpv6_rcv(struct sk_buff *skb)
785 kfree_skb(skb); 785 kfree_skb(skb);
786 return 0; 786 return 0;
787 787
788csum_error:
789 ICMP6_INC_STATS_BH(dev_net(dev), idev, ICMP6_MIB_CSUMERRORS);
788discard_it: 790discard_it:
789 ICMP6_INC_STATS_BH(dev_net(dev), idev, ICMP6_MIB_INERRORS); 791 ICMP6_INC_STATS_BH(dev_net(dev), idev, ICMP6_MIB_INERRORS);
790drop_no_count: 792drop_no_count:
diff --git a/net/ipv6/proc.c b/net/ipv6/proc.c
index bbbe53a99b57..115cc58898f5 100644
--- a/net/ipv6/proc.c
+++ b/net/ipv6/proc.c
@@ -90,6 +90,7 @@ static const struct snmp_mib snmp6_ipstats_list[] = {
90 SNMP_MIB_ITEM("Ip6OutMcastOctets", IPSTATS_MIB_OUTMCASTOCTETS), 90 SNMP_MIB_ITEM("Ip6OutMcastOctets", IPSTATS_MIB_OUTMCASTOCTETS),
91 SNMP_MIB_ITEM("Ip6InBcastOctets", IPSTATS_MIB_INBCASTOCTETS), 91 SNMP_MIB_ITEM("Ip6InBcastOctets", IPSTATS_MIB_INBCASTOCTETS),
92 SNMP_MIB_ITEM("Ip6OutBcastOctets", IPSTATS_MIB_OUTBCASTOCTETS), 92 SNMP_MIB_ITEM("Ip6OutBcastOctets", IPSTATS_MIB_OUTBCASTOCTETS),
93 SNMP_MIB_ITEM("InCsumErrors", IPSTATS_MIB_CSUMERRORS),
93 SNMP_MIB_SENTINEL 94 SNMP_MIB_SENTINEL
94}; 95};
95 96
@@ -99,6 +100,7 @@ static const struct snmp_mib snmp6_icmp6_list[] = {
99 SNMP_MIB_ITEM("Icmp6InErrors", ICMP6_MIB_INERRORS), 100 SNMP_MIB_ITEM("Icmp6InErrors", ICMP6_MIB_INERRORS),
100 SNMP_MIB_ITEM("Icmp6OutMsgs", ICMP6_MIB_OUTMSGS), 101 SNMP_MIB_ITEM("Icmp6OutMsgs", ICMP6_MIB_OUTMSGS),
101 SNMP_MIB_ITEM("Icmp6OutErrors", ICMP6_MIB_OUTERRORS), 102 SNMP_MIB_ITEM("Icmp6OutErrors", ICMP6_MIB_OUTERRORS),
103 SNMP_MIB_ITEM("Icmp6InCsumErrors", ICMP6_MIB_CSUMERRORS),
102 SNMP_MIB_SENTINEL 104 SNMP_MIB_SENTINEL
103}; 105};
104 106
@@ -129,6 +131,7 @@ static const struct snmp_mib snmp6_udp6_list[] = {
129 SNMP_MIB_ITEM("Udp6OutDatagrams", UDP_MIB_OUTDATAGRAMS), 131 SNMP_MIB_ITEM("Udp6OutDatagrams", UDP_MIB_OUTDATAGRAMS),
130 SNMP_MIB_ITEM("Udp6RcvbufErrors", UDP_MIB_RCVBUFERRORS), 132 SNMP_MIB_ITEM("Udp6RcvbufErrors", UDP_MIB_RCVBUFERRORS),
131 SNMP_MIB_ITEM("Udp6SndbufErrors", UDP_MIB_SNDBUFERRORS), 133 SNMP_MIB_ITEM("Udp6SndbufErrors", UDP_MIB_SNDBUFERRORS),
134 SNMP_MIB_ITEM("Udp6InCsumErrors", UDP_MIB_CSUMERRORS),
132 SNMP_MIB_SENTINEL 135 SNMP_MIB_SENTINEL
133}; 136};
134 137
@@ -139,6 +142,7 @@ static const struct snmp_mib snmp6_udplite6_list[] = {
139 SNMP_MIB_ITEM("UdpLite6OutDatagrams", UDP_MIB_OUTDATAGRAMS), 142 SNMP_MIB_ITEM("UdpLite6OutDatagrams", UDP_MIB_OUTDATAGRAMS),
140 SNMP_MIB_ITEM("UdpLite6RcvbufErrors", UDP_MIB_RCVBUFERRORS), 143 SNMP_MIB_ITEM("UdpLite6RcvbufErrors", UDP_MIB_RCVBUFERRORS),
141 SNMP_MIB_ITEM("UdpLite6SndbufErrors", UDP_MIB_SNDBUFERRORS), 144 SNMP_MIB_ITEM("UdpLite6SndbufErrors", UDP_MIB_SNDBUFERRORS),
145 SNMP_MIB_ITEM("UdpLite6InCsumErrors", UDP_MIB_CSUMERRORS),
142 SNMP_MIB_SENTINEL 146 SNMP_MIB_SENTINEL
143}; 147};
144 148
diff --git a/net/ipv6/tcp_ipv6.c b/net/ipv6/tcp_ipv6.c
index e51bd1a58264..71167069b394 100644
--- a/net/ipv6/tcp_ipv6.c
+++ b/net/ipv6/tcp_ipv6.c
@@ -1405,6 +1405,7 @@ discard:
1405 kfree_skb(skb); 1405 kfree_skb(skb);
1406 return 0; 1406 return 0;
1407csum_err: 1407csum_err:
1408 TCP_INC_STATS_BH(sock_net(sk), TCP_MIB_CSUMERRORS);
1408 TCP_INC_STATS_BH(sock_net(sk), TCP_MIB_INERRS); 1409 TCP_INC_STATS_BH(sock_net(sk), TCP_MIB_INERRS);
1409 goto discard; 1410 goto discard;
1410 1411
@@ -1466,7 +1467,7 @@ static int tcp_v6_rcv(struct sk_buff *skb)
1466 goto discard_it; 1467 goto discard_it;
1467 1468
1468 if (!skb_csum_unnecessary(skb) && tcp_v6_checksum_init(skb)) 1469 if (!skb_csum_unnecessary(skb) && tcp_v6_checksum_init(skb))
1469 goto bad_packet; 1470 goto csum_error;
1470 1471
1471 th = tcp_hdr(skb); 1472 th = tcp_hdr(skb);
1472 hdr = ipv6_hdr(skb); 1473 hdr = ipv6_hdr(skb);
@@ -1530,6 +1531,8 @@ no_tcp_socket:
1530 goto discard_it; 1531 goto discard_it;
1531 1532
1532 if (skb->len < (th->doff<<2) || tcp_checksum_complete(skb)) { 1533 if (skb->len < (th->doff<<2) || tcp_checksum_complete(skb)) {
1534csum_error:
1535 TCP_INC_STATS_BH(net, TCP_MIB_CSUMERRORS);
1533bad_packet: 1536bad_packet:
1534 TCP_INC_STATS_BH(net, TCP_MIB_INERRS); 1537 TCP_INC_STATS_BH(net, TCP_MIB_INERRS);
1535 } else { 1538 } else {
@@ -1537,11 +1540,6 @@ bad_packet:
1537 } 1540 }
1538 1541
1539discard_it: 1542discard_it:
1540
1541 /*
1542 * Discard frame
1543 */
1544
1545 kfree_skb(skb); 1543 kfree_skb(skb);
1546 return 0; 1544 return 0;
1547 1545
@@ -1555,10 +1553,13 @@ do_time_wait:
1555 goto discard_it; 1553 goto discard_it;
1556 } 1554 }
1557 1555
1558 if (skb->len < (th->doff<<2) || tcp_checksum_complete(skb)) { 1556 if (skb->len < (th->doff<<2)) {
1559 TCP_INC_STATS_BH(net, TCP_MIB_INERRS);
1560 inet_twsk_put(inet_twsk(sk)); 1557 inet_twsk_put(inet_twsk(sk));
1561 goto discard_it; 1558 goto bad_packet;
1559 }
1560 if (tcp_checksum_complete(skb)) {
1561 inet_twsk_put(inet_twsk(sk));
1562 goto csum_error;
1562 } 1563 }
1563 1564
1564 switch (tcp_timewait_state_process(inet_twsk(sk), skb, th)) { 1565 switch (tcp_timewait_state_process(inet_twsk(sk), skb, th)) {
diff --git a/net/ipv6/udp.c b/net/ipv6/udp.c
index da6019b63730..d4defdd44937 100644
--- a/net/ipv6/udp.c
+++ b/net/ipv6/udp.c
@@ -483,12 +483,17 @@ out:
483csum_copy_err: 483csum_copy_err:
484 slow = lock_sock_fast(sk); 484 slow = lock_sock_fast(sk);
485 if (!skb_kill_datagram(sk, skb, flags)) { 485 if (!skb_kill_datagram(sk, skb, flags)) {
486 if (is_udp4) 486 if (is_udp4) {
487 UDP_INC_STATS_USER(sock_net(sk),
488 UDP_MIB_CSUMERRORS, is_udplite);
487 UDP_INC_STATS_USER(sock_net(sk), 489 UDP_INC_STATS_USER(sock_net(sk),
488 UDP_MIB_INERRORS, is_udplite); 490 UDP_MIB_INERRORS, is_udplite);
489 else 491 } else {
492 UDP6_INC_STATS_USER(sock_net(sk),
493 UDP_MIB_CSUMERRORS, is_udplite);
490 UDP6_INC_STATS_USER(sock_net(sk), 494 UDP6_INC_STATS_USER(sock_net(sk),
491 UDP_MIB_INERRORS, is_udplite); 495 UDP_MIB_INERRORS, is_udplite);
496 }
492 } 497 }
493 unlock_sock_fast(sk, slow); 498 unlock_sock_fast(sk, slow);
494 499
@@ -637,7 +642,7 @@ int udpv6_queue_rcv_skb(struct sock *sk, struct sk_buff *skb)
637 642
638 if (rcu_access_pointer(sk->sk_filter)) { 643 if (rcu_access_pointer(sk->sk_filter)) {
639 if (udp_lib_checksum_complete(skb)) 644 if (udp_lib_checksum_complete(skb))
640 goto drop; 645 goto csum_error;
641 } 646 }
642 647
643 if (sk_rcvqueues_full(sk, skb, sk->sk_rcvbuf)) 648 if (sk_rcvqueues_full(sk, skb, sk->sk_rcvbuf))
@@ -656,6 +661,8 @@ int udpv6_queue_rcv_skb(struct sock *sk, struct sk_buff *skb)
656 bh_unlock_sock(sk); 661 bh_unlock_sock(sk);
657 662
658 return rc; 663 return rc;
664csum_error:
665 UDP6_INC_STATS_BH(sock_net(sk), UDP_MIB_CSUMERRORS, is_udplite);
659drop: 666drop:
660 UDP6_INC_STATS_BH(sock_net(sk), UDP_MIB_INERRORS, is_udplite); 667 UDP6_INC_STATS_BH(sock_net(sk), UDP_MIB_INERRORS, is_udplite);
661 atomic_inc(&sk->sk_drops); 668 atomic_inc(&sk->sk_drops);
@@ -817,7 +824,7 @@ int __udp6_lib_rcv(struct sk_buff *skb, struct udp_table *udptable,
817 } 824 }
818 825
819 if (udp6_csum_init(skb, uh, proto)) 826 if (udp6_csum_init(skb, uh, proto))
820 goto discard; 827 goto csum_error;
821 828
822 /* 829 /*
823 * Multicast receive code 830 * Multicast receive code
@@ -850,7 +857,7 @@ int __udp6_lib_rcv(struct sk_buff *skb, struct udp_table *udptable,
850 goto discard; 857 goto discard;
851 858
852 if (udp_lib_checksum_complete(skb)) 859 if (udp_lib_checksum_complete(skb))
853 goto discard; 860 goto csum_error;
854 861
855 UDP6_INC_STATS_BH(net, UDP_MIB_NOPORTS, proto == IPPROTO_UDPLITE); 862 UDP6_INC_STATS_BH(net, UDP_MIB_NOPORTS, proto == IPPROTO_UDPLITE);
856 icmpv6_send(skb, ICMPV6_DEST_UNREACH, ICMPV6_PORT_UNREACH, 0); 863 icmpv6_send(skb, ICMPV6_DEST_UNREACH, ICMPV6_PORT_UNREACH, 0);
@@ -867,7 +874,9 @@ short_packet:
867 skb->len, 874 skb->len,
868 daddr, 875 daddr,
869 ntohs(uh->dest)); 876 ntohs(uh->dest));
870 877 goto discard;
878csum_error:
879 UDP6_INC_STATS_BH(net, UDP_MIB_CSUMERRORS, proto == IPPROTO_UDPLITE);
871discard: 880discard:
872 UDP6_INC_STATS_BH(net, UDP_MIB_INERRORS, proto == IPPROTO_UDPLITE); 881 UDP6_INC_STATS_BH(net, UDP_MIB_INERRORS, proto == IPPROTO_UDPLITE);
873 kfree_skb(skb); 882 kfree_skb(skb);