ipv6: rename IP6_INC_STATS_BH()
Rename IP6_INC_STATS_BH() to __IP6_INC_STATS() and IP6_ADD_STATS_BH() to __IP6_ADD_STATS() Signed-off-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
02a1d6e7a6
commit
1d01550359
|
@ -167,11 +167,11 @@ extern int sysctl_mld_qrv;
|
||||||
|
|
||||||
#define IP6_INC_STATS(net, idev,field) \
|
#define IP6_INC_STATS(net, idev,field) \
|
||||||
_DEVINC(net, ipv6, 64, idev, field)
|
_DEVINC(net, ipv6, 64, idev, field)
|
||||||
#define IP6_INC_STATS_BH(net, idev,field) \
|
#define __IP6_INC_STATS(net, idev,field) \
|
||||||
_DEVINC(net, ipv6, 64_BH, idev, field)
|
_DEVINC(net, ipv6, 64_BH, idev, field)
|
||||||
#define IP6_ADD_STATS(net, idev,field,val) \
|
#define IP6_ADD_STATS(net, idev,field,val) \
|
||||||
_DEVADD(net, ipv6, 64, idev, field, val)
|
_DEVADD(net, ipv6, 64, idev, field, val)
|
||||||
#define IP6_ADD_STATS_BH(net, idev,field,val) \
|
#define __IP6_ADD_STATS(net, idev,field,val) \
|
||||||
_DEVADD(net, ipv6, 64_BH, idev, field, val)
|
_DEVADD(net, ipv6, 64_BH, idev, field, val)
|
||||||
#define IP6_UPD_PO_STATS(net, idev,field,val) \
|
#define IP6_UPD_PO_STATS(net, idev,field,val) \
|
||||||
_DEVUPD(net, ipv6, 64, idev, field, val)
|
_DEVUPD(net, ipv6, 64, idev, field, val)
|
||||||
|
|
|
@ -122,13 +122,13 @@ int br_validate_ipv6(struct net *net, struct sk_buff *skb)
|
||||||
|
|
||||||
if (pkt_len || hdr->nexthdr != NEXTHDR_HOP) {
|
if (pkt_len || hdr->nexthdr != NEXTHDR_HOP) {
|
||||||
if (pkt_len + ip6h_len > skb->len) {
|
if (pkt_len + ip6h_len > skb->len) {
|
||||||
IP6_INC_STATS_BH(net, idev,
|
__IP6_INC_STATS(net, idev,
|
||||||
IPSTATS_MIB_INTRUNCATEDPKTS);
|
IPSTATS_MIB_INTRUNCATEDPKTS);
|
||||||
goto drop;
|
goto drop;
|
||||||
}
|
}
|
||||||
if (pskb_trim_rcsum(skb, pkt_len + ip6h_len)) {
|
if (pskb_trim_rcsum(skb, pkt_len + ip6h_len)) {
|
||||||
IP6_INC_STATS_BH(net, idev,
|
__IP6_INC_STATS(net, idev,
|
||||||
IPSTATS_MIB_INDISCARDS);
|
IPSTATS_MIB_INDISCARDS);
|
||||||
goto drop;
|
goto drop;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -142,7 +142,7 @@ int br_validate_ipv6(struct net *net, struct sk_buff *skb)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
inhdr_error:
|
inhdr_error:
|
||||||
IP6_INC_STATS_BH(net, idev, IPSTATS_MIB_INHDRERRORS);
|
__IP6_INC_STATS(net, idev, IPSTATS_MIB_INHDRERRORS);
|
||||||
drop:
|
drop:
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -258,8 +258,8 @@ static int ipv6_destopt_rcv(struct sk_buff *skb)
|
||||||
if (!pskb_may_pull(skb, skb_transport_offset(skb) + 8) ||
|
if (!pskb_may_pull(skb, skb_transport_offset(skb) + 8) ||
|
||||||
!pskb_may_pull(skb, (skb_transport_offset(skb) +
|
!pskb_may_pull(skb, (skb_transport_offset(skb) +
|
||||||
((skb_transport_header(skb)[1] + 1) << 3)))) {
|
((skb_transport_header(skb)[1] + 1) << 3)))) {
|
||||||
IP6_INC_STATS_BH(dev_net(dst->dev), ip6_dst_idev(dst),
|
__IP6_INC_STATS(dev_net(dst->dev), ip6_dst_idev(dst),
|
||||||
IPSTATS_MIB_INHDRERRORS);
|
IPSTATS_MIB_INHDRERRORS);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -280,8 +280,8 @@ static int ipv6_destopt_rcv(struct sk_buff *skb)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
IP6_INC_STATS_BH(dev_net(dst->dev),
|
__IP6_INC_STATS(dev_net(dst->dev),
|
||||||
ip6_dst_idev(dst), IPSTATS_MIB_INHDRERRORS);
|
ip6_dst_idev(dst), IPSTATS_MIB_INHDRERRORS);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -309,8 +309,8 @@ static int ipv6_rthdr_rcv(struct sk_buff *skb)
|
||||||
if (!pskb_may_pull(skb, skb_transport_offset(skb) + 8) ||
|
if (!pskb_may_pull(skb, skb_transport_offset(skb) + 8) ||
|
||||||
!pskb_may_pull(skb, (skb_transport_offset(skb) +
|
!pskb_may_pull(skb, (skb_transport_offset(skb) +
|
||||||
((skb_transport_header(skb)[1] + 1) << 3)))) {
|
((skb_transport_header(skb)[1] + 1) << 3)))) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_INHDRERRORS);
|
IPSTATS_MIB_INHDRERRORS);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -319,8 +319,8 @@ static int ipv6_rthdr_rcv(struct sk_buff *skb)
|
||||||
|
|
||||||
if (ipv6_addr_is_multicast(&ipv6_hdr(skb)->daddr) ||
|
if (ipv6_addr_is_multicast(&ipv6_hdr(skb)->daddr) ||
|
||||||
skb->pkt_type != PACKET_HOST) {
|
skb->pkt_type != PACKET_HOST) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_INADDRERRORS);
|
IPSTATS_MIB_INADDRERRORS);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -334,8 +334,8 @@ static int ipv6_rthdr_rcv(struct sk_buff *skb)
|
||||||
* processed by own
|
* processed by own
|
||||||
*/
|
*/
|
||||||
if (!addr) {
|
if (!addr) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_INADDRERRORS);
|
IPSTATS_MIB_INADDRERRORS);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -360,8 +360,8 @@ static int ipv6_rthdr_rcv(struct sk_buff *skb)
|
||||||
goto unknown_rh;
|
goto unknown_rh;
|
||||||
/* Silently discard invalid RTH type 2 */
|
/* Silently discard invalid RTH type 2 */
|
||||||
if (hdr->hdrlen != 2 || hdr->segments_left != 1) {
|
if (hdr->hdrlen != 2 || hdr->segments_left != 1) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_INHDRERRORS);
|
IPSTATS_MIB_INHDRERRORS);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -379,8 +379,8 @@ static int ipv6_rthdr_rcv(struct sk_buff *skb)
|
||||||
n = hdr->hdrlen >> 1;
|
n = hdr->hdrlen >> 1;
|
||||||
|
|
||||||
if (hdr->segments_left > n) {
|
if (hdr->segments_left > n) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_INHDRERRORS);
|
IPSTATS_MIB_INHDRERRORS);
|
||||||
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD,
|
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD,
|
||||||
((&hdr->segments_left) -
|
((&hdr->segments_left) -
|
||||||
skb_network_header(skb)));
|
skb_network_header(skb)));
|
||||||
|
@ -393,8 +393,8 @@ static int ipv6_rthdr_rcv(struct sk_buff *skb)
|
||||||
if (skb_cloned(skb)) {
|
if (skb_cloned(skb)) {
|
||||||
/* the copy is a forwarded packet */
|
/* the copy is a forwarded packet */
|
||||||
if (pskb_expand_head(skb, 0, 0, GFP_ATOMIC)) {
|
if (pskb_expand_head(skb, 0, 0, GFP_ATOMIC)) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_OUTDISCARDS);
|
IPSTATS_MIB_OUTDISCARDS);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -416,14 +416,14 @@ static int ipv6_rthdr_rcv(struct sk_buff *skb)
|
||||||
if (xfrm6_input_addr(skb, (xfrm_address_t *)addr,
|
if (xfrm6_input_addr(skb, (xfrm_address_t *)addr,
|
||||||
(xfrm_address_t *)&ipv6_hdr(skb)->saddr,
|
(xfrm_address_t *)&ipv6_hdr(skb)->saddr,
|
||||||
IPPROTO_ROUTING) < 0) {
|
IPPROTO_ROUTING) < 0) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_INADDRERRORS);
|
IPSTATS_MIB_INADDRERRORS);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (!ipv6_chk_home_addr(dev_net(skb_dst(skb)->dev), addr)) {
|
if (!ipv6_chk_home_addr(dev_net(skb_dst(skb)->dev), addr)) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_INADDRERRORS);
|
IPSTATS_MIB_INADDRERRORS);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -434,8 +434,8 @@ static int ipv6_rthdr_rcv(struct sk_buff *skb)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ipv6_addr_is_multicast(addr)) {
|
if (ipv6_addr_is_multicast(addr)) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_INADDRERRORS);
|
IPSTATS_MIB_INADDRERRORS);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -454,8 +454,8 @@ static int ipv6_rthdr_rcv(struct sk_buff *skb)
|
||||||
|
|
||||||
if (skb_dst(skb)->dev->flags&IFF_LOOPBACK) {
|
if (skb_dst(skb)->dev->flags&IFF_LOOPBACK) {
|
||||||
if (ipv6_hdr(skb)->hop_limit <= 1) {
|
if (ipv6_hdr(skb)->hop_limit <= 1) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_INHDRERRORS);
|
IPSTATS_MIB_INHDRERRORS);
|
||||||
icmpv6_send(skb, ICMPV6_TIME_EXCEED, ICMPV6_EXC_HOPLIMIT,
|
icmpv6_send(skb, ICMPV6_TIME_EXCEED, ICMPV6_EXC_HOPLIMIT,
|
||||||
0);
|
0);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
|
@ -470,7 +470,7 @@ static int ipv6_rthdr_rcv(struct sk_buff *skb)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
unknown_rh:
|
unknown_rh:
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)), IPSTATS_MIB_INHDRERRORS);
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)), IPSTATS_MIB_INHDRERRORS);
|
||||||
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD,
|
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD,
|
||||||
(&hdr->type) - skb_network_header(skb));
|
(&hdr->type) - skb_network_header(skb));
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -568,28 +568,28 @@ static bool ipv6_hop_jumbo(struct sk_buff *skb, int optoff)
|
||||||
if (nh[optoff + 1] != 4 || (optoff & 3) != 2) {
|
if (nh[optoff + 1] != 4 || (optoff & 3) != 2) {
|
||||||
net_dbg_ratelimited("ipv6_hop_jumbo: wrong jumbo opt length/alignment %d\n",
|
net_dbg_ratelimited("ipv6_hop_jumbo: wrong jumbo opt length/alignment %d\n",
|
||||||
nh[optoff+1]);
|
nh[optoff+1]);
|
||||||
IP6_INC_STATS_BH(net, ipv6_skb_idev(skb),
|
__IP6_INC_STATS(net, ipv6_skb_idev(skb),
|
||||||
IPSTATS_MIB_INHDRERRORS);
|
IPSTATS_MIB_INHDRERRORS);
|
||||||
goto drop;
|
goto drop;
|
||||||
}
|
}
|
||||||
|
|
||||||
pkt_len = ntohl(*(__be32 *)(nh + optoff + 2));
|
pkt_len = ntohl(*(__be32 *)(nh + optoff + 2));
|
||||||
if (pkt_len <= IPV6_MAXPLEN) {
|
if (pkt_len <= IPV6_MAXPLEN) {
|
||||||
IP6_INC_STATS_BH(net, ipv6_skb_idev(skb),
|
__IP6_INC_STATS(net, ipv6_skb_idev(skb),
|
||||||
IPSTATS_MIB_INHDRERRORS);
|
IPSTATS_MIB_INHDRERRORS);
|
||||||
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD, optoff+2);
|
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD, optoff+2);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (ipv6_hdr(skb)->payload_len) {
|
if (ipv6_hdr(skb)->payload_len) {
|
||||||
IP6_INC_STATS_BH(net, ipv6_skb_idev(skb),
|
__IP6_INC_STATS(net, ipv6_skb_idev(skb),
|
||||||
IPSTATS_MIB_INHDRERRORS);
|
IPSTATS_MIB_INHDRERRORS);
|
||||||
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD, optoff);
|
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD, optoff);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pkt_len > skb->len - sizeof(struct ipv6hdr)) {
|
if (pkt_len > skb->len - sizeof(struct ipv6hdr)) {
|
||||||
IP6_INC_STATS_BH(net, ipv6_skb_idev(skb),
|
__IP6_INC_STATS(net, ipv6_skb_idev(skb),
|
||||||
IPSTATS_MIB_INTRUNCATEDPKTS);
|
IPSTATS_MIB_INTRUNCATEDPKTS);
|
||||||
goto drop;
|
goto drop;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -82,7 +82,7 @@ int ipv6_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt
|
||||||
|
|
||||||
if ((skb = skb_share_check(skb, GFP_ATOMIC)) == NULL ||
|
if ((skb = skb_share_check(skb, GFP_ATOMIC)) == NULL ||
|
||||||
!idev || unlikely(idev->cnf.disable_ipv6)) {
|
!idev || unlikely(idev->cnf.disable_ipv6)) {
|
||||||
IP6_INC_STATS_BH(net, idev, IPSTATS_MIB_INDISCARDS);
|
__IP6_INC_STATS(net, idev, IPSTATS_MIB_INDISCARDS);
|
||||||
goto drop;
|
goto drop;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -109,10 +109,10 @@ int ipv6_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt
|
||||||
if (hdr->version != 6)
|
if (hdr->version != 6)
|
||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
IP6_ADD_STATS_BH(net, idev,
|
__IP6_ADD_STATS(net, idev,
|
||||||
IPSTATS_MIB_NOECTPKTS +
|
IPSTATS_MIB_NOECTPKTS +
|
||||||
(ipv6_get_dsfield(hdr) & INET_ECN_MASK),
|
(ipv6_get_dsfield(hdr) & INET_ECN_MASK),
|
||||||
max_t(unsigned short, 1, skb_shinfo(skb)->gso_segs));
|
max_t(unsigned short, 1, skb_shinfo(skb)->gso_segs));
|
||||||
/*
|
/*
|
||||||
* RFC4291 2.5.3
|
* RFC4291 2.5.3
|
||||||
* A packet received on an interface with a destination address
|
* A packet received on an interface with a destination address
|
||||||
|
@ -169,12 +169,12 @@ int ipv6_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt
|
||||||
/* pkt_len may be zero if Jumbo payload option is present */
|
/* pkt_len may be zero if Jumbo payload option is present */
|
||||||
if (pkt_len || hdr->nexthdr != NEXTHDR_HOP) {
|
if (pkt_len || hdr->nexthdr != NEXTHDR_HOP) {
|
||||||
if (pkt_len + sizeof(struct ipv6hdr) > skb->len) {
|
if (pkt_len + sizeof(struct ipv6hdr) > skb->len) {
|
||||||
IP6_INC_STATS_BH(net,
|
__IP6_INC_STATS(net,
|
||||||
idev, IPSTATS_MIB_INTRUNCATEDPKTS);
|
idev, IPSTATS_MIB_INTRUNCATEDPKTS);
|
||||||
goto drop;
|
goto drop;
|
||||||
}
|
}
|
||||||
if (pskb_trim_rcsum(skb, pkt_len + sizeof(struct ipv6hdr))) {
|
if (pskb_trim_rcsum(skb, pkt_len + sizeof(struct ipv6hdr))) {
|
||||||
IP6_INC_STATS_BH(net, idev, IPSTATS_MIB_INHDRERRORS);
|
__IP6_INC_STATS(net, idev, IPSTATS_MIB_INHDRERRORS);
|
||||||
goto drop;
|
goto drop;
|
||||||
}
|
}
|
||||||
hdr = ipv6_hdr(skb);
|
hdr = ipv6_hdr(skb);
|
||||||
|
@ -182,7 +182,7 @@ int ipv6_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt
|
||||||
|
|
||||||
if (hdr->nexthdr == NEXTHDR_HOP) {
|
if (hdr->nexthdr == NEXTHDR_HOP) {
|
||||||
if (ipv6_parse_hopopts(skb) < 0) {
|
if (ipv6_parse_hopopts(skb) < 0) {
|
||||||
IP6_INC_STATS_BH(net, idev, IPSTATS_MIB_INHDRERRORS);
|
__IP6_INC_STATS(net, idev, IPSTATS_MIB_INHDRERRORS);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
return NET_RX_DROP;
|
return NET_RX_DROP;
|
||||||
}
|
}
|
||||||
|
@ -197,7 +197,7 @@ int ipv6_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt
|
||||||
net, NULL, skb, dev, NULL,
|
net, NULL, skb, dev, NULL,
|
||||||
ip6_rcv_finish);
|
ip6_rcv_finish);
|
||||||
err:
|
err:
|
||||||
IP6_INC_STATS_BH(net, idev, IPSTATS_MIB_INHDRERRORS);
|
__IP6_INC_STATS(net, idev, IPSTATS_MIB_INHDRERRORS);
|
||||||
drop:
|
drop:
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
|
@ -259,18 +259,18 @@ static int ip6_input_finish(struct net *net, struct sock *sk, struct sk_buff *sk
|
||||||
if (ret > 0)
|
if (ret > 0)
|
||||||
goto resubmit;
|
goto resubmit;
|
||||||
else if (ret == 0)
|
else if (ret == 0)
|
||||||
IP6_INC_STATS_BH(net, idev, IPSTATS_MIB_INDELIVERS);
|
__IP6_INC_STATS(net, idev, IPSTATS_MIB_INDELIVERS);
|
||||||
} else {
|
} else {
|
||||||
if (!raw) {
|
if (!raw) {
|
||||||
if (xfrm6_policy_check(NULL, XFRM_POLICY_IN, skb)) {
|
if (xfrm6_policy_check(NULL, XFRM_POLICY_IN, skb)) {
|
||||||
IP6_INC_STATS_BH(net, idev,
|
__IP6_INC_STATS(net, idev,
|
||||||
IPSTATS_MIB_INUNKNOWNPROTOS);
|
IPSTATS_MIB_INUNKNOWNPROTOS);
|
||||||
icmpv6_send(skb, ICMPV6_PARAMPROB,
|
icmpv6_send(skb, ICMPV6_PARAMPROB,
|
||||||
ICMPV6_UNK_NEXTHDR, nhoff);
|
ICMPV6_UNK_NEXTHDR, nhoff);
|
||||||
}
|
}
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
} else {
|
} else {
|
||||||
IP6_INC_STATS_BH(net, idev, IPSTATS_MIB_INDELIVERS);
|
__IP6_INC_STATS(net, idev, IPSTATS_MIB_INDELIVERS);
|
||||||
consume_skb(skb);
|
consume_skb(skb);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -278,7 +278,7 @@ static int ip6_input_finish(struct net *net, struct sock *sk, struct sk_buff *sk
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
discard:
|
discard:
|
||||||
IP6_INC_STATS_BH(net, idev, IPSTATS_MIB_INDISCARDS);
|
__IP6_INC_STATS(net, idev, IPSTATS_MIB_INDISCARDS);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -395,8 +395,8 @@ int ip6_forward(struct sk_buff *skb)
|
||||||
goto drop;
|
goto drop;
|
||||||
|
|
||||||
if (!xfrm6_policy_check(NULL, XFRM_POLICY_FWD, skb)) {
|
if (!xfrm6_policy_check(NULL, XFRM_POLICY_FWD, skb)) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(dst),
|
__IP6_INC_STATS(net, ip6_dst_idev(dst),
|
||||||
IPSTATS_MIB_INDISCARDS);
|
IPSTATS_MIB_INDISCARDS);
|
||||||
goto drop;
|
goto drop;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -427,8 +427,8 @@ int ip6_forward(struct sk_buff *skb)
|
||||||
/* Force OUTPUT device used as source address */
|
/* Force OUTPUT device used as source address */
|
||||||
skb->dev = dst->dev;
|
skb->dev = dst->dev;
|
||||||
icmpv6_send(skb, ICMPV6_TIME_EXCEED, ICMPV6_EXC_HOPLIMIT, 0);
|
icmpv6_send(skb, ICMPV6_TIME_EXCEED, ICMPV6_EXC_HOPLIMIT, 0);
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(dst),
|
__IP6_INC_STATS(net, ip6_dst_idev(dst),
|
||||||
IPSTATS_MIB_INHDRERRORS);
|
IPSTATS_MIB_INHDRERRORS);
|
||||||
|
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -ETIMEDOUT;
|
return -ETIMEDOUT;
|
||||||
|
@ -441,15 +441,15 @@ int ip6_forward(struct sk_buff *skb)
|
||||||
if (proxied > 0)
|
if (proxied > 0)
|
||||||
return ip6_input(skb);
|
return ip6_input(skb);
|
||||||
else if (proxied < 0) {
|
else if (proxied < 0) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(dst),
|
__IP6_INC_STATS(net, ip6_dst_idev(dst),
|
||||||
IPSTATS_MIB_INDISCARDS);
|
IPSTATS_MIB_INDISCARDS);
|
||||||
goto drop;
|
goto drop;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!xfrm6_route_forward(skb)) {
|
if (!xfrm6_route_forward(skb)) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(dst),
|
__IP6_INC_STATS(net, ip6_dst_idev(dst),
|
||||||
IPSTATS_MIB_INDISCARDS);
|
IPSTATS_MIB_INDISCARDS);
|
||||||
goto drop;
|
goto drop;
|
||||||
}
|
}
|
||||||
dst = skb_dst(skb);
|
dst = skb_dst(skb);
|
||||||
|
@ -505,17 +505,17 @@ int ip6_forward(struct sk_buff *skb)
|
||||||
/* Again, force OUTPUT device used as source address */
|
/* Again, force OUTPUT device used as source address */
|
||||||
skb->dev = dst->dev;
|
skb->dev = dst->dev;
|
||||||
icmpv6_send(skb, ICMPV6_PKT_TOOBIG, 0, mtu);
|
icmpv6_send(skb, ICMPV6_PKT_TOOBIG, 0, mtu);
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(dst),
|
__IP6_INC_STATS(net, ip6_dst_idev(dst),
|
||||||
IPSTATS_MIB_INTOOBIGERRORS);
|
IPSTATS_MIB_INTOOBIGERRORS);
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(dst),
|
__IP6_INC_STATS(net, ip6_dst_idev(dst),
|
||||||
IPSTATS_MIB_FRAGFAILS);
|
IPSTATS_MIB_FRAGFAILS);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (skb_cow(skb, dst->dev->hard_header_len)) {
|
if (skb_cow(skb, dst->dev->hard_header_len)) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(dst),
|
__IP6_INC_STATS(net, ip6_dst_idev(dst),
|
||||||
IPSTATS_MIB_OUTDISCARDS);
|
IPSTATS_MIB_OUTDISCARDS);
|
||||||
goto drop;
|
goto drop;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -525,14 +525,14 @@ int ip6_forward(struct sk_buff *skb)
|
||||||
|
|
||||||
hdr->hop_limit--;
|
hdr->hop_limit--;
|
||||||
|
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(dst), IPSTATS_MIB_OUTFORWDATAGRAMS);
|
__IP6_INC_STATS(net, ip6_dst_idev(dst), IPSTATS_MIB_OUTFORWDATAGRAMS);
|
||||||
IP6_ADD_STATS_BH(net, ip6_dst_idev(dst), IPSTATS_MIB_OUTOCTETS, skb->len);
|
__IP6_ADD_STATS(net, ip6_dst_idev(dst), IPSTATS_MIB_OUTOCTETS, skb->len);
|
||||||
return NF_HOOK(NFPROTO_IPV6, NF_INET_FORWARD,
|
return NF_HOOK(NFPROTO_IPV6, NF_INET_FORWARD,
|
||||||
net, NULL, skb, skb->dev, dst->dev,
|
net, NULL, skb, skb->dev, dst->dev,
|
||||||
ip6_forward_finish);
|
ip6_forward_finish);
|
||||||
|
|
||||||
error:
|
error:
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(dst), IPSTATS_MIB_INADDRERRORS);
|
__IP6_INC_STATS(net, ip6_dst_idev(dst), IPSTATS_MIB_INADDRERRORS);
|
||||||
drop:
|
drop:
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
|
@ -1984,10 +1984,10 @@ int ip6mr_compat_ioctl(struct sock *sk, unsigned int cmd, void __user *arg)
|
||||||
|
|
||||||
static inline int ip6mr_forward2_finish(struct net *net, struct sock *sk, struct sk_buff *skb)
|
static inline int ip6mr_forward2_finish(struct net *net, struct sock *sk, struct sk_buff *skb)
|
||||||
{
|
{
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_OUTFORWDATAGRAMS);
|
IPSTATS_MIB_OUTFORWDATAGRAMS);
|
||||||
IP6_ADD_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_ADD_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_OUTOCTETS, skb->len);
|
IPSTATS_MIB_OUTOCTETS, skb->len);
|
||||||
return dst_output(net, sk, skb);
|
return dst_output(net, sk, skb);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -145,12 +145,12 @@ void ip6_expire_frag_queue(struct net *net, struct frag_queue *fq,
|
||||||
if (!dev)
|
if (!dev)
|
||||||
goto out_rcu_unlock;
|
goto out_rcu_unlock;
|
||||||
|
|
||||||
IP6_INC_STATS_BH(net, __in6_dev_get(dev), IPSTATS_MIB_REASMFAILS);
|
__IP6_INC_STATS(net, __in6_dev_get(dev), IPSTATS_MIB_REASMFAILS);
|
||||||
|
|
||||||
if (inet_frag_evicting(&fq->q))
|
if (inet_frag_evicting(&fq->q))
|
||||||
goto out_rcu_unlock;
|
goto out_rcu_unlock;
|
||||||
|
|
||||||
IP6_INC_STATS_BH(net, __in6_dev_get(dev), IPSTATS_MIB_REASMTIMEOUT);
|
__IP6_INC_STATS(net, __in6_dev_get(dev), IPSTATS_MIB_REASMTIMEOUT);
|
||||||
|
|
||||||
/* Don't send error if the first segment did not arrive. */
|
/* Don't send error if the first segment did not arrive. */
|
||||||
if (!(fq->q.flags & INET_FRAG_FIRST_IN) || !fq->q.fragments)
|
if (!(fq->q.flags & INET_FRAG_FIRST_IN) || !fq->q.fragments)
|
||||||
|
@ -223,8 +223,8 @@ static int ip6_frag_queue(struct frag_queue *fq, struct sk_buff *skb,
|
||||||
((u8 *)(fhdr + 1) - (u8 *)(ipv6_hdr(skb) + 1)));
|
((u8 *)(fhdr + 1) - (u8 *)(ipv6_hdr(skb) + 1)));
|
||||||
|
|
||||||
if ((unsigned int)end > IPV6_MAXPLEN) {
|
if ((unsigned int)end > IPV6_MAXPLEN) {
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_INHDRERRORS);
|
IPSTATS_MIB_INHDRERRORS);
|
||||||
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD,
|
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD,
|
||||||
((u8 *)&fhdr->frag_off -
|
((u8 *)&fhdr->frag_off -
|
||||||
skb_network_header(skb)));
|
skb_network_header(skb)));
|
||||||
|
@ -258,8 +258,8 @@ static int ip6_frag_queue(struct frag_queue *fq, struct sk_buff *skb,
|
||||||
/* RFC2460 says always send parameter problem in
|
/* RFC2460 says always send parameter problem in
|
||||||
* this case. -DaveM
|
* this case. -DaveM
|
||||||
*/
|
*/
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_INHDRERRORS);
|
IPSTATS_MIB_INHDRERRORS);
|
||||||
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD,
|
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD,
|
||||||
offsetof(struct ipv6hdr, payload_len));
|
offsetof(struct ipv6hdr, payload_len));
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -361,8 +361,8 @@ static int ip6_frag_queue(struct frag_queue *fq, struct sk_buff *skb,
|
||||||
discard_fq:
|
discard_fq:
|
||||||
inet_frag_kill(&fq->q, &ip6_frags);
|
inet_frag_kill(&fq->q, &ip6_frags);
|
||||||
err:
|
err:
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_REASMFAILS);
|
IPSTATS_MIB_REASMFAILS);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -500,7 +500,7 @@ static int ip6_frag_reasm(struct frag_queue *fq, struct sk_buff *prev,
|
||||||
skb_network_header_len(head));
|
skb_network_header_len(head));
|
||||||
|
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
IP6_INC_STATS_BH(net, __in6_dev_get(dev), IPSTATS_MIB_REASMOKS);
|
__IP6_INC_STATS(net, __in6_dev_get(dev), IPSTATS_MIB_REASMOKS);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
fq->q.fragments = NULL;
|
fq->q.fragments = NULL;
|
||||||
fq->q.fragments_tail = NULL;
|
fq->q.fragments_tail = NULL;
|
||||||
|
@ -513,7 +513,7 @@ static int ip6_frag_reasm(struct frag_queue *fq, struct sk_buff *prev,
|
||||||
net_dbg_ratelimited("ip6_frag_reasm: no memory for reassembly\n");
|
net_dbg_ratelimited("ip6_frag_reasm: no memory for reassembly\n");
|
||||||
out_fail:
|
out_fail:
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
IP6_INC_STATS_BH(net, __in6_dev_get(dev), IPSTATS_MIB_REASMFAILS);
|
__IP6_INC_STATS(net, __in6_dev_get(dev), IPSTATS_MIB_REASMFAILS);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -528,7 +528,7 @@ static int ipv6_frag_rcv(struct sk_buff *skb)
|
||||||
if (IP6CB(skb)->flags & IP6SKB_FRAGMENTED)
|
if (IP6CB(skb)->flags & IP6SKB_FRAGMENTED)
|
||||||
goto fail_hdr;
|
goto fail_hdr;
|
||||||
|
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)), IPSTATS_MIB_REASMREQDS);
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)), IPSTATS_MIB_REASMREQDS);
|
||||||
|
|
||||||
/* Jumbo payload inhibits frag. header */
|
/* Jumbo payload inhibits frag. header */
|
||||||
if (hdr->payload_len == 0)
|
if (hdr->payload_len == 0)
|
||||||
|
@ -544,8 +544,8 @@ static int ipv6_frag_rcv(struct sk_buff *skb)
|
||||||
if (!(fhdr->frag_off & htons(0xFFF9))) {
|
if (!(fhdr->frag_off & htons(0xFFF9))) {
|
||||||
/* It is not a fragmented frame */
|
/* It is not a fragmented frame */
|
||||||
skb->transport_header += sizeof(struct frag_hdr);
|
skb->transport_header += sizeof(struct frag_hdr);
|
||||||
IP6_INC_STATS_BH(net,
|
__IP6_INC_STATS(net,
|
||||||
ip6_dst_idev(skb_dst(skb)), IPSTATS_MIB_REASMOKS);
|
ip6_dst_idev(skb_dst(skb)), IPSTATS_MIB_REASMOKS);
|
||||||
|
|
||||||
IP6CB(skb)->nhoff = (u8 *)fhdr - skb_network_header(skb);
|
IP6CB(skb)->nhoff = (u8 *)fhdr - skb_network_header(skb);
|
||||||
IP6CB(skb)->flags |= IP6SKB_FRAGMENTED;
|
IP6CB(skb)->flags |= IP6SKB_FRAGMENTED;
|
||||||
|
@ -566,13 +566,13 @@ static int ipv6_frag_rcv(struct sk_buff *skb)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)), IPSTATS_MIB_REASMFAILS);
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)), IPSTATS_MIB_REASMFAILS);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
fail_hdr:
|
fail_hdr:
|
||||||
IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)),
|
__IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_INHDRERRORS);
|
IPSTATS_MIB_INHDRERRORS);
|
||||||
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD, skb_network_header_len(skb));
|
icmpv6_param_prob(skb, ICMPV6_HDR_FIELD, skb_network_header_len(skb));
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue