diff options
author | David S. Miller <davem@davemloft.net> | 2013-08-26 16:37:08 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-08-26 16:37:08 -0400 |
commit | b05930f5d1c7d5873cb050261d21789a99de9d48 (patch) | |
tree | 2d374846712b0bdacc5dd0a36b3c2f754886e560 /net/ipv6 | |
parent | b65f63ee845136940db985f3072335d8cdb6fd6c (diff) | |
parent | 41a00f7950a6bc0aa956f6d6b423f0fbf34d431a (diff) |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net
Conflicts:
drivers/net/wireless/iwlwifi/pcie/trans.c
include/linux/inetdevice.h
The inetdevice.h conflict involves moving the IPV4_DEVCONF values
into a UAPI header, overlapping additions of some new entries.
The iwlwifi conflict is a context overlap.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6')
-rw-r--r-- | net/ipv6/addrconf.c | 10 | ||||
-rw-r--r-- | net/ipv6/ndisc.c | 4 | ||||
-rw-r--r-- | net/ipv6/reassembly.c | 5 | ||||
-rw-r--r-- | net/ipv6/route.c | 21 |
4 files changed, 33 insertions, 7 deletions
diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c index 8549a5d0d167..2d6d1793bbfe 100644 --- a/net/ipv6/addrconf.c +++ b/net/ipv6/addrconf.c | |||
@@ -1131,12 +1131,10 @@ retry: | |||
1131 | if (ifp->flags & IFA_F_OPTIMISTIC) | 1131 | if (ifp->flags & IFA_F_OPTIMISTIC) |
1132 | addr_flags |= IFA_F_OPTIMISTIC; | 1132 | addr_flags |= IFA_F_OPTIMISTIC; |
1133 | 1133 | ||
1134 | ift = !max_addresses || | 1134 | ift = ipv6_add_addr(idev, &addr, NULL, tmp_plen, |
1135 | ipv6_count_addresses(idev) < max_addresses ? | 1135 | ipv6_addr_scope(&addr), addr_flags, |
1136 | ipv6_add_addr(idev, &addr, NULL, tmp_plen, | 1136 | tmp_valid_lft, tmp_prefered_lft); |
1137 | ipv6_addr_scope(&addr), addr_flags, | 1137 | if (IS_ERR(ift)) { |
1138 | tmp_valid_lft, tmp_prefered_lft) : NULL; | ||
1139 | if (IS_ERR_OR_NULL(ift)) { | ||
1140 | in6_ifa_put(ifp); | 1138 | in6_ifa_put(ifp); |
1141 | in6_dev_put(idev); | 1139 | in6_dev_put(idev); |
1142 | pr_info("%s: retry temporary address regeneration\n", __func__); | 1140 | pr_info("%s: retry temporary address regeneration\n", __func__); |
diff --git a/net/ipv6/ndisc.c b/net/ipv6/ndisc.c index 79aa9652ed86..04d31c2fbef1 100644 --- a/net/ipv6/ndisc.c +++ b/net/ipv6/ndisc.c | |||
@@ -1369,8 +1369,10 @@ static void ndisc_redirect_rcv(struct sk_buff *skb) | |||
1369 | if (!ndisc_parse_options(msg->opt, ndoptlen, &ndopts)) | 1369 | if (!ndisc_parse_options(msg->opt, ndoptlen, &ndopts)) |
1370 | return; | 1370 | return; |
1371 | 1371 | ||
1372 | if (!ndopts.nd_opts_rh) | 1372 | if (!ndopts.nd_opts_rh) { |
1373 | ip6_redirect_no_header(skb, dev_net(skb->dev), 0, 0); | ||
1373 | return; | 1374 | return; |
1375 | } | ||
1374 | 1376 | ||
1375 | hdr = (u8 *)ndopts.nd_opts_rh; | 1377 | hdr = (u8 *)ndopts.nd_opts_rh; |
1376 | hdr += 8; | 1378 | hdr += 8; |
diff --git a/net/ipv6/reassembly.c b/net/ipv6/reassembly.c index 790d9f4b8b0b..1aeb473b2cc6 100644 --- a/net/ipv6/reassembly.c +++ b/net/ipv6/reassembly.c | |||
@@ -490,6 +490,7 @@ static int ip6_frag_reasm(struct frag_queue *fq, struct sk_buff *prev, | |||
490 | ipv6_hdr(head)->payload_len = htons(payload_len); | 490 | ipv6_hdr(head)->payload_len = htons(payload_len); |
491 | ipv6_change_dsfield(ipv6_hdr(head), 0xff, ecn); | 491 | ipv6_change_dsfield(ipv6_hdr(head), 0xff, ecn); |
492 | IP6CB(head)->nhoff = nhoff; | 492 | IP6CB(head)->nhoff = nhoff; |
493 | IP6CB(head)->flags |= IP6SKB_FRAGMENTED; | ||
493 | 494 | ||
494 | /* Yes, and fold redundant checksum back. 8) */ | 495 | /* Yes, and fold redundant checksum back. 8) */ |
495 | if (head->ip_summed == CHECKSUM_COMPLETE) | 496 | if (head->ip_summed == CHECKSUM_COMPLETE) |
@@ -524,6 +525,9 @@ static int ipv6_frag_rcv(struct sk_buff *skb) | |||
524 | struct net *net = dev_net(skb_dst(skb)->dev); | 525 | struct net *net = dev_net(skb_dst(skb)->dev); |
525 | int evicted; | 526 | int evicted; |
526 | 527 | ||
528 | if (IP6CB(skb)->flags & IP6SKB_FRAGMENTED) | ||
529 | goto fail_hdr; | ||
530 | |||
527 | IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)), IPSTATS_MIB_REASMREQDS); | 531 | IP6_INC_STATS_BH(net, ip6_dst_idev(skb_dst(skb)), IPSTATS_MIB_REASMREQDS); |
528 | 532 | ||
529 | /* Jumbo payload inhibits frag. header */ | 533 | /* Jumbo payload inhibits frag. header */ |
@@ -544,6 +548,7 @@ static int ipv6_frag_rcv(struct sk_buff *skb) | |||
544 | ip6_dst_idev(skb_dst(skb)), IPSTATS_MIB_REASMOKS); | 548 | ip6_dst_idev(skb_dst(skb)), IPSTATS_MIB_REASMOKS); |
545 | 549 | ||
546 | IP6CB(skb)->nhoff = (u8 *)fhdr - skb_network_header(skb); | 550 | IP6CB(skb)->nhoff = (u8 *)fhdr - skb_network_header(skb); |
551 | IP6CB(skb)->flags |= IP6SKB_FRAGMENTED; | ||
547 | return 1; | 552 | return 1; |
548 | } | 553 | } |
549 | 554 | ||
diff --git a/net/ipv6/route.c b/net/ipv6/route.c index e22c4db8d07a..55236a84c748 100644 --- a/net/ipv6/route.c +++ b/net/ipv6/route.c | |||
@@ -1177,6 +1177,27 @@ void ip6_redirect(struct sk_buff *skb, struct net *net, int oif, u32 mark) | |||
1177 | } | 1177 | } |
1178 | EXPORT_SYMBOL_GPL(ip6_redirect); | 1178 | EXPORT_SYMBOL_GPL(ip6_redirect); |
1179 | 1179 | ||
1180 | void ip6_redirect_no_header(struct sk_buff *skb, struct net *net, int oif, | ||
1181 | u32 mark) | ||
1182 | { | ||
1183 | const struct ipv6hdr *iph = ipv6_hdr(skb); | ||
1184 | const struct rd_msg *msg = (struct rd_msg *)icmp6_hdr(skb); | ||
1185 | struct dst_entry *dst; | ||
1186 | struct flowi6 fl6; | ||
1187 | |||
1188 | memset(&fl6, 0, sizeof(fl6)); | ||
1189 | fl6.flowi6_oif = oif; | ||
1190 | fl6.flowi6_mark = mark; | ||
1191 | fl6.flowi6_flags = 0; | ||
1192 | fl6.daddr = msg->dest; | ||
1193 | fl6.saddr = iph->daddr; | ||
1194 | |||
1195 | dst = ip6_route_output(net, NULL, &fl6); | ||
1196 | if (!dst->error) | ||
1197 | rt6_do_redirect(dst, NULL, skb); | ||
1198 | dst_release(dst); | ||
1199 | } | ||
1200 | |||
1180 | void ip6_sk_redirect(struct sk_buff *skb, struct sock *sk) | 1201 | void ip6_sk_redirect(struct sk_buff *skb, struct sock *sk) |
1181 | { | 1202 | { |
1182 | ip6_redirect(skb, sock_net(sk), sk->sk_bound_dev_if, sk->sk_mark); | 1203 | ip6_redirect(skb, sock_net(sk), sk->sk_bound_dev_if, sk->sk_mark); |