diff options
-rw-r--r-- | include/net/icmp.h | 2 | ||||
-rw-r--r-- | net/dccp/ipv4.c | 4 | ||||
-rw-r--r-- | net/ipv4/icmp.c | 10 | ||||
-rw-r--r-- | net/ipv4/tcp_ipv4.c | 4 | ||||
-rw-r--r-- | net/ipv4/udp.c | 2 | ||||
-rw-r--r-- | net/sctp/input.c | 5 |
6 files changed, 14 insertions, 13 deletions
diff --git a/include/net/icmp.h b/include/net/icmp.h index c86fef8c45e5..e2ae6409ff80 100644 --- a/include/net/icmp.h +++ b/include/net/icmp.h | |||
@@ -32,7 +32,7 @@ extern struct icmp_err icmp_err_convert[]; | |||
32 | DECLARE_SNMP_STAT(struct icmp_mib, icmp_statistics); | 32 | DECLARE_SNMP_STAT(struct icmp_mib, icmp_statistics); |
33 | DECLARE_SNMP_STAT(struct icmpmsg_mib, icmpmsg_statistics); | 33 | DECLARE_SNMP_STAT(struct icmpmsg_mib, icmpmsg_statistics); |
34 | #define ICMP_INC_STATS(net, field) SNMP_INC_STATS(icmp_statistics, field) | 34 | #define ICMP_INC_STATS(net, field) SNMP_INC_STATS(icmp_statistics, field) |
35 | #define ICMP_INC_STATS_BH(field) SNMP_INC_STATS_BH(icmp_statistics, field) | 35 | #define ICMP_INC_STATS_BH(net, field) SNMP_INC_STATS_BH(icmp_statistics, field) |
36 | #define ICMPMSGOUT_INC_STATS(field) SNMP_INC_STATS(icmpmsg_statistics, field+256) | 36 | #define ICMPMSGOUT_INC_STATS(field) SNMP_INC_STATS(icmpmsg_statistics, field+256) |
37 | #define ICMPMSGIN_INC_STATS_BH(field) SNMP_INC_STATS_BH(icmpmsg_statistics, field) | 37 | #define ICMPMSGIN_INC_STATS_BH(field) SNMP_INC_STATS_BH(icmpmsg_statistics, field) |
38 | 38 | ||
diff --git a/net/dccp/ipv4.c b/net/dccp/ipv4.c index cc4f33461f2d..2b03c47cab1b 100644 --- a/net/dccp/ipv4.c +++ b/net/dccp/ipv4.c | |||
@@ -208,7 +208,7 @@ static void dccp_v4_err(struct sk_buff *skb, u32 info) | |||
208 | struct net *net = dev_net(skb->dev); | 208 | struct net *net = dev_net(skb->dev); |
209 | 209 | ||
210 | if (skb->len < (iph->ihl << 2) + 8) { | 210 | if (skb->len < (iph->ihl << 2) + 8) { |
211 | ICMP_INC_STATS_BH(ICMP_MIB_INERRORS); | 211 | ICMP_INC_STATS_BH(net, ICMP_MIB_INERRORS); |
212 | return; | 212 | return; |
213 | } | 213 | } |
214 | 214 | ||
@@ -216,7 +216,7 @@ static void dccp_v4_err(struct sk_buff *skb, u32 info) | |||
216 | iph->daddr, dh->dccph_dport, | 216 | iph->daddr, dh->dccph_dport, |
217 | iph->saddr, dh->dccph_sport, inet_iif(skb)); | 217 | iph->saddr, dh->dccph_sport, inet_iif(skb)); |
218 | if (sk == NULL) { | 218 | if (sk == NULL) { |
219 | ICMP_INC_STATS_BH(ICMP_MIB_INERRORS); | 219 | ICMP_INC_STATS_BH(net, ICMP_MIB_INERRORS); |
220 | return; | 220 | return; |
221 | } | 221 | } |
222 | 222 | ||
diff --git a/net/ipv4/icmp.c b/net/ipv4/icmp.c index e94de411cfa0..56a7bbc7950c 100644 --- a/net/ipv4/icmp.c +++ b/net/ipv4/icmp.c | |||
@@ -763,7 +763,7 @@ static void icmp_unreach(struct sk_buff *skb) | |||
763 | out: | 763 | out: |
764 | return; | 764 | return; |
765 | out_err: | 765 | out_err: |
766 | ICMP_INC_STATS_BH(ICMP_MIB_INERRORS); | 766 | ICMP_INC_STATS_BH(net, ICMP_MIB_INERRORS); |
767 | goto out; | 767 | goto out; |
768 | } | 768 | } |
769 | 769 | ||
@@ -803,7 +803,7 @@ static void icmp_redirect(struct sk_buff *skb) | |||
803 | out: | 803 | out: |
804 | return; | 804 | return; |
805 | out_err: | 805 | out_err: |
806 | ICMP_INC_STATS_BH(ICMP_MIB_INERRORS); | 806 | ICMP_INC_STATS_BH(dev_net(skb->dev), ICMP_MIB_INERRORS); |
807 | goto out; | 807 | goto out; |
808 | } | 808 | } |
809 | 809 | ||
@@ -874,7 +874,7 @@ static void icmp_timestamp(struct sk_buff *skb) | |||
874 | out: | 874 | out: |
875 | return; | 875 | return; |
876 | out_err: | 876 | out_err: |
877 | ICMP_INC_STATS_BH(ICMP_MIB_INERRORS); | 877 | ICMP_INC_STATS_BH(dev_net(skb->dst->dev), ICMP_MIB_INERRORS); |
878 | goto out; | 878 | goto out; |
879 | } | 879 | } |
880 | 880 | ||
@@ -994,7 +994,7 @@ int icmp_rcv(struct sk_buff *skb) | |||
994 | skb_set_network_header(skb, nh); | 994 | skb_set_network_header(skb, nh); |
995 | } | 995 | } |
996 | 996 | ||
997 | ICMP_INC_STATS_BH(ICMP_MIB_INMSGS); | 997 | ICMP_INC_STATS_BH(net, ICMP_MIB_INMSGS); |
998 | 998 | ||
999 | switch (skb->ip_summed) { | 999 | switch (skb->ip_summed) { |
1000 | case CHECKSUM_COMPLETE: | 1000 | case CHECKSUM_COMPLETE: |
@@ -1053,7 +1053,7 @@ drop: | |||
1053 | kfree_skb(skb); | 1053 | kfree_skb(skb); |
1054 | return 0; | 1054 | return 0; |
1055 | error: | 1055 | error: |
1056 | ICMP_INC_STATS_BH(ICMP_MIB_INERRORS); | 1056 | ICMP_INC_STATS_BH(net, ICMP_MIB_INERRORS); |
1057 | goto drop; | 1057 | goto drop; |
1058 | } | 1058 | } |
1059 | 1059 | ||
diff --git a/net/ipv4/tcp_ipv4.c b/net/ipv4/tcp_ipv4.c index ca41b77f3f32..0fefd4409413 100644 --- a/net/ipv4/tcp_ipv4.c +++ b/net/ipv4/tcp_ipv4.c | |||
@@ -346,14 +346,14 @@ void tcp_v4_err(struct sk_buff *skb, u32 info) | |||
346 | struct net *net = dev_net(skb->dev); | 346 | struct net *net = dev_net(skb->dev); |
347 | 347 | ||
348 | if (skb->len < (iph->ihl << 2) + 8) { | 348 | if (skb->len < (iph->ihl << 2) + 8) { |
349 | ICMP_INC_STATS_BH(ICMP_MIB_INERRORS); | 349 | ICMP_INC_STATS_BH(net, ICMP_MIB_INERRORS); |
350 | return; | 350 | return; |
351 | } | 351 | } |
352 | 352 | ||
353 | sk = inet_lookup(net, &tcp_hashinfo, iph->daddr, th->dest, | 353 | sk = inet_lookup(net, &tcp_hashinfo, iph->daddr, th->dest, |
354 | iph->saddr, th->source, inet_iif(skb)); | 354 | iph->saddr, th->source, inet_iif(skb)); |
355 | if (!sk) { | 355 | if (!sk) { |
356 | ICMP_INC_STATS_BH(ICMP_MIB_INERRORS); | 356 | ICMP_INC_STATS_BH(net, ICMP_MIB_INERRORS); |
357 | return; | 357 | return; |
358 | } | 358 | } |
359 | if (sk->sk_state == TCP_TIME_WAIT) { | 359 | if (sk->sk_state == TCP_TIME_WAIT) { |
diff --git a/net/ipv4/udp.c b/net/ipv4/udp.c index 9342cfda3d0a..fdd4faa1f120 100644 --- a/net/ipv4/udp.c +++ b/net/ipv4/udp.c | |||
@@ -359,7 +359,7 @@ void __udp4_lib_err(struct sk_buff *skb, u32 info, struct hlist_head udptable[]) | |||
359 | sk = __udp4_lib_lookup(net, iph->daddr, uh->dest, | 359 | sk = __udp4_lib_lookup(net, iph->daddr, uh->dest, |
360 | iph->saddr, uh->source, skb->dev->ifindex, udptable); | 360 | iph->saddr, uh->source, skb->dev->ifindex, udptable); |
361 | if (sk == NULL) { | 361 | if (sk == NULL) { |
362 | ICMP_INC_STATS_BH(ICMP_MIB_INERRORS); | 362 | ICMP_INC_STATS_BH(net, ICMP_MIB_INERRORS); |
363 | return; /* No socket for error */ | 363 | return; /* No socket for error */ |
364 | } | 364 | } |
365 | 365 | ||
diff --git a/net/sctp/input.c b/net/sctp/input.c index d354a23972d4..ed8834e7f143 100644 --- a/net/sctp/input.c +++ b/net/sctp/input.c | |||
@@ -61,6 +61,7 @@ | |||
61 | #include <net/sctp/sctp.h> | 61 | #include <net/sctp/sctp.h> |
62 | #include <net/sctp/sm.h> | 62 | #include <net/sctp/sm.h> |
63 | #include <net/sctp/checksum.h> | 63 | #include <net/sctp/checksum.h> |
64 | #include <net/net_namespace.h> | ||
64 | 65 | ||
65 | /* Forward declarations for internal helpers. */ | 66 | /* Forward declarations for internal helpers. */ |
66 | static int sctp_rcv_ootb(struct sk_buff *); | 67 | static int sctp_rcv_ootb(struct sk_buff *); |
@@ -534,7 +535,7 @@ void sctp_v4_err(struct sk_buff *skb, __u32 info) | |||
534 | int err; | 535 | int err; |
535 | 536 | ||
536 | if (skb->len < ihlen + 8) { | 537 | if (skb->len < ihlen + 8) { |
537 | ICMP_INC_STATS_BH(ICMP_MIB_INERRORS); | 538 | ICMP_INC_STATS_BH(&init_net, ICMP_MIB_INERRORS); |
538 | return; | 539 | return; |
539 | } | 540 | } |
540 | 541 | ||
@@ -548,7 +549,7 @@ void sctp_v4_err(struct sk_buff *skb, __u32 info) | |||
548 | skb->network_header = saveip; | 549 | skb->network_header = saveip; |
549 | skb->transport_header = savesctp; | 550 | skb->transport_header = savesctp; |
550 | if (!sk) { | 551 | if (!sk) { |
551 | ICMP_INC_STATS_BH(ICMP_MIB_INERRORS); | 552 | ICMP_INC_STATS_BH(&init_net, ICMP_MIB_INERRORS); |
552 | return; | 553 | return; |
553 | } | 554 | } |
554 | /* Warning: The sock lock is held. Remember to call | 555 | /* Warning: The sock lock is held. Remember to call |