tcp: Protect accesses to .ts_recent_stamp with {READ,WRITE}_ONCE()
[linux-2.6-microblaze.git] / net / ipv6 / ndisc.c
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  *      Neighbour Discovery for IPv6
4  *      Linux INET6 implementation
5  *
6  *      Authors:
7  *      Pedro Roque             <roque@di.fc.ul.pt>
8  *      Mike Shaver             <shaver@ingenia.com>
9  */
10
11 /*
12  *      Changes:
13  *
14  *      Alexey I. Froloff               :       RFC6106 (DNSSL) support
15  *      Pierre Ynard                    :       export userland ND options
16  *                                              through netlink (RDNSS support)
17  *      Lars Fenneberg                  :       fixed MTU setting on receipt
18  *                                              of an RA.
19  *      Janos Farkas                    :       kmalloc failure checks
20  *      Alexey Kuznetsov                :       state machine reworked
21  *                                              and moved to net/core.
22  *      Pekka Savola                    :       RFC2461 validation
23  *      YOSHIFUJI Hideaki @USAGI        :       Verify ND options properly
24  */
25
26 #define pr_fmt(fmt) "ICMPv6: " fmt
27
28 #include <linux/module.h>
29 #include <linux/errno.h>
30 #include <linux/types.h>
31 #include <linux/socket.h>
32 #include <linux/sockios.h>
33 #include <linux/sched.h>
34 #include <linux/net.h>
35 #include <linux/in6.h>
36 #include <linux/route.h>
37 #include <linux/init.h>
38 #include <linux/rcupdate.h>
39 #include <linux/slab.h>
40 #ifdef CONFIG_SYSCTL
41 #include <linux/sysctl.h>
42 #endif
43
44 #include <linux/if_addr.h>
45 #include <linux/if_ether.h>
46 #include <linux/if_arp.h>
47 #include <linux/ipv6.h>
48 #include <linux/icmpv6.h>
49 #include <linux/jhash.h>
50
51 #include <net/sock.h>
52 #include <net/snmp.h>
53
54 #include <net/ipv6.h>
55 #include <net/protocol.h>
56 #include <net/ndisc.h>
57 #include <net/ip6_route.h>
58 #include <net/addrconf.h>
59 #include <net/icmp.h>
60
61 #include <net/netlink.h>
62 #include <linux/rtnetlink.h>
63
64 #include <net/flow.h>
65 #include <net/ip6_checksum.h>
66 #include <net/inet_common.h>
67 #include <linux/proc_fs.h>
68
69 #include <linux/netfilter.h>
70 #include <linux/netfilter_ipv6.h>
71
72 static u32 ndisc_hash(const void *pkey,
73                       const struct net_device *dev,
74                       __u32 *hash_rnd);
75 static bool ndisc_key_eq(const struct neighbour *neigh, const void *pkey);
76 static bool ndisc_allow_add(const struct net_device *dev,
77                             struct netlink_ext_ack *extack);
78 static int ndisc_constructor(struct neighbour *neigh);
79 static void ndisc_solicit(struct neighbour *neigh, struct sk_buff *skb);
80 static void ndisc_error_report(struct neighbour *neigh, struct sk_buff *skb);
81 static int pndisc_constructor(struct pneigh_entry *n);
82 static void pndisc_destructor(struct pneigh_entry *n);
83 static void pndisc_redo(struct sk_buff *skb);
84
85 static const struct neigh_ops ndisc_generic_ops = {
86         .family =               AF_INET6,
87         .solicit =              ndisc_solicit,
88         .error_report =         ndisc_error_report,
89         .output =               neigh_resolve_output,
90         .connected_output =     neigh_connected_output,
91 };
92
93 static const struct neigh_ops ndisc_hh_ops = {
94         .family =               AF_INET6,
95         .solicit =              ndisc_solicit,
96         .error_report =         ndisc_error_report,
97         .output =               neigh_resolve_output,
98         .connected_output =     neigh_resolve_output,
99 };
100
101
102 static const struct neigh_ops ndisc_direct_ops = {
103         .family =               AF_INET6,
104         .output =               neigh_direct_output,
105         .connected_output =     neigh_direct_output,
106 };
107
108 struct neigh_table nd_tbl = {
109         .family =       AF_INET6,
110         .key_len =      sizeof(struct in6_addr),
111         .protocol =     cpu_to_be16(ETH_P_IPV6),
112         .hash =         ndisc_hash,
113         .key_eq =       ndisc_key_eq,
114         .constructor =  ndisc_constructor,
115         .pconstructor = pndisc_constructor,
116         .pdestructor =  pndisc_destructor,
117         .proxy_redo =   pndisc_redo,
118         .allow_add  =   ndisc_allow_add,
119         .id =           "ndisc_cache",
120         .parms = {
121                 .tbl                    = &nd_tbl,
122                 .reachable_time         = ND_REACHABLE_TIME,
123                 .data = {
124                         [NEIGH_VAR_MCAST_PROBES] = 3,
125                         [NEIGH_VAR_UCAST_PROBES] = 3,
126                         [NEIGH_VAR_RETRANS_TIME] = ND_RETRANS_TIMER,
127                         [NEIGH_VAR_BASE_REACHABLE_TIME] = ND_REACHABLE_TIME,
128                         [NEIGH_VAR_DELAY_PROBE_TIME] = 5 * HZ,
129                         [NEIGH_VAR_GC_STALETIME] = 60 * HZ,
130                         [NEIGH_VAR_QUEUE_LEN_BYTES] = SK_WMEM_MAX,
131                         [NEIGH_VAR_PROXY_QLEN] = 64,
132                         [NEIGH_VAR_ANYCAST_DELAY] = 1 * HZ,
133                         [NEIGH_VAR_PROXY_DELAY] = (8 * HZ) / 10,
134                 },
135         },
136         .gc_interval =    30 * HZ,
137         .gc_thresh1 =    128,
138         .gc_thresh2 =    512,
139         .gc_thresh3 =   1024,
140 };
141 EXPORT_SYMBOL_GPL(nd_tbl);
142
143 void __ndisc_fill_addr_option(struct sk_buff *skb, int type, void *data,
144                               int data_len, int pad)
145 {
146         int space = __ndisc_opt_addr_space(data_len, pad);
147         u8 *opt = skb_put(skb, space);
148
149         opt[0] = type;
150         opt[1] = space>>3;
151
152         memset(opt + 2, 0, pad);
153         opt   += pad;
154         space -= pad;
155
156         memcpy(opt+2, data, data_len);
157         data_len += 2;
158         opt += data_len;
159         space -= data_len;
160         if (space > 0)
161                 memset(opt, 0, space);
162 }
163 EXPORT_SYMBOL_GPL(__ndisc_fill_addr_option);
164
165 static inline void ndisc_fill_addr_option(struct sk_buff *skb, int type,
166                                           void *data, u8 icmp6_type)
167 {
168         __ndisc_fill_addr_option(skb, type, data, skb->dev->addr_len,
169                                  ndisc_addr_option_pad(skb->dev->type));
170         ndisc_ops_fill_addr_option(skb->dev, skb, icmp6_type);
171 }
172
173 static inline void ndisc_fill_redirect_addr_option(struct sk_buff *skb,
174                                                    void *ha,
175                                                    const u8 *ops_data)
176 {
177         ndisc_fill_addr_option(skb, ND_OPT_TARGET_LL_ADDR, ha, NDISC_REDIRECT);
178         ndisc_ops_fill_redirect_addr_option(skb->dev, skb, ops_data);
179 }
180
181 static struct nd_opt_hdr *ndisc_next_option(struct nd_opt_hdr *cur,
182                                             struct nd_opt_hdr *end)
183 {
184         int type;
185         if (!cur || !end || cur >= end)
186                 return NULL;
187         type = cur->nd_opt_type;
188         do {
189                 cur = ((void *)cur) + (cur->nd_opt_len << 3);
190         } while (cur < end && cur->nd_opt_type != type);
191         return cur <= end && cur->nd_opt_type == type ? cur : NULL;
192 }
193
194 static inline int ndisc_is_useropt(const struct net_device *dev,
195                                    struct nd_opt_hdr *opt)
196 {
197         return opt->nd_opt_type == ND_OPT_RDNSS ||
198                 opt->nd_opt_type == ND_OPT_DNSSL ||
199                 opt->nd_opt_type == ND_OPT_CAPTIVE_PORTAL ||
200                 ndisc_ops_is_useropt(dev, opt->nd_opt_type);
201 }
202
203 static struct nd_opt_hdr *ndisc_next_useropt(const struct net_device *dev,
204                                              struct nd_opt_hdr *cur,
205                                              struct nd_opt_hdr *end)
206 {
207         if (!cur || !end || cur >= end)
208                 return NULL;
209         do {
210                 cur = ((void *)cur) + (cur->nd_opt_len << 3);
211         } while (cur < end && !ndisc_is_useropt(dev, cur));
212         return cur <= end && ndisc_is_useropt(dev, cur) ? cur : NULL;
213 }
214
215 struct ndisc_options *ndisc_parse_options(const struct net_device *dev,
216                                           u8 *opt, int opt_len,
217                                           struct ndisc_options *ndopts)
218 {
219         struct nd_opt_hdr *nd_opt = (struct nd_opt_hdr *)opt;
220
221         if (!nd_opt || opt_len < 0 || !ndopts)
222                 return NULL;
223         memset(ndopts, 0, sizeof(*ndopts));
224         while (opt_len) {
225                 int l;
226                 if (opt_len < sizeof(struct nd_opt_hdr))
227                         return NULL;
228                 l = nd_opt->nd_opt_len << 3;
229                 if (opt_len < l || l == 0)
230                         return NULL;
231                 if (ndisc_ops_parse_options(dev, nd_opt, ndopts))
232                         goto next_opt;
233                 switch (nd_opt->nd_opt_type) {
234                 case ND_OPT_SOURCE_LL_ADDR:
235                 case ND_OPT_TARGET_LL_ADDR:
236                 case ND_OPT_MTU:
237                 case ND_OPT_NONCE:
238                 case ND_OPT_REDIRECT_HDR:
239                         if (ndopts->nd_opt_array[nd_opt->nd_opt_type]) {
240                                 ND_PRINTK(2, warn,
241                                           "%s: duplicated ND6 option found: type=%d\n",
242                                           __func__, nd_opt->nd_opt_type);
243                         } else {
244                                 ndopts->nd_opt_array[nd_opt->nd_opt_type] = nd_opt;
245                         }
246                         break;
247                 case ND_OPT_PREFIX_INFO:
248                         ndopts->nd_opts_pi_end = nd_opt;
249                         if (!ndopts->nd_opt_array[nd_opt->nd_opt_type])
250                                 ndopts->nd_opt_array[nd_opt->nd_opt_type] = nd_opt;
251                         break;
252 #ifdef CONFIG_IPV6_ROUTE_INFO
253                 case ND_OPT_ROUTE_INFO:
254                         ndopts->nd_opts_ri_end = nd_opt;
255                         if (!ndopts->nd_opts_ri)
256                                 ndopts->nd_opts_ri = nd_opt;
257                         break;
258 #endif
259                 default:
260                         if (ndisc_is_useropt(dev, nd_opt)) {
261                                 ndopts->nd_useropts_end = nd_opt;
262                                 if (!ndopts->nd_useropts)
263                                         ndopts->nd_useropts = nd_opt;
264                         } else {
265                                 /*
266                                  * Unknown options must be silently ignored,
267                                  * to accommodate future extension to the
268                                  * protocol.
269                                  */
270                                 ND_PRINTK(2, notice,
271                                           "%s: ignored unsupported option; type=%d, len=%d\n",
272                                           __func__,
273                                           nd_opt->nd_opt_type,
274                                           nd_opt->nd_opt_len);
275                         }
276                 }
277 next_opt:
278                 opt_len -= l;
279                 nd_opt = ((void *)nd_opt) + l;
280         }
281         return ndopts;
282 }
283
284 int ndisc_mc_map(const struct in6_addr *addr, char *buf, struct net_device *dev, int dir)
285 {
286         switch (dev->type) {
287         case ARPHRD_ETHER:
288         case ARPHRD_IEEE802:    /* Not sure. Check it later. --ANK */
289         case ARPHRD_FDDI:
290                 ipv6_eth_mc_map(addr, buf);
291                 return 0;
292         case ARPHRD_ARCNET:
293                 ipv6_arcnet_mc_map(addr, buf);
294                 return 0;
295         case ARPHRD_INFINIBAND:
296                 ipv6_ib_mc_map(addr, dev->broadcast, buf);
297                 return 0;
298         case ARPHRD_IPGRE:
299                 return ipv6_ipgre_mc_map(addr, dev->broadcast, buf);
300         default:
301                 if (dir) {
302                         memcpy(buf, dev->broadcast, dev->addr_len);
303                         return 0;
304                 }
305         }
306         return -EINVAL;
307 }
308 EXPORT_SYMBOL(ndisc_mc_map);
309
310 static u32 ndisc_hash(const void *pkey,
311                       const struct net_device *dev,
312                       __u32 *hash_rnd)
313 {
314         return ndisc_hashfn(pkey, dev, hash_rnd);
315 }
316
317 static bool ndisc_key_eq(const struct neighbour *n, const void *pkey)
318 {
319         return neigh_key_eq128(n, pkey);
320 }
321
322 static int ndisc_constructor(struct neighbour *neigh)
323 {
324         struct in6_addr *addr = (struct in6_addr *)&neigh->primary_key;
325         struct net_device *dev = neigh->dev;
326         struct inet6_dev *in6_dev;
327         struct neigh_parms *parms;
328         bool is_multicast = ipv6_addr_is_multicast(addr);
329
330         in6_dev = in6_dev_get(dev);
331         if (!in6_dev) {
332                 return -EINVAL;
333         }
334
335         parms = in6_dev->nd_parms;
336         __neigh_parms_put(neigh->parms);
337         neigh->parms = neigh_parms_clone(parms);
338
339         neigh->type = is_multicast ? RTN_MULTICAST : RTN_UNICAST;
340         if (!dev->header_ops) {
341                 neigh->nud_state = NUD_NOARP;
342                 neigh->ops = &ndisc_direct_ops;
343                 neigh->output = neigh_direct_output;
344         } else {
345                 if (is_multicast) {
346                         neigh->nud_state = NUD_NOARP;
347                         ndisc_mc_map(addr, neigh->ha, dev, 1);
348                 } else if (dev->flags&(IFF_NOARP|IFF_LOOPBACK)) {
349                         neigh->nud_state = NUD_NOARP;
350                         memcpy(neigh->ha, dev->dev_addr, dev->addr_len);
351                         if (dev->flags&IFF_LOOPBACK)
352                                 neigh->type = RTN_LOCAL;
353                 } else if (dev->flags&IFF_POINTOPOINT) {
354                         neigh->nud_state = NUD_NOARP;
355                         memcpy(neigh->ha, dev->broadcast, dev->addr_len);
356                 }
357                 if (dev->header_ops->cache)
358                         neigh->ops = &ndisc_hh_ops;
359                 else
360                         neigh->ops = &ndisc_generic_ops;
361                 if (neigh->nud_state&NUD_VALID)
362                         neigh->output = neigh->ops->connected_output;
363                 else
364                         neigh->output = neigh->ops->output;
365         }
366         in6_dev_put(in6_dev);
367         return 0;
368 }
369
370 static int pndisc_constructor(struct pneigh_entry *n)
371 {
372         struct in6_addr *addr = (struct in6_addr *)&n->key;
373         struct in6_addr maddr;
374         struct net_device *dev = n->dev;
375
376         if (!dev || !__in6_dev_get(dev))
377                 return -EINVAL;
378         addrconf_addr_solict_mult(addr, &maddr);
379         ipv6_dev_mc_inc(dev, &maddr);
380         return 0;
381 }
382
383 static void pndisc_destructor(struct pneigh_entry *n)
384 {
385         struct in6_addr *addr = (struct in6_addr *)&n->key;
386         struct in6_addr maddr;
387         struct net_device *dev = n->dev;
388
389         if (!dev || !__in6_dev_get(dev))
390                 return;
391         addrconf_addr_solict_mult(addr, &maddr);
392         ipv6_dev_mc_dec(dev, &maddr);
393 }
394
395 /* called with rtnl held */
396 static bool ndisc_allow_add(const struct net_device *dev,
397                             struct netlink_ext_ack *extack)
398 {
399         struct inet6_dev *idev = __in6_dev_get(dev);
400
401         if (!idev || idev->cnf.disable_ipv6) {
402                 NL_SET_ERR_MSG(extack, "IPv6 is disabled on this device");
403                 return false;
404         }
405
406         return true;
407 }
408
409 static struct sk_buff *ndisc_alloc_skb(struct net_device *dev,
410                                        int len)
411 {
412         int hlen = LL_RESERVED_SPACE(dev);
413         int tlen = dev->needed_tailroom;
414         struct sock *sk = dev_net(dev)->ipv6.ndisc_sk;
415         struct sk_buff *skb;
416
417         skb = alloc_skb(hlen + sizeof(struct ipv6hdr) + len + tlen, GFP_ATOMIC);
418         if (!skb) {
419                 ND_PRINTK(0, err, "ndisc: %s failed to allocate an skb\n",
420                           __func__);
421                 return NULL;
422         }
423
424         skb->protocol = htons(ETH_P_IPV6);
425         skb->dev = dev;
426
427         skb_reserve(skb, hlen + sizeof(struct ipv6hdr));
428         skb_reset_transport_header(skb);
429
430         /* Manually assign socket ownership as we avoid calling
431          * sock_alloc_send_pskb() to bypass wmem buffer limits
432          */
433         skb_set_owner_w(skb, sk);
434
435         return skb;
436 }
437
438 static void ip6_nd_hdr(struct sk_buff *skb,
439                        const struct in6_addr *saddr,
440                        const struct in6_addr *daddr,
441                        int hop_limit, int len)
442 {
443         struct ipv6hdr *hdr;
444         struct inet6_dev *idev;
445         unsigned tclass;
446
447         rcu_read_lock();
448         idev = __in6_dev_get(skb->dev);
449         tclass = idev ? idev->cnf.ndisc_tclass : 0;
450         rcu_read_unlock();
451
452         skb_push(skb, sizeof(*hdr));
453         skb_reset_network_header(skb);
454         hdr = ipv6_hdr(skb);
455
456         ip6_flow_hdr(hdr, tclass, 0);
457
458         hdr->payload_len = htons(len);
459         hdr->nexthdr = IPPROTO_ICMPV6;
460         hdr->hop_limit = hop_limit;
461
462         hdr->saddr = *saddr;
463         hdr->daddr = *daddr;
464 }
465
466 static void ndisc_send_skb(struct sk_buff *skb,
467                            const struct in6_addr *daddr,
468                            const struct in6_addr *saddr)
469 {
470         struct dst_entry *dst = skb_dst(skb);
471         struct net *net = dev_net(skb->dev);
472         struct sock *sk = net->ipv6.ndisc_sk;
473         struct inet6_dev *idev;
474         int err;
475         struct icmp6hdr *icmp6h = icmp6_hdr(skb);
476         u8 type;
477
478         type = icmp6h->icmp6_type;
479
480         if (!dst) {
481                 struct flowi6 fl6;
482                 int oif = skb->dev->ifindex;
483
484                 icmpv6_flow_init(sk, &fl6, type, saddr, daddr, oif);
485                 dst = icmp6_dst_alloc(skb->dev, &fl6);
486                 if (IS_ERR(dst)) {
487                         kfree_skb(skb);
488                         return;
489                 }
490
491                 skb_dst_set(skb, dst);
492         }
493
494         icmp6h->icmp6_cksum = csum_ipv6_magic(saddr, daddr, skb->len,
495                                               IPPROTO_ICMPV6,
496                                               csum_partial(icmp6h,
497                                                            skb->len, 0));
498
499         ip6_nd_hdr(skb, saddr, daddr, inet6_sk(sk)->hop_limit, skb->len);
500
501         rcu_read_lock();
502         idev = __in6_dev_get(dst->dev);
503         IP6_UPD_PO_STATS(net, idev, IPSTATS_MIB_OUT, skb->len);
504
505         err = NF_HOOK(NFPROTO_IPV6, NF_INET_LOCAL_OUT,
506                       net, sk, skb, NULL, dst->dev,
507                       dst_output);
508         if (!err) {
509                 ICMP6MSGOUT_INC_STATS(net, idev, type);
510                 ICMP6_INC_STATS(net, idev, ICMP6_MIB_OUTMSGS);
511         }
512
513         rcu_read_unlock();
514 }
515
516 void ndisc_send_na(struct net_device *dev, const struct in6_addr *daddr,
517                    const struct in6_addr *solicited_addr,
518                    bool router, bool solicited, bool override, bool inc_opt)
519 {
520         struct sk_buff *skb;
521         struct in6_addr tmpaddr;
522         struct inet6_ifaddr *ifp;
523         const struct in6_addr *src_addr;
524         struct nd_msg *msg;
525         int optlen = 0;
526
527         /* for anycast or proxy, solicited_addr != src_addr */
528         ifp = ipv6_get_ifaddr(dev_net(dev), solicited_addr, dev, 1);
529         if (ifp) {
530                 src_addr = solicited_addr;
531                 if (ifp->flags & IFA_F_OPTIMISTIC)
532                         override = false;
533                 inc_opt |= ifp->idev->cnf.force_tllao;
534                 in6_ifa_put(ifp);
535         } else {
536                 if (ipv6_dev_get_saddr(dev_net(dev), dev, daddr,
537                                        inet6_sk(dev_net(dev)->ipv6.ndisc_sk)->srcprefs,
538                                        &tmpaddr))
539                         return;
540                 src_addr = &tmpaddr;
541         }
542
543         if (!dev->addr_len)
544                 inc_opt = false;
545         if (inc_opt)
546                 optlen += ndisc_opt_addr_space(dev,
547                                                NDISC_NEIGHBOUR_ADVERTISEMENT);
548
549         skb = ndisc_alloc_skb(dev, sizeof(*msg) + optlen);
550         if (!skb)
551                 return;
552
553         msg = skb_put(skb, sizeof(*msg));
554         *msg = (struct nd_msg) {
555                 .icmph = {
556                         .icmp6_type = NDISC_NEIGHBOUR_ADVERTISEMENT,
557                         .icmp6_router = router,
558                         .icmp6_solicited = solicited,
559                         .icmp6_override = override,
560                 },
561                 .target = *solicited_addr,
562         };
563
564         if (inc_opt)
565                 ndisc_fill_addr_option(skb, ND_OPT_TARGET_LL_ADDR,
566                                        dev->dev_addr,
567                                        NDISC_NEIGHBOUR_ADVERTISEMENT);
568
569         ndisc_send_skb(skb, daddr, src_addr);
570 }
571
572 static void ndisc_send_unsol_na(struct net_device *dev)
573 {
574         struct inet6_dev *idev;
575         struct inet6_ifaddr *ifa;
576
577         idev = in6_dev_get(dev);
578         if (!idev)
579                 return;
580
581         read_lock_bh(&idev->lock);
582         list_for_each_entry(ifa, &idev->addr_list, if_list) {
583                 /* skip tentative addresses until dad completes */
584                 if (ifa->flags & IFA_F_TENTATIVE &&
585                     !(ifa->flags & IFA_F_OPTIMISTIC))
586                         continue;
587
588                 ndisc_send_na(dev, &in6addr_linklocal_allnodes, &ifa->addr,
589                               /*router=*/ !!idev->cnf.forwarding,
590                               /*solicited=*/ false, /*override=*/ true,
591                               /*inc_opt=*/ true);
592         }
593         read_unlock_bh(&idev->lock);
594
595         in6_dev_put(idev);
596 }
597
598 void ndisc_send_ns(struct net_device *dev, const struct in6_addr *solicit,
599                    const struct in6_addr *daddr, const struct in6_addr *saddr,
600                    u64 nonce)
601 {
602         struct sk_buff *skb;
603         struct in6_addr addr_buf;
604         int inc_opt = dev->addr_len;
605         int optlen = 0;
606         struct nd_msg *msg;
607
608         if (!saddr) {
609                 if (ipv6_get_lladdr(dev, &addr_buf,
610                                    (IFA_F_TENTATIVE|IFA_F_OPTIMISTIC)))
611                         return;
612                 saddr = &addr_buf;
613         }
614
615         if (ipv6_addr_any(saddr))
616                 inc_opt = false;
617         if (inc_opt)
618                 optlen += ndisc_opt_addr_space(dev,
619                                                NDISC_NEIGHBOUR_SOLICITATION);
620         if (nonce != 0)
621                 optlen += 8;
622
623         skb = ndisc_alloc_skb(dev, sizeof(*msg) + optlen);
624         if (!skb)
625                 return;
626
627         msg = skb_put(skb, sizeof(*msg));
628         *msg = (struct nd_msg) {
629                 .icmph = {
630                         .icmp6_type = NDISC_NEIGHBOUR_SOLICITATION,
631                 },
632                 .target = *solicit,
633         };
634
635         if (inc_opt)
636                 ndisc_fill_addr_option(skb, ND_OPT_SOURCE_LL_ADDR,
637                                        dev->dev_addr,
638                                        NDISC_NEIGHBOUR_SOLICITATION);
639         if (nonce != 0) {
640                 u8 *opt = skb_put(skb, 8);
641
642                 opt[0] = ND_OPT_NONCE;
643                 opt[1] = 8 >> 3;
644                 memcpy(opt + 2, &nonce, 6);
645         }
646
647         ndisc_send_skb(skb, daddr, saddr);
648 }
649
650 void ndisc_send_rs(struct net_device *dev, const struct in6_addr *saddr,
651                    const struct in6_addr *daddr)
652 {
653         struct sk_buff *skb;
654         struct rs_msg *msg;
655         int send_sllao = dev->addr_len;
656         int optlen = 0;
657
658 #ifdef CONFIG_IPV6_OPTIMISTIC_DAD
659         /*
660          * According to section 2.2 of RFC 4429, we must not
661          * send router solicitations with a sllao from
662          * optimistic addresses, but we may send the solicitation
663          * if we don't include the sllao.  So here we check
664          * if our address is optimistic, and if so, we
665          * suppress the inclusion of the sllao.
666          */
667         if (send_sllao) {
668                 struct inet6_ifaddr *ifp = ipv6_get_ifaddr(dev_net(dev), saddr,
669                                                            dev, 1);
670                 if (ifp) {
671                         if (ifp->flags & IFA_F_OPTIMISTIC)  {
672                                 send_sllao = 0;
673                         }
674                         in6_ifa_put(ifp);
675                 } else {
676                         send_sllao = 0;
677                 }
678         }
679 #endif
680         if (send_sllao)
681                 optlen += ndisc_opt_addr_space(dev, NDISC_ROUTER_SOLICITATION);
682
683         skb = ndisc_alloc_skb(dev, sizeof(*msg) + optlen);
684         if (!skb)
685                 return;
686
687         msg = skb_put(skb, sizeof(*msg));
688         *msg = (struct rs_msg) {
689                 .icmph = {
690                         .icmp6_type = NDISC_ROUTER_SOLICITATION,
691                 },
692         };
693
694         if (send_sllao)
695                 ndisc_fill_addr_option(skb, ND_OPT_SOURCE_LL_ADDR,
696                                        dev->dev_addr,
697                                        NDISC_ROUTER_SOLICITATION);
698
699         ndisc_send_skb(skb, daddr, saddr);
700 }
701
702
703 static void ndisc_error_report(struct neighbour *neigh, struct sk_buff *skb)
704 {
705         /*
706          *      "The sender MUST return an ICMP
707          *       destination unreachable"
708          */
709         dst_link_failure(skb);
710         kfree_skb(skb);
711 }
712
713 /* Called with locked neigh: either read or both */
714
715 static void ndisc_solicit(struct neighbour *neigh, struct sk_buff *skb)
716 {
717         struct in6_addr *saddr = NULL;
718         struct in6_addr mcaddr;
719         struct net_device *dev = neigh->dev;
720         struct in6_addr *target = (struct in6_addr *)&neigh->primary_key;
721         int probes = atomic_read(&neigh->probes);
722
723         if (skb && ipv6_chk_addr_and_flags(dev_net(dev), &ipv6_hdr(skb)->saddr,
724                                            dev, false, 1,
725                                            IFA_F_TENTATIVE|IFA_F_OPTIMISTIC))
726                 saddr = &ipv6_hdr(skb)->saddr;
727         probes -= NEIGH_VAR(neigh->parms, UCAST_PROBES);
728         if (probes < 0) {
729                 if (!(neigh->nud_state & NUD_VALID)) {
730                         ND_PRINTK(1, dbg,
731                                   "%s: trying to ucast probe in NUD_INVALID: %pI6\n",
732                                   __func__, target);
733                 }
734                 ndisc_send_ns(dev, target, target, saddr, 0);
735         } else if ((probes -= NEIGH_VAR(neigh->parms, APP_PROBES)) < 0) {
736                 neigh_app_ns(neigh);
737         } else {
738                 addrconf_addr_solict_mult(target, &mcaddr);
739                 ndisc_send_ns(dev, target, &mcaddr, saddr, 0);
740         }
741 }
742
743 static int pndisc_is_router(const void *pkey,
744                             struct net_device *dev)
745 {
746         struct pneigh_entry *n;
747         int ret = -1;
748
749         read_lock_bh(&nd_tbl.lock);
750         n = __pneigh_lookup(&nd_tbl, dev_net(dev), pkey, dev);
751         if (n)
752                 ret = !!(n->flags & NTF_ROUTER);
753         read_unlock_bh(&nd_tbl.lock);
754
755         return ret;
756 }
757
758 void ndisc_update(const struct net_device *dev, struct neighbour *neigh,
759                   const u8 *lladdr, u8 new, u32 flags, u8 icmp6_type,
760                   struct ndisc_options *ndopts)
761 {
762         neigh_update(neigh, lladdr, new, flags, 0);
763         /* report ndisc ops about neighbour update */
764         ndisc_ops_update(dev, neigh, flags, icmp6_type, ndopts);
765 }
766
767 static void ndisc_recv_ns(struct sk_buff *skb)
768 {
769         struct nd_msg *msg = (struct nd_msg *)skb_transport_header(skb);
770         const struct in6_addr *saddr = &ipv6_hdr(skb)->saddr;
771         const struct in6_addr *daddr = &ipv6_hdr(skb)->daddr;
772         u8 *lladdr = NULL;
773         u32 ndoptlen = skb_tail_pointer(skb) - (skb_transport_header(skb) +
774                                     offsetof(struct nd_msg, opt));
775         struct ndisc_options ndopts;
776         struct net_device *dev = skb->dev;
777         struct inet6_ifaddr *ifp;
778         struct inet6_dev *idev = NULL;
779         struct neighbour *neigh;
780         int dad = ipv6_addr_any(saddr);
781         bool inc;
782         int is_router = -1;
783         u64 nonce = 0;
784
785         if (skb->len < sizeof(struct nd_msg)) {
786                 ND_PRINTK(2, warn, "NS: packet too short\n");
787                 return;
788         }
789
790         if (ipv6_addr_is_multicast(&msg->target)) {
791                 ND_PRINTK(2, warn, "NS: multicast target address\n");
792                 return;
793         }
794
795         /*
796          * RFC2461 7.1.1:
797          * DAD has to be destined for solicited node multicast address.
798          */
799         if (dad && !ipv6_addr_is_solict_mult(daddr)) {
800                 ND_PRINTK(2, warn, "NS: bad DAD packet (wrong destination)\n");
801                 return;
802         }
803
804         if (!ndisc_parse_options(dev, msg->opt, ndoptlen, &ndopts)) {
805                 ND_PRINTK(2, warn, "NS: invalid ND options\n");
806                 return;
807         }
808
809         if (ndopts.nd_opts_src_lladdr) {
810                 lladdr = ndisc_opt_addr_data(ndopts.nd_opts_src_lladdr, dev);
811                 if (!lladdr) {
812                         ND_PRINTK(2, warn,
813                                   "NS: invalid link-layer address length\n");
814                         return;
815                 }
816
817                 /* RFC2461 7.1.1:
818                  *      If the IP source address is the unspecified address,
819                  *      there MUST NOT be source link-layer address option
820                  *      in the message.
821                  */
822                 if (dad) {
823                         ND_PRINTK(2, warn,
824                                   "NS: bad DAD packet (link-layer address option)\n");
825                         return;
826                 }
827         }
828         if (ndopts.nd_opts_nonce && ndopts.nd_opts_nonce->nd_opt_len == 1)
829                 memcpy(&nonce, (u8 *)(ndopts.nd_opts_nonce + 1), 6);
830
831         inc = ipv6_addr_is_multicast(daddr);
832
833         ifp = ipv6_get_ifaddr(dev_net(dev), &msg->target, dev, 1);
834         if (ifp) {
835 have_ifp:
836                 if (ifp->flags & (IFA_F_TENTATIVE|IFA_F_OPTIMISTIC)) {
837                         if (dad) {
838                                 if (nonce != 0 && ifp->dad_nonce == nonce) {
839                                         u8 *np = (u8 *)&nonce;
840                                         /* Matching nonce if looped back */
841                                         ND_PRINTK(2, notice,
842                                                   "%s: IPv6 DAD loopback for address %pI6c nonce %pM ignored\n",
843                                                   ifp->idev->dev->name,
844                                                   &ifp->addr, np);
845                                         goto out;
846                                 }
847                                 /*
848                                  * We are colliding with another node
849                                  * who is doing DAD
850                                  * so fail our DAD process
851                                  */
852                                 addrconf_dad_failure(skb, ifp);
853                                 return;
854                         } else {
855                                 /*
856                                  * This is not a dad solicitation.
857                                  * If we are an optimistic node,
858                                  * we should respond.
859                                  * Otherwise, we should ignore it.
860                                  */
861                                 if (!(ifp->flags & IFA_F_OPTIMISTIC))
862                                         goto out;
863                         }
864                 }
865
866                 idev = ifp->idev;
867         } else {
868                 struct net *net = dev_net(dev);
869
870                 /* perhaps an address on the master device */
871                 if (netif_is_l3_slave(dev)) {
872                         struct net_device *mdev;
873
874                         mdev = netdev_master_upper_dev_get_rcu(dev);
875                         if (mdev) {
876                                 ifp = ipv6_get_ifaddr(net, &msg->target, mdev, 1);
877                                 if (ifp)
878                                         goto have_ifp;
879                         }
880                 }
881
882                 idev = in6_dev_get(dev);
883                 if (!idev) {
884                         /* XXX: count this drop? */
885                         return;
886                 }
887
888                 if (ipv6_chk_acast_addr(net, dev, &msg->target) ||
889                     (idev->cnf.forwarding &&
890                      (net->ipv6.devconf_all->proxy_ndp || idev->cnf.proxy_ndp) &&
891                      (is_router = pndisc_is_router(&msg->target, dev)) >= 0)) {
892                         if (!(NEIGH_CB(skb)->flags & LOCALLY_ENQUEUED) &&
893                             skb->pkt_type != PACKET_HOST &&
894                             inc &&
895                             NEIGH_VAR(idev->nd_parms, PROXY_DELAY) != 0) {
896                                 /*
897                                  * for anycast or proxy,
898                                  * sender should delay its response
899                                  * by a random time between 0 and
900                                  * MAX_ANYCAST_DELAY_TIME seconds.
901                                  * (RFC2461) -- yoshfuji
902                                  */
903                                 struct sk_buff *n = skb_clone(skb, GFP_ATOMIC);
904                                 if (n)
905                                         pneigh_enqueue(&nd_tbl, idev->nd_parms, n);
906                                 goto out;
907                         }
908                 } else
909                         goto out;
910         }
911
912         if (is_router < 0)
913                 is_router = idev->cnf.forwarding;
914
915         if (dad) {
916                 ndisc_send_na(dev, &in6addr_linklocal_allnodes, &msg->target,
917                               !!is_router, false, (ifp != NULL), true);
918                 goto out;
919         }
920
921         if (inc)
922                 NEIGH_CACHE_STAT_INC(&nd_tbl, rcv_probes_mcast);
923         else
924                 NEIGH_CACHE_STAT_INC(&nd_tbl, rcv_probes_ucast);
925
926         /*
927          *      update / create cache entry
928          *      for the source address
929          */
930         neigh = __neigh_lookup(&nd_tbl, saddr, dev,
931                                !inc || lladdr || !dev->addr_len);
932         if (neigh)
933                 ndisc_update(dev, neigh, lladdr, NUD_STALE,
934                              NEIGH_UPDATE_F_WEAK_OVERRIDE|
935                              NEIGH_UPDATE_F_OVERRIDE,
936                              NDISC_NEIGHBOUR_SOLICITATION, &ndopts);
937         if (neigh || !dev->header_ops) {
938                 ndisc_send_na(dev, saddr, &msg->target, !!is_router,
939                               true, (ifp != NULL && inc), inc);
940                 if (neigh)
941                         neigh_release(neigh);
942         }
943
944 out:
945         if (ifp)
946                 in6_ifa_put(ifp);
947         else
948                 in6_dev_put(idev);
949 }
950
951 static void ndisc_recv_na(struct sk_buff *skb)
952 {
953         struct nd_msg *msg = (struct nd_msg *)skb_transport_header(skb);
954         struct in6_addr *saddr = &ipv6_hdr(skb)->saddr;
955         const struct in6_addr *daddr = &ipv6_hdr(skb)->daddr;
956         u8 *lladdr = NULL;
957         u32 ndoptlen = skb_tail_pointer(skb) - (skb_transport_header(skb) +
958                                     offsetof(struct nd_msg, opt));
959         struct ndisc_options ndopts;
960         struct net_device *dev = skb->dev;
961         struct inet6_dev *idev = __in6_dev_get(dev);
962         struct inet6_ifaddr *ifp;
963         struct neighbour *neigh;
964
965         if (skb->len < sizeof(struct nd_msg)) {
966                 ND_PRINTK(2, warn, "NA: packet too short\n");
967                 return;
968         }
969
970         if (ipv6_addr_is_multicast(&msg->target)) {
971                 ND_PRINTK(2, warn, "NA: target address is multicast\n");
972                 return;
973         }
974
975         if (ipv6_addr_is_multicast(daddr) &&
976             msg->icmph.icmp6_solicited) {
977                 ND_PRINTK(2, warn, "NA: solicited NA is multicasted\n");
978                 return;
979         }
980
981         /* For some 802.11 wireless deployments (and possibly other networks),
982          * there will be a NA proxy and unsolicitd packets are attacks
983          * and thus should not be accepted.
984          */
985         if (!msg->icmph.icmp6_solicited && idev &&
986             idev->cnf.drop_unsolicited_na)
987                 return;
988
989         if (!ndisc_parse_options(dev, msg->opt, ndoptlen, &ndopts)) {
990                 ND_PRINTK(2, warn, "NS: invalid ND option\n");
991                 return;
992         }
993         if (ndopts.nd_opts_tgt_lladdr) {
994                 lladdr = ndisc_opt_addr_data(ndopts.nd_opts_tgt_lladdr, dev);
995                 if (!lladdr) {
996                         ND_PRINTK(2, warn,
997                                   "NA: invalid link-layer address length\n");
998                         return;
999                 }
1000         }
1001         ifp = ipv6_get_ifaddr(dev_net(dev), &msg->target, dev, 1);
1002         if (ifp) {
1003                 if (skb->pkt_type != PACKET_LOOPBACK
1004                     && (ifp->flags & IFA_F_TENTATIVE)) {
1005                                 addrconf_dad_failure(skb, ifp);
1006                                 return;
1007                 }
1008                 /* What should we make now? The advertisement
1009                    is invalid, but ndisc specs say nothing
1010                    about it. It could be misconfiguration, or
1011                    an smart proxy agent tries to help us :-)
1012
1013                    We should not print the error if NA has been
1014                    received from loopback - it is just our own
1015                    unsolicited advertisement.
1016                  */
1017                 if (skb->pkt_type != PACKET_LOOPBACK)
1018                         ND_PRINTK(1, warn,
1019                                   "NA: %pM advertised our address %pI6c on %s!\n",
1020                                   eth_hdr(skb)->h_source, &ifp->addr, ifp->idev->dev->name);
1021                 in6_ifa_put(ifp);
1022                 return;
1023         }
1024         neigh = neigh_lookup(&nd_tbl, &msg->target, dev);
1025
1026         if (neigh) {
1027                 u8 old_flags = neigh->flags;
1028                 struct net *net = dev_net(dev);
1029
1030                 if (neigh->nud_state & NUD_FAILED)
1031                         goto out;
1032
1033                 /*
1034                  * Don't update the neighbor cache entry on a proxy NA from
1035                  * ourselves because either the proxied node is off link or it
1036                  * has already sent a NA to us.
1037                  */
1038                 if (lladdr && !memcmp(lladdr, dev->dev_addr, dev->addr_len) &&
1039                     net->ipv6.devconf_all->forwarding && net->ipv6.devconf_all->proxy_ndp &&
1040                     pneigh_lookup(&nd_tbl, net, &msg->target, dev, 0)) {
1041                         /* XXX: idev->cnf.proxy_ndp */
1042                         goto out;
1043                 }
1044
1045                 ndisc_update(dev, neigh, lladdr,
1046                              msg->icmph.icmp6_solicited ? NUD_REACHABLE : NUD_STALE,
1047                              NEIGH_UPDATE_F_WEAK_OVERRIDE|
1048                              (msg->icmph.icmp6_override ? NEIGH_UPDATE_F_OVERRIDE : 0)|
1049                              NEIGH_UPDATE_F_OVERRIDE_ISROUTER|
1050                              (msg->icmph.icmp6_router ? NEIGH_UPDATE_F_ISROUTER : 0),
1051                              NDISC_NEIGHBOUR_ADVERTISEMENT, &ndopts);
1052
1053                 if ((old_flags & ~neigh->flags) & NTF_ROUTER) {
1054                         /*
1055                          * Change: router to host
1056                          */
1057                         rt6_clean_tohost(dev_net(dev),  saddr);
1058                 }
1059
1060 out:
1061                 neigh_release(neigh);
1062         }
1063 }
1064
1065 static void ndisc_recv_rs(struct sk_buff *skb)
1066 {
1067         struct rs_msg *rs_msg = (struct rs_msg *)skb_transport_header(skb);
1068         unsigned long ndoptlen = skb->len - sizeof(*rs_msg);
1069         struct neighbour *neigh;
1070         struct inet6_dev *idev;
1071         const struct in6_addr *saddr = &ipv6_hdr(skb)->saddr;
1072         struct ndisc_options ndopts;
1073         u8 *lladdr = NULL;
1074
1075         if (skb->len < sizeof(*rs_msg))
1076                 return;
1077
1078         idev = __in6_dev_get(skb->dev);
1079         if (!idev) {
1080                 ND_PRINTK(1, err, "RS: can't find in6 device\n");
1081                 return;
1082         }
1083
1084         /* Don't accept RS if we're not in router mode */
1085         if (!idev->cnf.forwarding)
1086                 goto out;
1087
1088         /*
1089          * Don't update NCE if src = ::;
1090          * this implies that the source node has no ip address assigned yet.
1091          */
1092         if (ipv6_addr_any(saddr))
1093                 goto out;
1094
1095         /* Parse ND options */
1096         if (!ndisc_parse_options(skb->dev, rs_msg->opt, ndoptlen, &ndopts)) {
1097                 ND_PRINTK(2, notice, "NS: invalid ND option, ignored\n");
1098                 goto out;
1099         }
1100
1101         if (ndopts.nd_opts_src_lladdr) {
1102                 lladdr = ndisc_opt_addr_data(ndopts.nd_opts_src_lladdr,
1103                                              skb->dev);
1104                 if (!lladdr)
1105                         goto out;
1106         }
1107
1108         neigh = __neigh_lookup(&nd_tbl, saddr, skb->dev, 1);
1109         if (neigh) {
1110                 ndisc_update(skb->dev, neigh, lladdr, NUD_STALE,
1111                              NEIGH_UPDATE_F_WEAK_OVERRIDE|
1112                              NEIGH_UPDATE_F_OVERRIDE|
1113                              NEIGH_UPDATE_F_OVERRIDE_ISROUTER,
1114                              NDISC_ROUTER_SOLICITATION, &ndopts);
1115                 neigh_release(neigh);
1116         }
1117 out:
1118         return;
1119 }
1120
1121 static void ndisc_ra_useropt(struct sk_buff *ra, struct nd_opt_hdr *opt)
1122 {
1123         struct icmp6hdr *icmp6h = (struct icmp6hdr *)skb_transport_header(ra);
1124         struct sk_buff *skb;
1125         struct nlmsghdr *nlh;
1126         struct nduseroptmsg *ndmsg;
1127         struct net *net = dev_net(ra->dev);
1128         int err;
1129         int base_size = NLMSG_ALIGN(sizeof(struct nduseroptmsg)
1130                                     + (opt->nd_opt_len << 3));
1131         size_t msg_size = base_size + nla_total_size(sizeof(struct in6_addr));
1132
1133         skb = nlmsg_new(msg_size, GFP_ATOMIC);
1134         if (!skb) {
1135                 err = -ENOBUFS;
1136                 goto errout;
1137         }
1138
1139         nlh = nlmsg_put(skb, 0, 0, RTM_NEWNDUSEROPT, base_size, 0);
1140         if (!nlh) {
1141                 goto nla_put_failure;
1142         }
1143
1144         ndmsg = nlmsg_data(nlh);
1145         ndmsg->nduseropt_family = AF_INET6;
1146         ndmsg->nduseropt_ifindex = ra->dev->ifindex;
1147         ndmsg->nduseropt_icmp_type = icmp6h->icmp6_type;
1148         ndmsg->nduseropt_icmp_code = icmp6h->icmp6_code;
1149         ndmsg->nduseropt_opts_len = opt->nd_opt_len << 3;
1150
1151         memcpy(ndmsg + 1, opt, opt->nd_opt_len << 3);
1152
1153         if (nla_put_in6_addr(skb, NDUSEROPT_SRCADDR, &ipv6_hdr(ra)->saddr))
1154                 goto nla_put_failure;
1155         nlmsg_end(skb, nlh);
1156
1157         rtnl_notify(skb, net, 0, RTNLGRP_ND_USEROPT, NULL, GFP_ATOMIC);
1158         return;
1159
1160 nla_put_failure:
1161         nlmsg_free(skb);
1162         err = -EMSGSIZE;
1163 errout:
1164         rtnl_set_sk_err(net, RTNLGRP_ND_USEROPT, err);
1165 }
1166
1167 static void ndisc_router_discovery(struct sk_buff *skb)
1168 {
1169         struct ra_msg *ra_msg = (struct ra_msg *)skb_transport_header(skb);
1170         struct neighbour *neigh = NULL;
1171         struct inet6_dev *in6_dev;
1172         struct fib6_info *rt = NULL;
1173         struct net *net;
1174         int lifetime;
1175         struct ndisc_options ndopts;
1176         int optlen;
1177         unsigned int pref = 0;
1178         __u32 old_if_flags;
1179         bool send_ifinfo_notify = false;
1180
1181         __u8 *opt = (__u8 *)(ra_msg + 1);
1182
1183         optlen = (skb_tail_pointer(skb) - skb_transport_header(skb)) -
1184                 sizeof(struct ra_msg);
1185
1186         ND_PRINTK(2, info,
1187                   "RA: %s, dev: %s\n",
1188                   __func__, skb->dev->name);
1189         if (!(ipv6_addr_type(&ipv6_hdr(skb)->saddr) & IPV6_ADDR_LINKLOCAL)) {
1190                 ND_PRINTK(2, warn, "RA: source address is not link-local\n");
1191                 return;
1192         }
1193         if (optlen < 0) {
1194                 ND_PRINTK(2, warn, "RA: packet too short\n");
1195                 return;
1196         }
1197
1198 #ifdef CONFIG_IPV6_NDISC_NODETYPE
1199         if (skb->ndisc_nodetype == NDISC_NODETYPE_HOST) {
1200                 ND_PRINTK(2, warn, "RA: from host or unauthorized router\n");
1201                 return;
1202         }
1203 #endif
1204
1205         /*
1206          *      set the RA_RECV flag in the interface
1207          */
1208
1209         in6_dev = __in6_dev_get(skb->dev);
1210         if (!in6_dev) {
1211                 ND_PRINTK(0, err, "RA: can't find inet6 device for %s\n",
1212                           skb->dev->name);
1213                 return;
1214         }
1215
1216         if (!ndisc_parse_options(skb->dev, opt, optlen, &ndopts)) {
1217                 ND_PRINTK(2, warn, "RA: invalid ND options\n");
1218                 return;
1219         }
1220
1221         if (!ipv6_accept_ra(in6_dev)) {
1222                 ND_PRINTK(2, info,
1223                           "RA: %s, did not accept ra for dev: %s\n",
1224                           __func__, skb->dev->name);
1225                 goto skip_linkparms;
1226         }
1227
1228 #ifdef CONFIG_IPV6_NDISC_NODETYPE
1229         /* skip link-specific parameters from interior routers */
1230         if (skb->ndisc_nodetype == NDISC_NODETYPE_NODEFAULT) {
1231                 ND_PRINTK(2, info,
1232                           "RA: %s, nodetype is NODEFAULT, dev: %s\n",
1233                           __func__, skb->dev->name);
1234                 goto skip_linkparms;
1235         }
1236 #endif
1237
1238         if (in6_dev->if_flags & IF_RS_SENT) {
1239                 /*
1240                  *      flag that an RA was received after an RS was sent
1241                  *      out on this interface.
1242                  */
1243                 in6_dev->if_flags |= IF_RA_RCVD;
1244         }
1245
1246         /*
1247          * Remember the managed/otherconf flags from most recently
1248          * received RA message (RFC 2462) -- yoshfuji
1249          */
1250         old_if_flags = in6_dev->if_flags;
1251         in6_dev->if_flags = (in6_dev->if_flags & ~(IF_RA_MANAGED |
1252                                 IF_RA_OTHERCONF)) |
1253                                 (ra_msg->icmph.icmp6_addrconf_managed ?
1254                                         IF_RA_MANAGED : 0) |
1255                                 (ra_msg->icmph.icmp6_addrconf_other ?
1256                                         IF_RA_OTHERCONF : 0);
1257
1258         if (old_if_flags != in6_dev->if_flags)
1259                 send_ifinfo_notify = true;
1260
1261         if (!in6_dev->cnf.accept_ra_defrtr) {
1262                 ND_PRINTK(2, info,
1263                           "RA: %s, defrtr is false for dev: %s\n",
1264                           __func__, skb->dev->name);
1265                 goto skip_defrtr;
1266         }
1267
1268         /* Do not accept RA with source-addr found on local machine unless
1269          * accept_ra_from_local is set to true.
1270          */
1271         net = dev_net(in6_dev->dev);
1272         if (!in6_dev->cnf.accept_ra_from_local &&
1273             ipv6_chk_addr(net, &ipv6_hdr(skb)->saddr, in6_dev->dev, 0)) {
1274                 ND_PRINTK(2, info,
1275                           "RA from local address detected on dev: %s: default router ignored\n",
1276                           skb->dev->name);
1277                 goto skip_defrtr;
1278         }
1279
1280         lifetime = ntohs(ra_msg->icmph.icmp6_rt_lifetime);
1281
1282 #ifdef CONFIG_IPV6_ROUTER_PREF
1283         pref = ra_msg->icmph.icmp6_router_pref;
1284         /* 10b is handled as if it were 00b (medium) */
1285         if (pref == ICMPV6_ROUTER_PREF_INVALID ||
1286             !in6_dev->cnf.accept_ra_rtr_pref)
1287                 pref = ICMPV6_ROUTER_PREF_MEDIUM;
1288 #endif
1289         /* routes added from RAs do not use nexthop objects */
1290         rt = rt6_get_dflt_router(net, &ipv6_hdr(skb)->saddr, skb->dev);
1291         if (rt) {
1292                 neigh = ip6_neigh_lookup(&rt->fib6_nh->fib_nh_gw6,
1293                                          rt->fib6_nh->fib_nh_dev, NULL,
1294                                           &ipv6_hdr(skb)->saddr);
1295                 if (!neigh) {
1296                         ND_PRINTK(0, err,
1297                                   "RA: %s got default router without neighbour\n",
1298                                   __func__);
1299                         fib6_info_release(rt);
1300                         return;
1301                 }
1302         }
1303         if (rt && lifetime == 0) {
1304                 ip6_del_rt(net, rt);
1305                 rt = NULL;
1306         }
1307
1308         ND_PRINTK(3, info, "RA: rt: %p  lifetime: %d, for dev: %s\n",
1309                   rt, lifetime, skb->dev->name);
1310         if (!rt && lifetime) {
1311                 ND_PRINTK(3, info, "RA: adding default router\n");
1312
1313                 rt = rt6_add_dflt_router(net, &ipv6_hdr(skb)->saddr,
1314                                          skb->dev, pref);
1315                 if (!rt) {
1316                         ND_PRINTK(0, err,
1317                                   "RA: %s failed to add default route\n",
1318                                   __func__);
1319                         return;
1320                 }
1321
1322                 neigh = ip6_neigh_lookup(&rt->fib6_nh->fib_nh_gw6,
1323                                          rt->fib6_nh->fib_nh_dev, NULL,
1324                                           &ipv6_hdr(skb)->saddr);
1325                 if (!neigh) {
1326                         ND_PRINTK(0, err,
1327                                   "RA: %s got default router without neighbour\n",
1328                                   __func__);
1329                         fib6_info_release(rt);
1330                         return;
1331                 }
1332                 neigh->flags |= NTF_ROUTER;
1333         } else if (rt) {
1334                 rt->fib6_flags = (rt->fib6_flags & ~RTF_PREF_MASK) | RTF_PREF(pref);
1335         }
1336
1337         if (rt)
1338                 fib6_set_expires(rt, jiffies + (HZ * lifetime));
1339         if (in6_dev->cnf.accept_ra_min_hop_limit < 256 &&
1340             ra_msg->icmph.icmp6_hop_limit) {
1341                 if (in6_dev->cnf.accept_ra_min_hop_limit <= ra_msg->icmph.icmp6_hop_limit) {
1342                         in6_dev->cnf.hop_limit = ra_msg->icmph.icmp6_hop_limit;
1343                         fib6_metric_set(rt, RTAX_HOPLIMIT,
1344                                         ra_msg->icmph.icmp6_hop_limit);
1345                 } else {
1346                         ND_PRINTK(2, warn, "RA: Got route advertisement with lower hop_limit than minimum\n");
1347                 }
1348         }
1349
1350 skip_defrtr:
1351
1352         /*
1353          *      Update Reachable Time and Retrans Timer
1354          */
1355
1356         if (in6_dev->nd_parms) {
1357                 unsigned long rtime = ntohl(ra_msg->retrans_timer);
1358
1359                 if (rtime && rtime/1000 < MAX_SCHEDULE_TIMEOUT/HZ) {
1360                         rtime = (rtime*HZ)/1000;
1361                         if (rtime < HZ/10)
1362                                 rtime = HZ/10;
1363                         NEIGH_VAR_SET(in6_dev->nd_parms, RETRANS_TIME, rtime);
1364                         in6_dev->tstamp = jiffies;
1365                         send_ifinfo_notify = true;
1366                 }
1367
1368                 rtime = ntohl(ra_msg->reachable_time);
1369                 if (rtime && rtime/1000 < MAX_SCHEDULE_TIMEOUT/(3*HZ)) {
1370                         rtime = (rtime*HZ)/1000;
1371
1372                         if (rtime < HZ/10)
1373                                 rtime = HZ/10;
1374
1375                         if (rtime != NEIGH_VAR(in6_dev->nd_parms, BASE_REACHABLE_TIME)) {
1376                                 NEIGH_VAR_SET(in6_dev->nd_parms,
1377                                               BASE_REACHABLE_TIME, rtime);
1378                                 NEIGH_VAR_SET(in6_dev->nd_parms,
1379                                               GC_STALETIME, 3 * rtime);
1380                                 in6_dev->nd_parms->reachable_time = neigh_rand_reach_time(rtime);
1381                                 in6_dev->tstamp = jiffies;
1382                                 send_ifinfo_notify = true;
1383                         }
1384                 }
1385         }
1386
1387         /*
1388          *      Send a notify if RA changed managed/otherconf flags or timer settings
1389          */
1390         if (send_ifinfo_notify)
1391                 inet6_ifinfo_notify(RTM_NEWLINK, in6_dev);
1392
1393 skip_linkparms:
1394
1395         /*
1396          *      Process options.
1397          */
1398
1399         if (!neigh)
1400                 neigh = __neigh_lookup(&nd_tbl, &ipv6_hdr(skb)->saddr,
1401                                        skb->dev, 1);
1402         if (neigh) {
1403                 u8 *lladdr = NULL;
1404                 if (ndopts.nd_opts_src_lladdr) {
1405                         lladdr = ndisc_opt_addr_data(ndopts.nd_opts_src_lladdr,
1406                                                      skb->dev);
1407                         if (!lladdr) {
1408                                 ND_PRINTK(2, warn,
1409                                           "RA: invalid link-layer address length\n");
1410                                 goto out;
1411                         }
1412                 }
1413                 ndisc_update(skb->dev, neigh, lladdr, NUD_STALE,
1414                              NEIGH_UPDATE_F_WEAK_OVERRIDE|
1415                              NEIGH_UPDATE_F_OVERRIDE|
1416                              NEIGH_UPDATE_F_OVERRIDE_ISROUTER|
1417                              NEIGH_UPDATE_F_ISROUTER,
1418                              NDISC_ROUTER_ADVERTISEMENT, &ndopts);
1419         }
1420
1421         if (!ipv6_accept_ra(in6_dev)) {
1422                 ND_PRINTK(2, info,
1423                           "RA: %s, accept_ra is false for dev: %s\n",
1424                           __func__, skb->dev->name);
1425                 goto out;
1426         }
1427
1428 #ifdef CONFIG_IPV6_ROUTE_INFO
1429         if (!in6_dev->cnf.accept_ra_from_local &&
1430             ipv6_chk_addr(dev_net(in6_dev->dev), &ipv6_hdr(skb)->saddr,
1431                           in6_dev->dev, 0)) {
1432                 ND_PRINTK(2, info,
1433                           "RA from local address detected on dev: %s: router info ignored.\n",
1434                           skb->dev->name);
1435                 goto skip_routeinfo;
1436         }
1437
1438         if (in6_dev->cnf.accept_ra_rtr_pref && ndopts.nd_opts_ri) {
1439                 struct nd_opt_hdr *p;
1440                 for (p = ndopts.nd_opts_ri;
1441                      p;
1442                      p = ndisc_next_option(p, ndopts.nd_opts_ri_end)) {
1443                         struct route_info *ri = (struct route_info *)p;
1444 #ifdef CONFIG_IPV6_NDISC_NODETYPE
1445                         if (skb->ndisc_nodetype == NDISC_NODETYPE_NODEFAULT &&
1446                             ri->prefix_len == 0)
1447                                 continue;
1448 #endif
1449                         if (ri->prefix_len == 0 &&
1450                             !in6_dev->cnf.accept_ra_defrtr)
1451                                 continue;
1452                         if (ri->prefix_len < in6_dev->cnf.accept_ra_rt_info_min_plen)
1453                                 continue;
1454                         if (ri->prefix_len > in6_dev->cnf.accept_ra_rt_info_max_plen)
1455                                 continue;
1456                         rt6_route_rcv(skb->dev, (u8 *)p, (p->nd_opt_len) << 3,
1457                                       &ipv6_hdr(skb)->saddr);
1458                 }
1459         }
1460
1461 skip_routeinfo:
1462 #endif
1463
1464 #ifdef CONFIG_IPV6_NDISC_NODETYPE
1465         /* skip link-specific ndopts from interior routers */
1466         if (skb->ndisc_nodetype == NDISC_NODETYPE_NODEFAULT) {
1467                 ND_PRINTK(2, info,
1468                           "RA: %s, nodetype is NODEFAULT (interior routes), dev: %s\n",
1469                           __func__, skb->dev->name);
1470                 goto out;
1471         }
1472 #endif
1473
1474         if (in6_dev->cnf.accept_ra_pinfo && ndopts.nd_opts_pi) {
1475                 struct nd_opt_hdr *p;
1476                 for (p = ndopts.nd_opts_pi;
1477                      p;
1478                      p = ndisc_next_option(p, ndopts.nd_opts_pi_end)) {
1479                         addrconf_prefix_rcv(skb->dev, (u8 *)p,
1480                                             (p->nd_opt_len) << 3,
1481                                             ndopts.nd_opts_src_lladdr != NULL);
1482                 }
1483         }
1484
1485         if (ndopts.nd_opts_mtu && in6_dev->cnf.accept_ra_mtu) {
1486                 __be32 n;
1487                 u32 mtu;
1488
1489                 memcpy(&n, ((u8 *)(ndopts.nd_opts_mtu+1))+2, sizeof(mtu));
1490                 mtu = ntohl(n);
1491
1492                 if (mtu < IPV6_MIN_MTU || mtu > skb->dev->mtu) {
1493                         ND_PRINTK(2, warn, "RA: invalid mtu: %d\n", mtu);
1494                 } else if (in6_dev->cnf.mtu6 != mtu) {
1495                         in6_dev->cnf.mtu6 = mtu;
1496                         fib6_metric_set(rt, RTAX_MTU, mtu);
1497                         rt6_mtu_change(skb->dev, mtu);
1498                 }
1499         }
1500
1501         if (ndopts.nd_useropts) {
1502                 struct nd_opt_hdr *p;
1503                 for (p = ndopts.nd_useropts;
1504                      p;
1505                      p = ndisc_next_useropt(skb->dev, p,
1506                                             ndopts.nd_useropts_end)) {
1507                         ndisc_ra_useropt(skb, p);
1508                 }
1509         }
1510
1511         if (ndopts.nd_opts_tgt_lladdr || ndopts.nd_opts_rh) {
1512                 ND_PRINTK(2, warn, "RA: invalid RA options\n");
1513         }
1514 out:
1515         fib6_info_release(rt);
1516         if (neigh)
1517                 neigh_release(neigh);
1518 }
1519
1520 static void ndisc_redirect_rcv(struct sk_buff *skb)
1521 {
1522         u8 *hdr;
1523         struct ndisc_options ndopts;
1524         struct rd_msg *msg = (struct rd_msg *)skb_transport_header(skb);
1525         u32 ndoptlen = skb_tail_pointer(skb) - (skb_transport_header(skb) +
1526                                     offsetof(struct rd_msg, opt));
1527
1528 #ifdef CONFIG_IPV6_NDISC_NODETYPE
1529         switch (skb->ndisc_nodetype) {
1530         case NDISC_NODETYPE_HOST:
1531         case NDISC_NODETYPE_NODEFAULT:
1532                 ND_PRINTK(2, warn,
1533                           "Redirect: from host or unauthorized router\n");
1534                 return;
1535         }
1536 #endif
1537
1538         if (!(ipv6_addr_type(&ipv6_hdr(skb)->saddr) & IPV6_ADDR_LINKLOCAL)) {
1539                 ND_PRINTK(2, warn,
1540                           "Redirect: source address is not link-local\n");
1541                 return;
1542         }
1543
1544         if (!ndisc_parse_options(skb->dev, msg->opt, ndoptlen, &ndopts))
1545                 return;
1546
1547         if (!ndopts.nd_opts_rh) {
1548                 ip6_redirect_no_header(skb, dev_net(skb->dev),
1549                                         skb->dev->ifindex);
1550                 return;
1551         }
1552
1553         hdr = (u8 *)ndopts.nd_opts_rh;
1554         hdr += 8;
1555         if (!pskb_pull(skb, hdr - skb_transport_header(skb)))
1556                 return;
1557
1558         icmpv6_notify(skb, NDISC_REDIRECT, 0, 0);
1559 }
1560
1561 static void ndisc_fill_redirect_hdr_option(struct sk_buff *skb,
1562                                            struct sk_buff *orig_skb,
1563                                            int rd_len)
1564 {
1565         u8 *opt = skb_put(skb, rd_len);
1566
1567         memset(opt, 0, 8);
1568         *(opt++) = ND_OPT_REDIRECT_HDR;
1569         *(opt++) = (rd_len >> 3);
1570         opt += 6;
1571
1572         skb_copy_bits(orig_skb, skb_network_offset(orig_skb), opt,
1573                       rd_len - 8);
1574 }
1575
1576 void ndisc_send_redirect(struct sk_buff *skb, const struct in6_addr *target)
1577 {
1578         struct net_device *dev = skb->dev;
1579         struct net *net = dev_net(dev);
1580         struct sock *sk = net->ipv6.ndisc_sk;
1581         int optlen = 0;
1582         struct inet_peer *peer;
1583         struct sk_buff *buff;
1584         struct rd_msg *msg;
1585         struct in6_addr saddr_buf;
1586         struct rt6_info *rt;
1587         struct dst_entry *dst;
1588         struct flowi6 fl6;
1589         int rd_len;
1590         u8 ha_buf[MAX_ADDR_LEN], *ha = NULL,
1591            ops_data_buf[NDISC_OPS_REDIRECT_DATA_SPACE], *ops_data = NULL;
1592         bool ret;
1593
1594         if (netif_is_l3_master(skb->dev)) {
1595                 dev = __dev_get_by_index(dev_net(skb->dev), IPCB(skb)->iif);
1596                 if (!dev)
1597                         return;
1598         }
1599
1600         if (ipv6_get_lladdr(dev, &saddr_buf, IFA_F_TENTATIVE)) {
1601                 ND_PRINTK(2, warn, "Redirect: no link-local address on %s\n",
1602                           dev->name);
1603                 return;
1604         }
1605
1606         if (!ipv6_addr_equal(&ipv6_hdr(skb)->daddr, target) &&
1607             ipv6_addr_type(target) != (IPV6_ADDR_UNICAST|IPV6_ADDR_LINKLOCAL)) {
1608                 ND_PRINTK(2, warn,
1609                           "Redirect: target address is not link-local unicast\n");
1610                 return;
1611         }
1612
1613         icmpv6_flow_init(sk, &fl6, NDISC_REDIRECT,
1614                          &saddr_buf, &ipv6_hdr(skb)->saddr, dev->ifindex);
1615
1616         dst = ip6_route_output(net, NULL, &fl6);
1617         if (dst->error) {
1618                 dst_release(dst);
1619                 return;
1620         }
1621         dst = xfrm_lookup(net, dst, flowi6_to_flowi(&fl6), NULL, 0);
1622         if (IS_ERR(dst))
1623                 return;
1624
1625         rt = (struct rt6_info *) dst;
1626
1627         if (rt->rt6i_flags & RTF_GATEWAY) {
1628                 ND_PRINTK(2, warn,
1629                           "Redirect: destination is not a neighbour\n");
1630                 goto release;
1631         }
1632         peer = inet_getpeer_v6(net->ipv6.peers, &ipv6_hdr(skb)->saddr, 1);
1633         ret = inet_peer_xrlim_allow(peer, 1*HZ);
1634         if (peer)
1635                 inet_putpeer(peer);
1636         if (!ret)
1637                 goto release;
1638
1639         if (dev->addr_len) {
1640                 struct neighbour *neigh = dst_neigh_lookup(skb_dst(skb), target);
1641                 if (!neigh) {
1642                         ND_PRINTK(2, warn,
1643                                   "Redirect: no neigh for target address\n");
1644                         goto release;
1645                 }
1646
1647                 read_lock_bh(&neigh->lock);
1648                 if (neigh->nud_state & NUD_VALID) {
1649                         memcpy(ha_buf, neigh->ha, dev->addr_len);
1650                         read_unlock_bh(&neigh->lock);
1651                         ha = ha_buf;
1652                         optlen += ndisc_redirect_opt_addr_space(dev, neigh,
1653                                                                 ops_data_buf,
1654                                                                 &ops_data);
1655                 } else
1656                         read_unlock_bh(&neigh->lock);
1657
1658                 neigh_release(neigh);
1659         }
1660
1661         rd_len = min_t(unsigned int,
1662                        IPV6_MIN_MTU - sizeof(struct ipv6hdr) - sizeof(*msg) - optlen,
1663                        skb->len + 8);
1664         rd_len &= ~0x7;
1665         optlen += rd_len;
1666
1667         buff = ndisc_alloc_skb(dev, sizeof(*msg) + optlen);
1668         if (!buff)
1669                 goto release;
1670
1671         msg = skb_put(buff, sizeof(*msg));
1672         *msg = (struct rd_msg) {
1673                 .icmph = {
1674                         .icmp6_type = NDISC_REDIRECT,
1675                 },
1676                 .target = *target,
1677                 .dest = ipv6_hdr(skb)->daddr,
1678         };
1679
1680         /*
1681          *      include target_address option
1682          */
1683
1684         if (ha)
1685                 ndisc_fill_redirect_addr_option(buff, ha, ops_data);
1686
1687         /*
1688          *      build redirect option and copy skb over to the new packet.
1689          */
1690
1691         if (rd_len)
1692                 ndisc_fill_redirect_hdr_option(buff, skb, rd_len);
1693
1694         skb_dst_set(buff, dst);
1695         ndisc_send_skb(buff, &ipv6_hdr(skb)->saddr, &saddr_buf);
1696         return;
1697
1698 release:
1699         dst_release(dst);
1700 }
1701
1702 static void pndisc_redo(struct sk_buff *skb)
1703 {
1704         ndisc_recv_ns(skb);
1705         kfree_skb(skb);
1706 }
1707
1708 static bool ndisc_suppress_frag_ndisc(struct sk_buff *skb)
1709 {
1710         struct inet6_dev *idev = __in6_dev_get(skb->dev);
1711
1712         if (!idev)
1713                 return true;
1714         if (IP6CB(skb)->flags & IP6SKB_FRAGMENTED &&
1715             idev->cnf.suppress_frag_ndisc) {
1716                 net_warn_ratelimited("Received fragmented ndisc packet. Carefully consider disabling suppress_frag_ndisc.\n");
1717                 return true;
1718         }
1719         return false;
1720 }
1721
1722 int ndisc_rcv(struct sk_buff *skb)
1723 {
1724         struct nd_msg *msg;
1725
1726         if (ndisc_suppress_frag_ndisc(skb))
1727                 return 0;
1728
1729         if (skb_linearize(skb))
1730                 return 0;
1731
1732         msg = (struct nd_msg *)skb_transport_header(skb);
1733
1734         __skb_push(skb, skb->data - skb_transport_header(skb));
1735
1736         if (ipv6_hdr(skb)->hop_limit != 255) {
1737                 ND_PRINTK(2, warn, "NDISC: invalid hop-limit: %d\n",
1738                           ipv6_hdr(skb)->hop_limit);
1739                 return 0;
1740         }
1741
1742         if (msg->icmph.icmp6_code != 0) {
1743                 ND_PRINTK(2, warn, "NDISC: invalid ICMPv6 code: %d\n",
1744                           msg->icmph.icmp6_code);
1745                 return 0;
1746         }
1747
1748         switch (msg->icmph.icmp6_type) {
1749         case NDISC_NEIGHBOUR_SOLICITATION:
1750                 memset(NEIGH_CB(skb), 0, sizeof(struct neighbour_cb));
1751                 ndisc_recv_ns(skb);
1752                 break;
1753
1754         case NDISC_NEIGHBOUR_ADVERTISEMENT:
1755                 ndisc_recv_na(skb);
1756                 break;
1757
1758         case NDISC_ROUTER_SOLICITATION:
1759                 ndisc_recv_rs(skb);
1760                 break;
1761
1762         case NDISC_ROUTER_ADVERTISEMENT:
1763                 ndisc_router_discovery(skb);
1764                 break;
1765
1766         case NDISC_REDIRECT:
1767                 ndisc_redirect_rcv(skb);
1768                 break;
1769         }
1770
1771         return 0;
1772 }
1773
1774 static int ndisc_netdev_event(struct notifier_block *this, unsigned long event, void *ptr)
1775 {
1776         struct net_device *dev = netdev_notifier_info_to_dev(ptr);
1777         struct netdev_notifier_change_info *change_info;
1778         struct net *net = dev_net(dev);
1779         struct inet6_dev *idev;
1780
1781         switch (event) {
1782         case NETDEV_CHANGEADDR:
1783                 neigh_changeaddr(&nd_tbl, dev);
1784                 fib6_run_gc(0, net, false);
1785                 /* fallthrough */
1786         case NETDEV_UP:
1787                 idev = in6_dev_get(dev);
1788                 if (!idev)
1789                         break;
1790                 if (idev->cnf.ndisc_notify ||
1791                     net->ipv6.devconf_all->ndisc_notify)
1792                         ndisc_send_unsol_na(dev);
1793                 in6_dev_put(idev);
1794                 break;
1795         case NETDEV_CHANGE:
1796                 change_info = ptr;
1797                 if (change_info->flags_changed & IFF_NOARP)
1798                         neigh_changeaddr(&nd_tbl, dev);
1799                 if (!netif_carrier_ok(dev))
1800                         neigh_carrier_down(&nd_tbl, dev);
1801                 break;
1802         case NETDEV_DOWN:
1803                 neigh_ifdown(&nd_tbl, dev);
1804                 fib6_run_gc(0, net, false);
1805                 break;
1806         case NETDEV_NOTIFY_PEERS:
1807                 ndisc_send_unsol_na(dev);
1808                 break;
1809         default:
1810                 break;
1811         }
1812
1813         return NOTIFY_DONE;
1814 }
1815
1816 static struct notifier_block ndisc_netdev_notifier = {
1817         .notifier_call = ndisc_netdev_event,
1818         .priority = ADDRCONF_NOTIFY_PRIORITY - 5,
1819 };
1820
1821 #ifdef CONFIG_SYSCTL
1822 static void ndisc_warn_deprecated_sysctl(struct ctl_table *ctl,
1823                                          const char *func, const char *dev_name)
1824 {
1825         static char warncomm[TASK_COMM_LEN];
1826         static int warned;
1827         if (strcmp(warncomm, current->comm) && warned < 5) {
1828                 strcpy(warncomm, current->comm);
1829                 pr_warn("process `%s' is using deprecated sysctl (%s) net.ipv6.neigh.%s.%s - use net.ipv6.neigh.%s.%s_ms instead\n",
1830                         warncomm, func,
1831                         dev_name, ctl->procname,
1832                         dev_name, ctl->procname);
1833                 warned++;
1834         }
1835 }
1836
1837 int ndisc_ifinfo_sysctl_change(struct ctl_table *ctl, int write, void __user *buffer, size_t *lenp, loff_t *ppos)
1838 {
1839         struct net_device *dev = ctl->extra1;
1840         struct inet6_dev *idev;
1841         int ret;
1842
1843         if ((strcmp(ctl->procname, "retrans_time") == 0) ||
1844             (strcmp(ctl->procname, "base_reachable_time") == 0))
1845                 ndisc_warn_deprecated_sysctl(ctl, "syscall", dev ? dev->name : "default");
1846
1847         if (strcmp(ctl->procname, "retrans_time") == 0)
1848                 ret = neigh_proc_dointvec(ctl, write, buffer, lenp, ppos);
1849
1850         else if (strcmp(ctl->procname, "base_reachable_time") == 0)
1851                 ret = neigh_proc_dointvec_jiffies(ctl, write,
1852                                                   buffer, lenp, ppos);
1853
1854         else if ((strcmp(ctl->procname, "retrans_time_ms") == 0) ||
1855                  (strcmp(ctl->procname, "base_reachable_time_ms") == 0))
1856                 ret = neigh_proc_dointvec_ms_jiffies(ctl, write,
1857                                                      buffer, lenp, ppos);
1858         else
1859                 ret = -1;
1860
1861         if (write && ret == 0 && dev && (idev = in6_dev_get(dev)) != NULL) {
1862                 if (ctl->data == &NEIGH_VAR(idev->nd_parms, BASE_REACHABLE_TIME))
1863                         idev->nd_parms->reachable_time =
1864                                         neigh_rand_reach_time(NEIGH_VAR(idev->nd_parms, BASE_REACHABLE_TIME));
1865                 idev->tstamp = jiffies;
1866                 inet6_ifinfo_notify(RTM_NEWLINK, idev);
1867                 in6_dev_put(idev);
1868         }
1869         return ret;
1870 }
1871
1872
1873 #endif
1874
1875 static int __net_init ndisc_net_init(struct net *net)
1876 {
1877         struct ipv6_pinfo *np;
1878         struct sock *sk;
1879         int err;
1880
1881         err = inet_ctl_sock_create(&sk, PF_INET6,
1882                                    SOCK_RAW, IPPROTO_ICMPV6, net);
1883         if (err < 0) {
1884                 ND_PRINTK(0, err,
1885                           "NDISC: Failed to initialize the control socket (err %d)\n",
1886                           err);
1887                 return err;
1888         }
1889
1890         net->ipv6.ndisc_sk = sk;
1891
1892         np = inet6_sk(sk);
1893         np->hop_limit = 255;
1894         /* Do not loopback ndisc messages */
1895         np->mc_loop = 0;
1896
1897         return 0;
1898 }
1899
1900 static void __net_exit ndisc_net_exit(struct net *net)
1901 {
1902         inet_ctl_sock_destroy(net->ipv6.ndisc_sk);
1903 }
1904
1905 static struct pernet_operations ndisc_net_ops = {
1906         .init = ndisc_net_init,
1907         .exit = ndisc_net_exit,
1908 };
1909
1910 int __init ndisc_init(void)
1911 {
1912         int err;
1913
1914         err = register_pernet_subsys(&ndisc_net_ops);
1915         if (err)
1916                 return err;
1917         /*
1918          * Initialize the neighbour table
1919          */
1920         neigh_table_init(NEIGH_ND_TABLE, &nd_tbl);
1921
1922 #ifdef CONFIG_SYSCTL
1923         err = neigh_sysctl_register(NULL, &nd_tbl.parms,
1924                                     ndisc_ifinfo_sysctl_change);
1925         if (err)
1926                 goto out_unregister_pernet;
1927 out:
1928 #endif
1929         return err;
1930
1931 #ifdef CONFIG_SYSCTL
1932 out_unregister_pernet:
1933         unregister_pernet_subsys(&ndisc_net_ops);
1934         goto out;
1935 #endif
1936 }
1937
1938 int __init ndisc_late_init(void)
1939 {
1940         return register_netdevice_notifier(&ndisc_netdev_notifier);
1941 }
1942
1943 void ndisc_late_cleanup(void)
1944 {
1945         unregister_netdevice_notifier(&ndisc_netdev_notifier);
1946 }
1947
1948 void ndisc_cleanup(void)
1949 {
1950 #ifdef CONFIG_SYSCTL
1951         neigh_sysctl_unregister(&nd_tbl.parms);
1952 #endif
1953         neigh_table_clear(NEIGH_ND_TABLE, &nd_tbl);
1954         unregister_pernet_subsys(&ndisc_net_ops);
1955 }