blob: 80316bb318c5a51a5dd62e2757e3f943ca7c846e [file] [log] [blame]
b.liue9582032025-04-17 19:18:16 +08001// SPDX-License-Identifier: GPL-2.0-or-later
2/*
3 * Linux IPv6 multicast routing support for BSD pim6sd
4 * Based on net/ipv4/ipmr.c.
5 *
6 * (c) 2004 Mickael Hoerdt, <hoerdt@clarinet.u-strasbg.fr>
7 * LSIIT Laboratory, Strasbourg, France
8 * (c) 2004 Jean-Philippe Andriot, <jean-philippe.andriot@6WIND.com>
9 * 6WIND, Paris, France
10 * Copyright (C)2007,2008 USAGI/WIDE Project
11 * YOSHIFUJI Hideaki <yoshfuji@linux-ipv6.org>
12 */
13
14#include <linux/uaccess.h>
15#include <linux/types.h>
16#include <linux/sched.h>
17#include <linux/errno.h>
18#include <linux/mm.h>
19#include <linux/kernel.h>
20#include <linux/fcntl.h>
21#include <linux/stat.h>
22#include <linux/socket.h>
23#include <linux/inet.h>
24#include <linux/netdevice.h>
25#include <linux/inetdevice.h>
26#include <linux/proc_fs.h>
27#include <linux/seq_file.h>
28#include <linux/init.h>
29#include <linux/compat.h>
30#include <linux/rhashtable.h>
31#include <net/protocol.h>
32#include <linux/skbuff.h>
33#include <net/raw.h>
34#include <linux/notifier.h>
35#include <linux/if_arp.h>
36#include <net/checksum.h>
37#include <net/netlink.h>
38#include <net/fib_rules.h>
39
40#include <net/ipv6.h>
41#include <net/ip6_route.h>
42#include <linux/mroute6.h>
43#include <linux/pim.h>
44#include <net/addrconf.h>
45#include <linux/netfilter_ipv6.h>
46#include <linux/export.h>
47#include <net/ip6_checksum.h>
48#include <linux/netconf.h>
49#include <net/ip_tunnels.h>
50
51#include <linux/nospec.h>
52
53struct ip6mr_rule {
54 struct fib_rule common;
55};
56
57struct ip6mr_result {
58 struct mr_table *mrt;
59};
60
61/* Big lock, protecting vif table, mrt cache and mroute socket state.
62 Note that the changes are semaphored via rtnl_lock.
63 */
64
65static DEFINE_RWLOCK(mrt_lock);
66
67/* Multicast router control variables */
68
69/* Special spinlock for queue of unresolved entries */
70static DEFINE_SPINLOCK(mfc_unres_lock);
71
72/* We return to original Alan's scheme. Hash table of resolved
73 entries is changed only in process context and protected
74 with weak lock mrt_lock. Queue of unresolved entries is protected
75 with strong spinlock mfc_unres_lock.
76
77 In this case data path is free of exclusive locks at all.
78 */
79
80static struct kmem_cache *mrt_cachep __read_mostly;
81
82static struct mr_table *ip6mr_new_table(struct net *net, u32 id);
83static void ip6mr_free_table(struct mr_table *mrt);
84
85static void ip6_mr_forward(struct net *net, struct mr_table *mrt,
86 struct net_device *dev, struct sk_buff *skb,
87 struct mfc6_cache *cache);
88static int ip6mr_cache_report(struct mr_table *mrt, struct sk_buff *pkt,
89 mifi_t mifi, int assert);
90static void mr6_netlink_event(struct mr_table *mrt, struct mfc6_cache *mfc,
91 int cmd);
92static void mrt6msg_netlink_event(struct mr_table *mrt, struct sk_buff *pkt);
93static int ip6mr_rtm_dumproute(struct sk_buff *skb,
94 struct netlink_callback *cb);
95static void mroute_clean_tables(struct mr_table *mrt, int flags);
96static void ipmr_expire_process(struct timer_list *t);
97
98#ifdef CONFIG_IPV6_MROUTE_MULTIPLE_TABLES
99#define ip6mr_for_each_table(mrt, net) \
100 list_for_each_entry_rcu(mrt, &net->ipv6.mr6_tables, list)
101
102static struct mr_table *ip6mr_mr_table_iter(struct net *net,
103 struct mr_table *mrt)
104{
105 struct mr_table *ret;
106
107 if (!mrt)
108 ret = list_entry_rcu(net->ipv6.mr6_tables.next,
109 struct mr_table, list);
110 else
111 ret = list_entry_rcu(mrt->list.next,
112 struct mr_table, list);
113
114 if (&ret->list == &net->ipv6.mr6_tables)
115 return NULL;
116 return ret;
117}
118
119static struct mr_table *ip6mr_get_table(struct net *net, u32 id)
120{
121 struct mr_table *mrt;
122
123 ip6mr_for_each_table(mrt, net) {
124 if (mrt->id == id)
125 return mrt;
126 }
127 return NULL;
128}
129
130static int ip6mr_fib_lookup(struct net *net, struct flowi6 *flp6,
131 struct mr_table **mrt)
132{
133 int err;
134 struct ip6mr_result res;
135 struct fib_lookup_arg arg = {
136 .result = &res,
137 .flags = FIB_LOOKUP_NOREF,
138 };
139
140 /* update flow if oif or iif point to device enslaved to l3mdev */
141 l3mdev_update_flow(net, flowi6_to_flowi(flp6));
142
143 err = fib_rules_lookup(net->ipv6.mr6_rules_ops,
144 flowi6_to_flowi(flp6), 0, &arg);
145 if (err < 0)
146 return err;
147 *mrt = res.mrt;
148 return 0;
149}
150
151static int ip6mr_rule_action(struct fib_rule *rule, struct flowi *flp,
152 int flags, struct fib_lookup_arg *arg)
153{
154 struct ip6mr_result *res = arg->result;
155 struct mr_table *mrt;
156
157 switch (rule->action) {
158 case FR_ACT_TO_TBL:
159 break;
160 case FR_ACT_UNREACHABLE:
161 return -ENETUNREACH;
162 case FR_ACT_PROHIBIT:
163 return -EACCES;
164 case FR_ACT_POLICY_FAILED:
165 return -EACCES;
166 case FR_ACT_BLACKHOLE:
167 default:
168 return -EINVAL;
169 }
170
171 arg->table = fib_rule_get_table(rule, arg);
172
173 mrt = ip6mr_get_table(rule->fr_net, arg->table);
174 if (!mrt)
175 return -EAGAIN;
176 res->mrt = mrt;
177 return 0;
178}
179
180static int ip6mr_rule_match(struct fib_rule *rule, struct flowi *flp, int flags)
181{
182 return 1;
183}
184
185static const struct nla_policy ip6mr_rule_policy[FRA_MAX + 1] = {
186 FRA_GENERIC_POLICY,
187};
188
189static int ip6mr_rule_configure(struct fib_rule *rule, struct sk_buff *skb,
190 struct fib_rule_hdr *frh, struct nlattr **tb,
191 struct netlink_ext_ack *extack)
192{
193 return 0;
194}
195
196static int ip6mr_rule_compare(struct fib_rule *rule, struct fib_rule_hdr *frh,
197 struct nlattr **tb)
198{
199 return 1;
200}
201
202static int ip6mr_rule_fill(struct fib_rule *rule, struct sk_buff *skb,
203 struct fib_rule_hdr *frh)
204{
205 frh->dst_len = 0;
206 frh->src_len = 0;
207 frh->tos = 0;
208 return 0;
209}
210
211static const struct fib_rules_ops __net_initconst ip6mr_rules_ops_template = {
212 .family = RTNL_FAMILY_IP6MR,
213 .rule_size = sizeof(struct ip6mr_rule),
214 .addr_size = sizeof(struct in6_addr),
215 .action = ip6mr_rule_action,
216 .match = ip6mr_rule_match,
217 .configure = ip6mr_rule_configure,
218 .compare = ip6mr_rule_compare,
219 .fill = ip6mr_rule_fill,
220 .nlgroup = RTNLGRP_IPV6_RULE,
221 .policy = ip6mr_rule_policy,
222 .owner = THIS_MODULE,
223};
224
225static int __net_init ip6mr_rules_init(struct net *net)
226{
227 struct fib_rules_ops *ops;
228 struct mr_table *mrt;
229 int err;
230
231 ops = fib_rules_register(&ip6mr_rules_ops_template, net);
232 if (IS_ERR(ops))
233 return PTR_ERR(ops);
234
235 INIT_LIST_HEAD(&net->ipv6.mr6_tables);
236
237 mrt = ip6mr_new_table(net, RT6_TABLE_DFLT);
238 if (IS_ERR(mrt)) {
239 err = PTR_ERR(mrt);
240 goto err1;
241 }
242
243 err = fib_default_rule_add(ops, 0x7fff, RT6_TABLE_DFLT, 0);
244 if (err < 0)
245 goto err2;
246
247 net->ipv6.mr6_rules_ops = ops;
248 return 0;
249
250err2:
251 rtnl_lock();
252 ip6mr_free_table(mrt);
253 rtnl_unlock();
254err1:
255 fib_rules_unregister(ops);
256 return err;
257}
258
259static void __net_exit ip6mr_rules_exit(struct net *net)
260{
261 struct mr_table *mrt, *next;
262
263 rtnl_lock();
264 list_for_each_entry_safe(mrt, next, &net->ipv6.mr6_tables, list) {
265 list_del(&mrt->list);
266 ip6mr_free_table(mrt);
267 }
268 fib_rules_unregister(net->ipv6.mr6_rules_ops);
269 rtnl_unlock();
270}
271
272static int ip6mr_rules_dump(struct net *net, struct notifier_block *nb)
273{
274 return fib_rules_dump(net, nb, RTNL_FAMILY_IP6MR);
275}
276
277static unsigned int ip6mr_rules_seq_read(struct net *net)
278{
279 return fib_rules_seq_read(net, RTNL_FAMILY_IP6MR);
280}
281
282bool ip6mr_rule_default(const struct fib_rule *rule)
283{
284 return fib_rule_matchall(rule) && rule->action == FR_ACT_TO_TBL &&
285 rule->table == RT6_TABLE_DFLT && !rule->l3mdev;
286}
287EXPORT_SYMBOL(ip6mr_rule_default);
288#else
289#define ip6mr_for_each_table(mrt, net) \
290 for (mrt = net->ipv6.mrt6; mrt; mrt = NULL)
291
292static struct mr_table *ip6mr_mr_table_iter(struct net *net,
293 struct mr_table *mrt)
294{
295 if (!mrt)
296 return net->ipv6.mrt6;
297 return NULL;
298}
299
300static struct mr_table *ip6mr_get_table(struct net *net, u32 id)
301{
302 return net->ipv6.mrt6;
303}
304
305static int ip6mr_fib_lookup(struct net *net, struct flowi6 *flp6,
306 struct mr_table **mrt)
307{
308 *mrt = net->ipv6.mrt6;
309 return 0;
310}
311
312static int __net_init ip6mr_rules_init(struct net *net)
313{
314 struct mr_table *mrt;
315
316 mrt = ip6mr_new_table(net, RT6_TABLE_DFLT);
317 if (IS_ERR(mrt))
318 return PTR_ERR(mrt);
319 net->ipv6.mrt6 = mrt;
320 return 0;
321}
322
323static void __net_exit ip6mr_rules_exit(struct net *net)
324{
325 rtnl_lock();
326 ip6mr_free_table(net->ipv6.mrt6);
327 net->ipv6.mrt6 = NULL;
328 rtnl_unlock();
329}
330
331static int ip6mr_rules_dump(struct net *net, struct notifier_block *nb)
332{
333 return 0;
334}
335
336static unsigned int ip6mr_rules_seq_read(struct net *net)
337{
338 return 0;
339}
340#endif
341
342static int ip6mr_hash_cmp(struct rhashtable_compare_arg *arg,
343 const void *ptr)
344{
345 const struct mfc6_cache_cmp_arg *cmparg = arg->key;
346 struct mfc6_cache *c = (struct mfc6_cache *)ptr;
347
348 return !ipv6_addr_equal(&c->mf6c_mcastgrp, &cmparg->mf6c_mcastgrp) ||
349 !ipv6_addr_equal(&c->mf6c_origin, &cmparg->mf6c_origin);
350}
351
352static const struct rhashtable_params ip6mr_rht_params = {
353 .head_offset = offsetof(struct mr_mfc, mnode),
354 .key_offset = offsetof(struct mfc6_cache, cmparg),
355 .key_len = sizeof(struct mfc6_cache_cmp_arg),
356 .nelem_hint = 3,
357 .obj_cmpfn = ip6mr_hash_cmp,
358 .automatic_shrinking = true,
359};
360
361static void ip6mr_new_table_set(struct mr_table *mrt,
362 struct net *net)
363{
364#ifdef CONFIG_IPV6_MROUTE_MULTIPLE_TABLES
365 list_add_tail_rcu(&mrt->list, &net->ipv6.mr6_tables);
366#endif
367}
368
369static struct mfc6_cache_cmp_arg ip6mr_mr_table_ops_cmparg_any = {
370 .mf6c_origin = IN6ADDR_ANY_INIT,
371 .mf6c_mcastgrp = IN6ADDR_ANY_INIT,
372};
373
374static struct mr_table_ops ip6mr_mr_table_ops = {
375 .rht_params = &ip6mr_rht_params,
376 .cmparg_any = &ip6mr_mr_table_ops_cmparg_any,
377};
378
379static struct mr_table *ip6mr_new_table(struct net *net, u32 id)
380{
381 struct mr_table *mrt;
382
383 mrt = ip6mr_get_table(net, id);
384 if (mrt)
385 return mrt;
386
387 return mr_table_alloc(net, id, &ip6mr_mr_table_ops,
388 ipmr_expire_process, ip6mr_new_table_set);
389}
390
391static void ip6mr_free_table(struct mr_table *mrt)
392{
393 del_timer_sync(&mrt->ipmr_expire_timer);
394 mroute_clean_tables(mrt, MRT6_FLUSH_MIFS | MRT6_FLUSH_MIFS_STATIC |
395 MRT6_FLUSH_MFC | MRT6_FLUSH_MFC_STATIC);
396 rhltable_destroy(&mrt->mfc_hash);
397 kfree(mrt);
398}
399
400#ifdef CONFIG_PROC_FS
401/* The /proc interfaces to multicast routing
402 * /proc/ip6_mr_cache /proc/ip6_mr_vif
403 */
404
405static void *ip6mr_vif_seq_start(struct seq_file *seq, loff_t *pos)
406 __acquires(RCU)
407{
408 struct mr_vif_iter *iter = seq->private;
409 struct net *net = seq_file_net(seq);
410 struct mr_table *mrt;
411
412 mrt = ip6mr_get_table(net, RT6_TABLE_DFLT);
413 if (!mrt)
414 return ERR_PTR(-ENOENT);
415
416 iter->mrt = mrt;
417
418 rcu_read_lock();
419 return mr_vif_seq_start(seq, pos);
420}
421
422static void ip6mr_vif_seq_stop(struct seq_file *seq, void *v)
423 __releases(RCU)
424{
425 rcu_read_unlock();
426}
427
428static int ip6mr_vif_seq_show(struct seq_file *seq, void *v)
429{
430 struct mr_vif_iter *iter = seq->private;
431 struct mr_table *mrt = iter->mrt;
432
433 if (v == SEQ_START_TOKEN) {
434 seq_puts(seq,
435 "Interface BytesIn PktsIn BytesOut PktsOut Flags\n");
436 } else {
437 const struct vif_device *vif = v;
438 const char *name = vif->dev ? vif->dev->name : "none";
439
440 seq_printf(seq,
441 "%2td %-10s %8ld %7ld %8ld %7ld %05X\n",
442 vif - mrt->vif_table,
443 name, vif->bytes_in, vif->pkt_in,
444 vif->bytes_out, vif->pkt_out,
445 vif->flags);
446 }
447 return 0;
448}
449
450static const struct seq_operations ip6mr_vif_seq_ops = {
451 .start = ip6mr_vif_seq_start,
452 .next = mr_vif_seq_next,
453 .stop = ip6mr_vif_seq_stop,
454 .show = ip6mr_vif_seq_show,
455};
456
457static void *ipmr_mfc_seq_start(struct seq_file *seq, loff_t *pos)
458{
459 struct net *net = seq_file_net(seq);
460 struct mr_table *mrt;
461
462 mrt = ip6mr_get_table(net, RT6_TABLE_DFLT);
463 if (!mrt)
464 return ERR_PTR(-ENOENT);
465
466 return mr_mfc_seq_start(seq, pos, mrt, &mfc_unres_lock);
467}
468
469static int ipmr_mfc_seq_show(struct seq_file *seq, void *v)
470{
471 int n;
472
473 if (v == SEQ_START_TOKEN) {
474 seq_puts(seq,
475 "Group "
476 "Origin "
477 "Iif Pkts Bytes Wrong Oifs\n");
478 } else {
479 const struct mfc6_cache *mfc = v;
480 const struct mr_mfc_iter *it = seq->private;
481 struct mr_table *mrt = it->mrt;
482
483 seq_printf(seq, "%pI6 %pI6 %-3hd",
484 &mfc->mf6c_mcastgrp, &mfc->mf6c_origin,
485 mfc->_c.mfc_parent);
486
487 if (it->cache != &mrt->mfc_unres_queue) {
488 seq_printf(seq, " %8lu %8lu %8lu",
489 mfc->_c.mfc_un.res.pkt,
490 mfc->_c.mfc_un.res.bytes,
491 mfc->_c.mfc_un.res.wrong_if);
492 for (n = mfc->_c.mfc_un.res.minvif;
493 n < mfc->_c.mfc_un.res.maxvif; n++) {
494 if (VIF_EXISTS(mrt, n) &&
495 mfc->_c.mfc_un.res.ttls[n] < 255)
496 seq_printf(seq,
497 " %2d:%-3d", n,
498 mfc->_c.mfc_un.res.ttls[n]);
499 }
500 } else {
501 /* unresolved mfc_caches don't contain
502 * pkt, bytes and wrong_if values
503 */
504 seq_printf(seq, " %8lu %8lu %8lu", 0ul, 0ul, 0ul);
505 }
506 seq_putc(seq, '\n');
507 }
508 return 0;
509}
510
511static const struct seq_operations ipmr_mfc_seq_ops = {
512 .start = ipmr_mfc_seq_start,
513 .next = mr_mfc_seq_next,
514 .stop = mr_mfc_seq_stop,
515 .show = ipmr_mfc_seq_show,
516};
517#endif
518
519#ifdef CONFIG_IPV6_PIMSM_V2
520
521static int pim6_rcv(struct sk_buff *skb)
522{
523 struct pimreghdr *pim;
524 struct ipv6hdr *encap;
525 struct net_device *reg_dev = NULL;
526 struct net *net = dev_net(skb->dev);
527 struct mr_table *mrt;
528 struct flowi6 fl6 = {
529 .flowi6_iif = skb->dev->ifindex,
530 .flowi6_mark = skb->mark,
531 };
532 int reg_vif_num;
533
534 if (!pskb_may_pull(skb, sizeof(*pim) + sizeof(*encap)))
535 goto drop;
536
537 pim = (struct pimreghdr *)skb_transport_header(skb);
538 if (pim->type != ((PIM_VERSION << 4) | PIM_TYPE_REGISTER) ||
539 (pim->flags & PIM_NULL_REGISTER) ||
540 (csum_ipv6_magic(&ipv6_hdr(skb)->saddr, &ipv6_hdr(skb)->daddr,
541 sizeof(*pim), IPPROTO_PIM,
542 csum_partial((void *)pim, sizeof(*pim), 0)) &&
543 csum_fold(skb_checksum(skb, 0, skb->len, 0))))
544 goto drop;
545
546 /* check if the inner packet is destined to mcast group */
547 encap = (struct ipv6hdr *)(skb_transport_header(skb) +
548 sizeof(*pim));
549
550 if (!ipv6_addr_is_multicast(&encap->daddr) ||
551 encap->payload_len == 0 ||
552 ntohs(encap->payload_len) + sizeof(*pim) > skb->len)
553 goto drop;
554
555 if (ip6mr_fib_lookup(net, &fl6, &mrt) < 0)
556 goto drop;
557 reg_vif_num = mrt->mroute_reg_vif_num;
558
559 read_lock(&mrt_lock);
560 if (reg_vif_num >= 0)
561 reg_dev = mrt->vif_table[reg_vif_num].dev;
562 if (reg_dev)
563 dev_hold(reg_dev);
564 read_unlock(&mrt_lock);
565
566 if (!reg_dev)
567 goto drop;
568
569 skb->mac_header = skb->network_header;
570 skb_pull(skb, (u8 *)encap - skb->data);
571 skb_reset_network_header(skb);
572 skb->protocol = htons(ETH_P_IPV6);
573 skb->ip_summed = CHECKSUM_NONE;
574
575 skb_tunnel_rx(skb, reg_dev, dev_net(reg_dev));
576
577 netif_rx(skb);
578
579 dev_put(reg_dev);
580 return 0;
581 drop:
582 kfree_skb(skb);
583 return 0;
584}
585
586static const struct inet6_protocol pim6_protocol = {
587 .handler = pim6_rcv,
588};
589
590/* Service routines creating virtual interfaces: PIMREG */
591
592static netdev_tx_t reg_vif_xmit(struct sk_buff *skb,
593 struct net_device *dev)
594{
595 struct net *net = dev_net(dev);
596 struct mr_table *mrt;
597 struct flowi6 fl6 = {
598 .flowi6_oif = dev->ifindex,
599 .flowi6_iif = skb->skb_iif ? : LOOPBACK_IFINDEX,
600 .flowi6_mark = skb->mark,
601 };
602
603 if (!pskb_inet_may_pull(skb))
604 goto tx_err;
605
606 if (ip6mr_fib_lookup(net, &fl6, &mrt) < 0)
607 goto tx_err;
608
609 read_lock(&mrt_lock);
610 dev->stats.tx_bytes += skb->len;
611 dev->stats.tx_packets++;
612 ip6mr_cache_report(mrt, skb, mrt->mroute_reg_vif_num, MRT6MSG_WHOLEPKT);
613 read_unlock(&mrt_lock);
614 kfree_skb(skb);
615 return NETDEV_TX_OK;
616
617tx_err:
618 dev->stats.tx_errors++;
619 kfree_skb(skb);
620 return NETDEV_TX_OK;
621}
622
623static int reg_vif_get_iflink(const struct net_device *dev)
624{
625 return 0;
626}
627
628static const struct net_device_ops reg_vif_netdev_ops = {
629 .ndo_start_xmit = reg_vif_xmit,
630 .ndo_get_iflink = reg_vif_get_iflink,
631};
632
633static void reg_vif_setup(struct net_device *dev)
634{
635 dev->type = ARPHRD_PIMREG;
636 dev->mtu = 1500 - sizeof(struct ipv6hdr) - 8;
637 dev->flags = IFF_NOARP;
638 dev->netdev_ops = &reg_vif_netdev_ops;
639 dev->needs_free_netdev = true;
640 dev->features |= NETIF_F_NETNS_LOCAL;
641}
642
643static struct net_device *ip6mr_reg_vif(struct net *net, struct mr_table *mrt)
644{
645 struct net_device *dev;
646 char name[IFNAMSIZ];
647
648 if (mrt->id == RT6_TABLE_DFLT)
649 sprintf(name, "pim6reg");
650 else
651 sprintf(name, "pim6reg%u", mrt->id);
652
653 dev = alloc_netdev(0, name, NET_NAME_UNKNOWN, reg_vif_setup);
654 if (!dev)
655 return NULL;
656
657 dev_net_set(dev, net);
658
659 if (register_netdevice(dev)) {
660 free_netdev(dev);
661 return NULL;
662 }
663
664 if (dev_open(dev, NULL))
665 goto failure;
666
667 dev_hold(dev);
668 return dev;
669
670failure:
671 unregister_netdevice(dev);
672 return NULL;
673}
674#endif
675
676static int call_ip6mr_vif_entry_notifiers(struct net *net,
677 enum fib_event_type event_type,
678 struct vif_device *vif,
679 mifi_t vif_index, u32 tb_id)
680{
681 return mr_call_vif_notifiers(net, RTNL_FAMILY_IP6MR, event_type,
682 vif, vif_index, tb_id,
683 &net->ipv6.ipmr_seq);
684}
685
686static int call_ip6mr_mfc_entry_notifiers(struct net *net,
687 enum fib_event_type event_type,
688 struct mfc6_cache *mfc, u32 tb_id)
689{
690 return mr_call_mfc_notifiers(net, RTNL_FAMILY_IP6MR, event_type,
691 &mfc->_c, tb_id, &net->ipv6.ipmr_seq);
692}
693
694/* Delete a VIF entry */
695static int mif6_delete(struct mr_table *mrt, int vifi, int notify,
696 struct list_head *head)
697{
698 struct vif_device *v;
699 struct net_device *dev;
700 struct inet6_dev *in6_dev;
701
702 if (vifi < 0 || vifi >= mrt->maxvif)
703 return -EADDRNOTAVAIL;
704
705 v = &mrt->vif_table[vifi];
706
707 if (VIF_EXISTS(mrt, vifi))
708 call_ip6mr_vif_entry_notifiers(read_pnet(&mrt->net),
709 FIB_EVENT_VIF_DEL, v, vifi,
710 mrt->id);
711
712 write_lock_bh(&mrt_lock);
713 dev = v->dev;
714 v->dev = NULL;
715
716 if (!dev) {
717 write_unlock_bh(&mrt_lock);
718 return -EADDRNOTAVAIL;
719 }
720
721#ifdef CONFIG_IPV6_PIMSM_V2
722 if (vifi == mrt->mroute_reg_vif_num)
723 mrt->mroute_reg_vif_num = -1;
724#endif
725
726 if (vifi + 1 == mrt->maxvif) {
727 int tmp;
728 for (tmp = vifi - 1; tmp >= 0; tmp--) {
729 if (VIF_EXISTS(mrt, tmp))
730 break;
731 }
732 mrt->maxvif = tmp + 1;
733 }
734
735 write_unlock_bh(&mrt_lock);
736
737 dev_set_allmulti(dev, -1);
738
739 in6_dev = __in6_dev_get(dev);
740 if (in6_dev) {
741 atomic_dec(&in6_dev->cnf.mc_forwarding);
742 inet6_netconf_notify_devconf(dev_net(dev), RTM_NEWNETCONF,
743 NETCONFA_MC_FORWARDING,
744 dev->ifindex, &in6_dev->cnf);
745 }
746
747 if ((v->flags & MIFF_REGISTER) && !notify)
748 unregister_netdevice_queue(dev, head);
749
750 dev_put(dev);
751 return 0;
752}
753
754static inline void ip6mr_cache_free_rcu(struct rcu_head *head)
755{
756 struct mr_mfc *c = container_of(head, struct mr_mfc, rcu);
757
758 kmem_cache_free(mrt_cachep, (struct mfc6_cache *)c);
759}
760
761static inline void ip6mr_cache_free(struct mfc6_cache *c)
762{
763 call_rcu(&c->_c.rcu, ip6mr_cache_free_rcu);
764}
765
766/* Destroy an unresolved cache entry, killing queued skbs
767 and reporting error to netlink readers.
768 */
769
770static void ip6mr_destroy_unres(struct mr_table *mrt, struct mfc6_cache *c)
771{
772 struct net *net = read_pnet(&mrt->net);
773 struct sk_buff *skb;
774
775 atomic_dec(&mrt->cache_resolve_queue_len);
776
777 while ((skb = skb_dequeue(&c->_c.mfc_un.unres.unresolved)) != NULL) {
778 if (ipv6_hdr(skb)->version == 0) {
779 struct nlmsghdr *nlh = skb_pull(skb,
780 sizeof(struct ipv6hdr));
781 nlh->nlmsg_type = NLMSG_ERROR;
782 nlh->nlmsg_len = nlmsg_msg_size(sizeof(struct nlmsgerr));
783 skb_trim(skb, nlh->nlmsg_len);
784 ((struct nlmsgerr *)nlmsg_data(nlh))->error = -ETIMEDOUT;
785 rtnl_unicast(skb, net, NETLINK_CB(skb).portid);
786 } else
787 kfree_skb(skb);
788 }
789
790 ip6mr_cache_free(c);
791}
792
793
794/* Timer process for all the unresolved queue. */
795
796static void ipmr_do_expire_process(struct mr_table *mrt)
797{
798 unsigned long now = jiffies;
799 unsigned long expires = 10 * HZ;
800 struct mr_mfc *c, *next;
801
802 list_for_each_entry_safe(c, next, &mrt->mfc_unres_queue, list) {
803 if (time_after(c->mfc_un.unres.expires, now)) {
804 /* not yet... */
805 unsigned long interval = c->mfc_un.unres.expires - now;
806 if (interval < expires)
807 expires = interval;
808 continue;
809 }
810
811 list_del(&c->list);
812 mr6_netlink_event(mrt, (struct mfc6_cache *)c, RTM_DELROUTE);
813 ip6mr_destroy_unres(mrt, (struct mfc6_cache *)c);
814 }
815
816 if (!list_empty(&mrt->mfc_unres_queue))
817 mod_timer(&mrt->ipmr_expire_timer, jiffies + expires);
818}
819
820static void ipmr_expire_process(struct timer_list *t)
821{
822 struct mr_table *mrt = from_timer(mrt, t, ipmr_expire_timer);
823
824 if (!spin_trylock(&mfc_unres_lock)) {
825 mod_timer(&mrt->ipmr_expire_timer, jiffies + 1);
826 return;
827 }
828
829 if (!list_empty(&mrt->mfc_unres_queue))
830 ipmr_do_expire_process(mrt);
831
832 spin_unlock(&mfc_unres_lock);
833}
834
835/* Fill oifs list. It is called under write locked mrt_lock. */
836
837static void ip6mr_update_thresholds(struct mr_table *mrt,
838 struct mr_mfc *cache,
839 unsigned char *ttls)
840{
841 int vifi;
842
843 cache->mfc_un.res.minvif = MAXMIFS;
844 cache->mfc_un.res.maxvif = 0;
845 memset(cache->mfc_un.res.ttls, 255, MAXMIFS);
846
847 for (vifi = 0; vifi < mrt->maxvif; vifi++) {
848 if (VIF_EXISTS(mrt, vifi) &&
849 ttls[vifi] && ttls[vifi] < 255) {
850 cache->mfc_un.res.ttls[vifi] = ttls[vifi];
851 if (cache->mfc_un.res.minvif > vifi)
852 cache->mfc_un.res.minvif = vifi;
853 if (cache->mfc_un.res.maxvif <= vifi)
854 cache->mfc_un.res.maxvif = vifi + 1;
855 }
856 }
857 cache->mfc_un.res.lastuse = jiffies;
858}
859
860static int mif6_add(struct net *net, struct mr_table *mrt,
861 struct mif6ctl *vifc, int mrtsock)
862{
863 int vifi = vifc->mif6c_mifi;
864 struct vif_device *v = &mrt->vif_table[vifi];
865 struct net_device *dev;
866 struct inet6_dev *in6_dev;
867 int err;
868
869 /* Is vif busy ? */
870 if (VIF_EXISTS(mrt, vifi))
871 return -EADDRINUSE;
872
873 switch (vifc->mif6c_flags) {
874#ifdef CONFIG_IPV6_PIMSM_V2
875 case MIFF_REGISTER:
876 /*
877 * Special Purpose VIF in PIM
878 * All the packets will be sent to the daemon
879 */
880 if (mrt->mroute_reg_vif_num >= 0)
881 return -EADDRINUSE;
882 dev = ip6mr_reg_vif(net, mrt);
883 if (!dev)
884 return -ENOBUFS;
885 err = dev_set_allmulti(dev, 1);
886 if (err) {
887 unregister_netdevice(dev);
888 dev_put(dev);
889 return err;
890 }
891 break;
892#endif
893 case 0:
894 dev = dev_get_by_index(net, vifc->mif6c_pifi);
895 if (!dev)
896 return -EADDRNOTAVAIL;
897 err = dev_set_allmulti(dev, 1);
898 if (err) {
899 dev_put(dev);
900 return err;
901 }
902 break;
903 default:
904 return -EINVAL;
905 }
906
907 in6_dev = __in6_dev_get(dev);
908 if (in6_dev) {
909 atomic_inc(&in6_dev->cnf.mc_forwarding);
910 inet6_netconf_notify_devconf(dev_net(dev), RTM_NEWNETCONF,
911 NETCONFA_MC_FORWARDING,
912 dev->ifindex, &in6_dev->cnf);
913 }
914
915 /* Fill in the VIF structures */
916 vif_device_init(v, dev, vifc->vifc_rate_limit, vifc->vifc_threshold,
917 vifc->mif6c_flags | (!mrtsock ? VIFF_STATIC : 0),
918 MIFF_REGISTER);
919
920 /* And finish update writing critical data */
921 write_lock_bh(&mrt_lock);
922 v->dev = dev;
923#ifdef CONFIG_IPV6_PIMSM_V2
924 if (v->flags & MIFF_REGISTER)
925 mrt->mroute_reg_vif_num = vifi;
926#endif
927 if (vifi + 1 > mrt->maxvif)
928 mrt->maxvif = vifi + 1;
929 write_unlock_bh(&mrt_lock);
930 call_ip6mr_vif_entry_notifiers(net, FIB_EVENT_VIF_ADD,
931 v, vifi, mrt->id);
932 return 0;
933}
934
935static struct mfc6_cache *ip6mr_cache_find(struct mr_table *mrt,
936 const struct in6_addr *origin,
937 const struct in6_addr *mcastgrp)
938{
939 struct mfc6_cache_cmp_arg arg = {
940 .mf6c_origin = *origin,
941 .mf6c_mcastgrp = *mcastgrp,
942 };
943
944 return mr_mfc_find(mrt, &arg);
945}
946
947/* Look for a (*,G) entry */
948static struct mfc6_cache *ip6mr_cache_find_any(struct mr_table *mrt,
949 struct in6_addr *mcastgrp,
950 mifi_t mifi)
951{
952 struct mfc6_cache_cmp_arg arg = {
953 .mf6c_origin = in6addr_any,
954 .mf6c_mcastgrp = *mcastgrp,
955 };
956
957 if (ipv6_addr_any(mcastgrp))
958 return mr_mfc_find_any_parent(mrt, mifi);
959 return mr_mfc_find_any(mrt, mifi, &arg);
960}
961
962/* Look for a (S,G,iif) entry if parent != -1 */
963static struct mfc6_cache *
964ip6mr_cache_find_parent(struct mr_table *mrt,
965 const struct in6_addr *origin,
966 const struct in6_addr *mcastgrp,
967 int parent)
968{
969 struct mfc6_cache_cmp_arg arg = {
970 .mf6c_origin = *origin,
971 .mf6c_mcastgrp = *mcastgrp,
972 };
973
974 return mr_mfc_find_parent(mrt, &arg, parent);
975}
976
977/* Allocate a multicast cache entry */
978static struct mfc6_cache *ip6mr_cache_alloc(void)
979{
980 struct mfc6_cache *c = kmem_cache_zalloc(mrt_cachep, GFP_KERNEL);
981 if (!c)
982 return NULL;
983 c->_c.mfc_un.res.last_assert = jiffies - MFC_ASSERT_THRESH - 1;
984 c->_c.mfc_un.res.minvif = MAXMIFS;
985 c->_c.free = ip6mr_cache_free_rcu;
986 refcount_set(&c->_c.mfc_un.res.refcount, 1);
987 return c;
988}
989
990static struct mfc6_cache *ip6mr_cache_alloc_unres(void)
991{
992 struct mfc6_cache *c = kmem_cache_zalloc(mrt_cachep, GFP_ATOMIC);
993 if (!c)
994 return NULL;
995 skb_queue_head_init(&c->_c.mfc_un.unres.unresolved);
996 c->_c.mfc_un.unres.expires = jiffies + 10 * HZ;
997 return c;
998}
999
1000/*
1001 * A cache entry has gone into a resolved state from queued
1002 */
1003
1004static void ip6mr_cache_resolve(struct net *net, struct mr_table *mrt,
1005 struct mfc6_cache *uc, struct mfc6_cache *c)
1006{
1007 struct sk_buff *skb;
1008
1009 /*
1010 * Play the pending entries through our router
1011 */
1012
1013 while ((skb = __skb_dequeue(&uc->_c.mfc_un.unres.unresolved))) {
1014 if (ipv6_hdr(skb)->version == 0) {
1015 struct nlmsghdr *nlh = skb_pull(skb,
1016 sizeof(struct ipv6hdr));
1017
1018 if (mr_fill_mroute(mrt, skb, &c->_c,
1019 nlmsg_data(nlh)) > 0) {
1020 nlh->nlmsg_len = skb_tail_pointer(skb) - (u8 *)nlh;
1021 } else {
1022 nlh->nlmsg_type = NLMSG_ERROR;
1023 nlh->nlmsg_len = nlmsg_msg_size(sizeof(struct nlmsgerr));
1024 skb_trim(skb, nlh->nlmsg_len);
1025 ((struct nlmsgerr *)nlmsg_data(nlh))->error = -EMSGSIZE;
1026 }
1027 rtnl_unicast(skb, net, NETLINK_CB(skb).portid);
1028 } else
1029 ip6_mr_forward(net, mrt, skb->dev, skb, c);
1030 }
1031}
1032
1033/*
1034 * Bounce a cache query up to pim6sd and netlink.
1035 *
1036 * Called under mrt_lock.
1037 */
1038
1039static int ip6mr_cache_report(struct mr_table *mrt, struct sk_buff *pkt,
1040 mifi_t mifi, int assert)
1041{
1042 struct sock *mroute6_sk;
1043 struct sk_buff *skb;
1044 struct mrt6msg *msg;
1045 int ret;
1046
1047#ifdef CONFIG_IPV6_PIMSM_V2
1048 if (assert == MRT6MSG_WHOLEPKT)
1049 skb = skb_realloc_headroom(pkt, -skb_network_offset(pkt)
1050 +sizeof(*msg));
1051 else
1052#endif
1053 skb = alloc_skb(sizeof(struct ipv6hdr) + sizeof(*msg), GFP_ATOMIC);
1054
1055 if (!skb)
1056 return -ENOBUFS;
1057
1058 /* I suppose that internal messages
1059 * do not require checksums */
1060
1061 skb->ip_summed = CHECKSUM_UNNECESSARY;
1062
1063#ifdef CONFIG_IPV6_PIMSM_V2
1064 if (assert == MRT6MSG_WHOLEPKT) {
1065 /* Ugly, but we have no choice with this interface.
1066 Duplicate old header, fix length etc.
1067 And all this only to mangle msg->im6_msgtype and
1068 to set msg->im6_mbz to "mbz" :-)
1069 */
1070 __skb_pull(skb, skb_network_offset(pkt));
1071
1072 skb_push(skb, sizeof(*msg));
1073 skb_reset_transport_header(skb);
1074 msg = (struct mrt6msg *)skb_transport_header(skb);
1075 msg->im6_mbz = 0;
1076 msg->im6_msgtype = MRT6MSG_WHOLEPKT;
1077 msg->im6_mif = mrt->mroute_reg_vif_num;
1078 msg->im6_pad = 0;
1079 msg->im6_src = ipv6_hdr(pkt)->saddr;
1080 msg->im6_dst = ipv6_hdr(pkt)->daddr;
1081
1082 skb->ip_summed = CHECKSUM_UNNECESSARY;
1083 } else
1084#endif
1085 {
1086 /*
1087 * Copy the IP header
1088 */
1089
1090 skb_put(skb, sizeof(struct ipv6hdr));
1091 skb_reset_network_header(skb);
1092 skb_copy_to_linear_data(skb, ipv6_hdr(pkt), sizeof(struct ipv6hdr));
1093
1094 /*
1095 * Add our header
1096 */
1097 skb_put(skb, sizeof(*msg));
1098 skb_reset_transport_header(skb);
1099 msg = (struct mrt6msg *)skb_transport_header(skb);
1100
1101 msg->im6_mbz = 0;
1102 msg->im6_msgtype = assert;
1103 msg->im6_mif = mifi;
1104 msg->im6_pad = 0;
1105 msg->im6_src = ipv6_hdr(pkt)->saddr;
1106 msg->im6_dst = ipv6_hdr(pkt)->daddr;
1107
1108 skb_dst_set(skb, dst_clone(skb_dst(pkt)));
1109 skb->ip_summed = CHECKSUM_UNNECESSARY;
1110 }
1111
1112 rcu_read_lock();
1113 mroute6_sk = rcu_dereference(mrt->mroute_sk);
1114 if (!mroute6_sk) {
1115 rcu_read_unlock();
1116 kfree_skb(skb);
1117 return -EINVAL;
1118 }
1119
1120 mrt6msg_netlink_event(mrt, skb);
1121
1122 /* Deliver to user space multicast routing algorithms */
1123 ret = sock_queue_rcv_skb(mroute6_sk, skb);
1124 rcu_read_unlock();
1125 if (ret < 0) {
1126 net_warn_ratelimited("mroute6: pending queue full, dropping entries\n");
1127 kfree_skb(skb);
1128 }
1129
1130 return ret;
1131}
1132
1133/* Queue a packet for resolution. It gets locked cache entry! */
1134static int ip6mr_cache_unresolved(struct mr_table *mrt, mifi_t mifi,
1135 struct sk_buff *skb, struct net_device *dev)
1136{
1137 struct mfc6_cache *c;
1138 bool found = false;
1139 int err;
1140
1141 spin_lock_bh(&mfc_unres_lock);
1142 list_for_each_entry(c, &mrt->mfc_unres_queue, _c.list) {
1143 if (ipv6_addr_equal(&c->mf6c_mcastgrp, &ipv6_hdr(skb)->daddr) &&
1144 ipv6_addr_equal(&c->mf6c_origin, &ipv6_hdr(skb)->saddr)) {
1145 found = true;
1146 break;
1147 }
1148 }
1149
1150 if (!found) {
1151 /*
1152 * Create a new entry if allowable
1153 */
1154
1155 c = ip6mr_cache_alloc_unres();
1156 if (!c) {
1157 spin_unlock_bh(&mfc_unres_lock);
1158
1159 kfree_skb(skb);
1160 return -ENOBUFS;
1161 }
1162
1163 /* Fill in the new cache entry */
1164 c->_c.mfc_parent = -1;
1165 c->mf6c_origin = ipv6_hdr(skb)->saddr;
1166 c->mf6c_mcastgrp = ipv6_hdr(skb)->daddr;
1167
1168 /*
1169 * Reflect first query at pim6sd
1170 */
1171 err = ip6mr_cache_report(mrt, skb, mifi, MRT6MSG_NOCACHE);
1172 if (err < 0) {
1173 /* If the report failed throw the cache entry
1174 out - Brad Parker
1175 */
1176 spin_unlock_bh(&mfc_unres_lock);
1177
1178 ip6mr_cache_free(c);
1179 kfree_skb(skb);
1180 return err;
1181 }
1182
1183 atomic_inc(&mrt->cache_resolve_queue_len);
1184 list_add(&c->_c.list, &mrt->mfc_unres_queue);
1185 mr6_netlink_event(mrt, c, RTM_NEWROUTE);
1186
1187 ipmr_do_expire_process(mrt);
1188 }
1189
1190 /* See if we can append the packet */
1191 if (c->_c.mfc_un.unres.unresolved.qlen > 3) {
1192 kfree_skb(skb);
1193 err = -ENOBUFS;
1194 } else {
1195 if (dev) {
1196 skb->dev = dev;
1197 skb->skb_iif = dev->ifindex;
1198 }
1199 skb_queue_tail(&c->_c.mfc_un.unres.unresolved, skb);
1200 err = 0;
1201 }
1202
1203 spin_unlock_bh(&mfc_unres_lock);
1204 return err;
1205}
1206
1207/*
1208 * MFC6 cache manipulation by user space
1209 */
1210
1211static int ip6mr_mfc_delete(struct mr_table *mrt, struct mf6cctl *mfc,
1212 int parent)
1213{
1214 struct mfc6_cache *c;
1215
1216 /* The entries are added/deleted only under RTNL */
1217 rcu_read_lock();
1218 c = ip6mr_cache_find_parent(mrt, &mfc->mf6cc_origin.sin6_addr,
1219 &mfc->mf6cc_mcastgrp.sin6_addr, parent);
1220 rcu_read_unlock();
1221 if (!c)
1222 return -ENOENT;
1223 rhltable_remove(&mrt->mfc_hash, &c->_c.mnode, ip6mr_rht_params);
1224 list_del_rcu(&c->_c.list);
1225
1226 call_ip6mr_mfc_entry_notifiers(read_pnet(&mrt->net),
1227 FIB_EVENT_ENTRY_DEL, c, mrt->id);
1228 mr6_netlink_event(mrt, c, RTM_DELROUTE);
1229 mr_cache_put(&c->_c);
1230 return 0;
1231}
1232
1233static int ip6mr_device_event(struct notifier_block *this,
1234 unsigned long event, void *ptr)
1235{
1236 struct net_device *dev = netdev_notifier_info_to_dev(ptr);
1237 struct net *net = dev_net(dev);
1238 struct mr_table *mrt;
1239 struct vif_device *v;
1240 int ct;
1241
1242 if (event != NETDEV_UNREGISTER)
1243 return NOTIFY_DONE;
1244
1245 ip6mr_for_each_table(mrt, net) {
1246 v = &mrt->vif_table[0];
1247 for (ct = 0; ct < mrt->maxvif; ct++, v++) {
1248 if (v->dev == dev)
1249 mif6_delete(mrt, ct, 1, NULL);
1250 }
1251 }
1252
1253 return NOTIFY_DONE;
1254}
1255
1256static unsigned int ip6mr_seq_read(struct net *net)
1257{
1258 ASSERT_RTNL();
1259
1260 return net->ipv6.ipmr_seq + ip6mr_rules_seq_read(net);
1261}
1262
1263static int ip6mr_dump(struct net *net, struct notifier_block *nb)
1264{
1265 return mr_dump(net, nb, RTNL_FAMILY_IP6MR, ip6mr_rules_dump,
1266 ip6mr_mr_table_iter, &mrt_lock);
1267}
1268
1269static struct notifier_block ip6_mr_notifier = {
1270 .notifier_call = ip6mr_device_event
1271};
1272
1273static const struct fib_notifier_ops ip6mr_notifier_ops_template = {
1274 .family = RTNL_FAMILY_IP6MR,
1275 .fib_seq_read = ip6mr_seq_read,
1276 .fib_dump = ip6mr_dump,
1277 .owner = THIS_MODULE,
1278};
1279
1280static int __net_init ip6mr_notifier_init(struct net *net)
1281{
1282 struct fib_notifier_ops *ops;
1283
1284 net->ipv6.ipmr_seq = 0;
1285
1286 ops = fib_notifier_ops_register(&ip6mr_notifier_ops_template, net);
1287 if (IS_ERR(ops))
1288 return PTR_ERR(ops);
1289
1290 net->ipv6.ip6mr_notifier_ops = ops;
1291
1292 return 0;
1293}
1294
1295static void __net_exit ip6mr_notifier_exit(struct net *net)
1296{
1297 fib_notifier_ops_unregister(net->ipv6.ip6mr_notifier_ops);
1298 net->ipv6.ip6mr_notifier_ops = NULL;
1299}
1300
1301/* Setup for IP multicast routing */
1302static int __net_init ip6mr_net_init(struct net *net)
1303{
1304 int err;
1305
1306 err = ip6mr_notifier_init(net);
1307 if (err)
1308 return err;
1309
1310 err = ip6mr_rules_init(net);
1311 if (err < 0)
1312 goto ip6mr_rules_fail;
1313
1314#ifdef CONFIG_PROC_FS
1315 err = -ENOMEM;
1316 if (!proc_create_net("ip6_mr_vif", 0, net->proc_net, &ip6mr_vif_seq_ops,
1317 sizeof(struct mr_vif_iter)))
1318 goto proc_vif_fail;
1319 if (!proc_create_net("ip6_mr_cache", 0, net->proc_net, &ipmr_mfc_seq_ops,
1320 sizeof(struct mr_mfc_iter)))
1321 goto proc_cache_fail;
1322#endif
1323
1324 return 0;
1325
1326#ifdef CONFIG_PROC_FS
1327proc_cache_fail:
1328 remove_proc_entry("ip6_mr_vif", net->proc_net);
1329proc_vif_fail:
1330 ip6mr_rules_exit(net);
1331#endif
1332ip6mr_rules_fail:
1333 ip6mr_notifier_exit(net);
1334 return err;
1335}
1336
1337static void __net_exit ip6mr_net_exit(struct net *net)
1338{
1339#ifdef CONFIG_PROC_FS
1340 remove_proc_entry("ip6_mr_cache", net->proc_net);
1341 remove_proc_entry("ip6_mr_vif", net->proc_net);
1342#endif
1343 ip6mr_rules_exit(net);
1344 ip6mr_notifier_exit(net);
1345}
1346
1347static struct pernet_operations ip6mr_net_ops = {
1348 .init = ip6mr_net_init,
1349 .exit = ip6mr_net_exit,
1350};
1351
1352int __init ip6_mr_init(void)
1353{
1354 int err;
1355
1356 mrt_cachep = kmem_cache_create("ip6_mrt_cache",
1357 sizeof(struct mfc6_cache),
1358 0, SLAB_HWCACHE_ALIGN,
1359 NULL);
1360 if (!mrt_cachep)
1361 return -ENOMEM;
1362
1363 err = register_pernet_subsys(&ip6mr_net_ops);
1364 if (err)
1365 goto reg_pernet_fail;
1366
1367 err = register_netdevice_notifier(&ip6_mr_notifier);
1368 if (err)
1369 goto reg_notif_fail;
1370#ifdef CONFIG_IPV6_PIMSM_V2
1371 if (inet6_add_protocol(&pim6_protocol, IPPROTO_PIM) < 0) {
1372 pr_err("%s: can't add PIM protocol\n", __func__);
1373 err = -EAGAIN;
1374 goto add_proto_fail;
1375 }
1376#endif
1377 err = rtnl_register_module(THIS_MODULE, RTNL_FAMILY_IP6MR, RTM_GETROUTE,
1378 NULL, ip6mr_rtm_dumproute, 0);
1379 if (err == 0)
1380 return 0;
1381
1382#ifdef CONFIG_IPV6_PIMSM_V2
1383 inet6_del_protocol(&pim6_protocol, IPPROTO_PIM);
1384add_proto_fail:
1385 unregister_netdevice_notifier(&ip6_mr_notifier);
1386#endif
1387reg_notif_fail:
1388 unregister_pernet_subsys(&ip6mr_net_ops);
1389reg_pernet_fail:
1390 kmem_cache_destroy(mrt_cachep);
1391 return err;
1392}
1393
1394void ip6_mr_cleanup(void)
1395{
1396 rtnl_unregister(RTNL_FAMILY_IP6MR, RTM_GETROUTE);
1397#ifdef CONFIG_IPV6_PIMSM_V2
1398 inet6_del_protocol(&pim6_protocol, IPPROTO_PIM);
1399#endif
1400 unregister_netdevice_notifier(&ip6_mr_notifier);
1401 unregister_pernet_subsys(&ip6mr_net_ops);
1402 kmem_cache_destroy(mrt_cachep);
1403}
1404
1405static int ip6mr_mfc_add(struct net *net, struct mr_table *mrt,
1406 struct mf6cctl *mfc, int mrtsock, int parent)
1407{
1408 unsigned char ttls[MAXMIFS];
1409 struct mfc6_cache *uc, *c;
1410 struct mr_mfc *_uc;
1411 bool found;
1412 int i, err;
1413
1414 if (mfc->mf6cc_parent >= MAXMIFS)
1415 return -ENFILE;
1416
1417 memset(ttls, 255, MAXMIFS);
1418 for (i = 0; i < MAXMIFS; i++) {
1419 if (IF_ISSET(i, &mfc->mf6cc_ifset))
1420 ttls[i] = 1;
1421 }
1422
1423 /* The entries are added/deleted only under RTNL */
1424 rcu_read_lock();
1425 c = ip6mr_cache_find_parent(mrt, &mfc->mf6cc_origin.sin6_addr,
1426 &mfc->mf6cc_mcastgrp.sin6_addr, parent);
1427 rcu_read_unlock();
1428 if (c) {
1429 write_lock_bh(&mrt_lock);
1430 c->_c.mfc_parent = mfc->mf6cc_parent;
1431 ip6mr_update_thresholds(mrt, &c->_c, ttls);
1432 if (!mrtsock)
1433 c->_c.mfc_flags |= MFC_STATIC;
1434 write_unlock_bh(&mrt_lock);
1435 call_ip6mr_mfc_entry_notifiers(net, FIB_EVENT_ENTRY_REPLACE,
1436 c, mrt->id);
1437 mr6_netlink_event(mrt, c, RTM_NEWROUTE);
1438 return 0;
1439 }
1440
1441 if (!ipv6_addr_any(&mfc->mf6cc_mcastgrp.sin6_addr) &&
1442 !ipv6_addr_is_multicast(&mfc->mf6cc_mcastgrp.sin6_addr))
1443 return -EINVAL;
1444
1445 c = ip6mr_cache_alloc();
1446 if (!c)
1447 return -ENOMEM;
1448
1449 c->mf6c_origin = mfc->mf6cc_origin.sin6_addr;
1450 c->mf6c_mcastgrp = mfc->mf6cc_mcastgrp.sin6_addr;
1451 c->_c.mfc_parent = mfc->mf6cc_parent;
1452 ip6mr_update_thresholds(mrt, &c->_c, ttls);
1453 if (!mrtsock)
1454 c->_c.mfc_flags |= MFC_STATIC;
1455
1456 err = rhltable_insert_key(&mrt->mfc_hash, &c->cmparg, &c->_c.mnode,
1457 ip6mr_rht_params);
1458 if (err) {
1459 pr_err("ip6mr: rhtable insert error %d\n", err);
1460 ip6mr_cache_free(c);
1461 return err;
1462 }
1463 list_add_tail_rcu(&c->_c.list, &mrt->mfc_cache_list);
1464
1465 /* Check to see if we resolved a queued list. If so we
1466 * need to send on the frames and tidy up.
1467 */
1468 found = false;
1469 spin_lock_bh(&mfc_unres_lock);
1470 list_for_each_entry(_uc, &mrt->mfc_unres_queue, list) {
1471 uc = (struct mfc6_cache *)_uc;
1472 if (ipv6_addr_equal(&uc->mf6c_origin, &c->mf6c_origin) &&
1473 ipv6_addr_equal(&uc->mf6c_mcastgrp, &c->mf6c_mcastgrp)) {
1474 list_del(&_uc->list);
1475 atomic_dec(&mrt->cache_resolve_queue_len);
1476 found = true;
1477 break;
1478 }
1479 }
1480 if (list_empty(&mrt->mfc_unres_queue))
1481 del_timer(&mrt->ipmr_expire_timer);
1482 spin_unlock_bh(&mfc_unres_lock);
1483
1484 if (found) {
1485 ip6mr_cache_resolve(net, mrt, uc, c);
1486 ip6mr_cache_free(uc);
1487 }
1488 call_ip6mr_mfc_entry_notifiers(net, FIB_EVENT_ENTRY_ADD,
1489 c, mrt->id);
1490 mr6_netlink_event(mrt, c, RTM_NEWROUTE);
1491 return 0;
1492}
1493
1494/*
1495 * Close the multicast socket, and clear the vif tables etc
1496 */
1497
1498static void mroute_clean_tables(struct mr_table *mrt, int flags)
1499{
1500 struct mr_mfc *c, *tmp;
1501 LIST_HEAD(list);
1502 int i;
1503
1504 /* Shut down all active vif entries */
1505 if (flags & (MRT6_FLUSH_MIFS | MRT6_FLUSH_MIFS_STATIC)) {
1506 for (i = 0; i < mrt->maxvif; i++) {
1507 if (((mrt->vif_table[i].flags & VIFF_STATIC) &&
1508 !(flags & MRT6_FLUSH_MIFS_STATIC)) ||
1509 (!(mrt->vif_table[i].flags & VIFF_STATIC) && !(flags & MRT6_FLUSH_MIFS)))
1510 continue;
1511 mif6_delete(mrt, i, 0, &list);
1512 }
1513 unregister_netdevice_many(&list);
1514 }
1515
1516 /* Wipe the cache */
1517 if (flags & (MRT6_FLUSH_MFC | MRT6_FLUSH_MFC_STATIC)) {
1518 list_for_each_entry_safe(c, tmp, &mrt->mfc_cache_list, list) {
1519 if (((c->mfc_flags & MFC_STATIC) && !(flags & MRT6_FLUSH_MFC_STATIC)) ||
1520 (!(c->mfc_flags & MFC_STATIC) && !(flags & MRT6_FLUSH_MFC)))
1521 continue;
1522 rhltable_remove(&mrt->mfc_hash, &c->mnode, ip6mr_rht_params);
1523 list_del_rcu(&c->list);
1524 call_ip6mr_mfc_entry_notifiers(read_pnet(&mrt->net),
1525 FIB_EVENT_ENTRY_DEL,
1526 (struct mfc6_cache *)c, mrt->id);
1527 mr6_netlink_event(mrt, (struct mfc6_cache *)c, RTM_DELROUTE);
1528 mr_cache_put(c);
1529 }
1530 }
1531
1532 if (flags & MRT6_FLUSH_MFC) {
1533 if (atomic_read(&mrt->cache_resolve_queue_len) != 0) {
1534 spin_lock_bh(&mfc_unres_lock);
1535 list_for_each_entry_safe(c, tmp, &mrt->mfc_unres_queue, list) {
1536 list_del(&c->list);
1537 mr6_netlink_event(mrt, (struct mfc6_cache *)c,
1538 RTM_DELROUTE);
1539 ip6mr_destroy_unres(mrt, (struct mfc6_cache *)c);
1540 }
1541 spin_unlock_bh(&mfc_unres_lock);
1542 }
1543 }
1544}
1545
1546static int ip6mr_sk_init(struct mr_table *mrt, struct sock *sk)
1547{
1548 int err = 0;
1549 struct net *net = sock_net(sk);
1550
1551 rtnl_lock();
1552 write_lock_bh(&mrt_lock);
1553 if (rtnl_dereference(mrt->mroute_sk)) {
1554 err = -EADDRINUSE;
1555 } else {
1556 rcu_assign_pointer(mrt->mroute_sk, sk);
1557 sock_set_flag(sk, SOCK_RCU_FREE);
1558 atomic_inc(&net->ipv6.devconf_all->mc_forwarding);
1559 }
1560 write_unlock_bh(&mrt_lock);
1561
1562 if (!err)
1563 inet6_netconf_notify_devconf(net, RTM_NEWNETCONF,
1564 NETCONFA_MC_FORWARDING,
1565 NETCONFA_IFINDEX_ALL,
1566 net->ipv6.devconf_all);
1567 rtnl_unlock();
1568
1569 return err;
1570}
1571
1572int ip6mr_sk_done(struct sock *sk)
1573{
1574 int err = -EACCES;
1575 struct net *net = sock_net(sk);
1576 struct mr_table *mrt;
1577
1578 if (sk->sk_type != SOCK_RAW ||
1579 inet_sk(sk)->inet_num != IPPROTO_ICMPV6)
1580 return err;
1581
1582 rtnl_lock();
1583 ip6mr_for_each_table(mrt, net) {
1584 if (sk == rtnl_dereference(mrt->mroute_sk)) {
1585 write_lock_bh(&mrt_lock);
1586 RCU_INIT_POINTER(mrt->mroute_sk, NULL);
1587 /* Note that mroute_sk had SOCK_RCU_FREE set,
1588 * so the RCU grace period before sk freeing
1589 * is guaranteed by sk_destruct()
1590 */
1591 atomic_dec(&net->ipv6.devconf_all->mc_forwarding);
1592 write_unlock_bh(&mrt_lock);
1593 inet6_netconf_notify_devconf(net, RTM_NEWNETCONF,
1594 NETCONFA_MC_FORWARDING,
1595 NETCONFA_IFINDEX_ALL,
1596 net->ipv6.devconf_all);
1597
1598 mroute_clean_tables(mrt, MRT6_FLUSH_MIFS | MRT6_FLUSH_MFC);
1599 err = 0;
1600 break;
1601 }
1602 }
1603 rtnl_unlock();
1604
1605 return err;
1606}
1607
1608bool mroute6_is_socket(struct net *net, struct sk_buff *skb)
1609{
1610 struct mr_table *mrt;
1611 struct flowi6 fl6 = {
1612 .flowi6_iif = skb->skb_iif ? : LOOPBACK_IFINDEX,
1613 .flowi6_oif = skb->dev->ifindex,
1614 .flowi6_mark = skb->mark,
1615 };
1616
1617 if (ip6mr_fib_lookup(net, &fl6, &mrt) < 0)
1618 return NULL;
1619
1620 return rcu_access_pointer(mrt->mroute_sk);
1621}
1622EXPORT_SYMBOL(mroute6_is_socket);
1623
1624/*
1625 * Socket options and virtual interface manipulation. The whole
1626 * virtual interface system is a complete heap, but unfortunately
1627 * that's how BSD mrouted happens to think. Maybe one day with a proper
1628 * MOSPF/PIM router set up we can clean this up.
1629 */
1630
1631int ip6_mroute_setsockopt(struct sock *sk, int optname, char __user *optval, unsigned int optlen)
1632{
1633 int ret, parent = 0;
1634 struct mif6ctl vif;
1635 struct mf6cctl mfc;
1636 mifi_t mifi;
1637 struct net *net = sock_net(sk);
1638 struct mr_table *mrt;
1639
1640 if (sk->sk_type != SOCK_RAW ||
1641 inet_sk(sk)->inet_num != IPPROTO_ICMPV6)
1642 return -EOPNOTSUPP;
1643
1644 mrt = ip6mr_get_table(net, raw6_sk(sk)->ip6mr_table ? : RT6_TABLE_DFLT);
1645 if (!mrt)
1646 return -ENOENT;
1647
1648 if (optname != MRT6_INIT) {
1649 if (sk != rcu_access_pointer(mrt->mroute_sk) &&
1650 !ns_capable(net->user_ns, CAP_NET_ADMIN))
1651 return -EACCES;
1652 }
1653
1654 switch (optname) {
1655 case MRT6_INIT:
1656 if (optlen < sizeof(int))
1657 return -EINVAL;
1658
1659 return ip6mr_sk_init(mrt, sk);
1660
1661 case MRT6_DONE:
1662 return ip6mr_sk_done(sk);
1663
1664 case MRT6_ADD_MIF:
1665 if (optlen < sizeof(vif))
1666 return -EINVAL;
1667 if (copy_from_user(&vif, optval, sizeof(vif)))
1668 return -EFAULT;
1669 if (vif.mif6c_mifi >= MAXMIFS)
1670 return -ENFILE;
1671 rtnl_lock();
1672 ret = mif6_add(net, mrt, &vif,
1673 sk == rtnl_dereference(mrt->mroute_sk));
1674 rtnl_unlock();
1675 return ret;
1676
1677 case MRT6_DEL_MIF:
1678 if (optlen < sizeof(mifi_t))
1679 return -EINVAL;
1680 if (copy_from_user(&mifi, optval, sizeof(mifi_t)))
1681 return -EFAULT;
1682 rtnl_lock();
1683 ret = mif6_delete(mrt, mifi, 0, NULL);
1684 rtnl_unlock();
1685 return ret;
1686
1687 /*
1688 * Manipulate the forwarding caches. These live
1689 * in a sort of kernel/user symbiosis.
1690 */
1691 case MRT6_ADD_MFC:
1692 case MRT6_DEL_MFC:
1693 parent = -1;
1694 /* fall through */
1695 case MRT6_ADD_MFC_PROXY:
1696 case MRT6_DEL_MFC_PROXY:
1697 if (optlen < sizeof(mfc))
1698 return -EINVAL;
1699 if (copy_from_user(&mfc, optval, sizeof(mfc)))
1700 return -EFAULT;
1701 if (parent == 0)
1702 parent = mfc.mf6cc_parent;
1703 rtnl_lock();
1704 if (optname == MRT6_DEL_MFC || optname == MRT6_DEL_MFC_PROXY)
1705 ret = ip6mr_mfc_delete(mrt, &mfc, parent);
1706 else
1707 ret = ip6mr_mfc_add(net, mrt, &mfc,
1708 sk ==
1709 rtnl_dereference(mrt->mroute_sk),
1710 parent);
1711 rtnl_unlock();
1712 return ret;
1713
1714 case MRT6_FLUSH:
1715 {
1716 int flags;
1717
1718 if (optlen != sizeof(flags))
1719 return -EINVAL;
1720 if (get_user(flags, (int __user *)optval))
1721 return -EFAULT;
1722 rtnl_lock();
1723 mroute_clean_tables(mrt, flags);
1724 rtnl_unlock();
1725 return 0;
1726 }
1727
1728 /*
1729 * Control PIM assert (to activate pim will activate assert)
1730 */
1731 case MRT6_ASSERT:
1732 {
1733 int v;
1734
1735 if (optlen != sizeof(v))
1736 return -EINVAL;
1737 if (get_user(v, (int __user *)optval))
1738 return -EFAULT;
1739 mrt->mroute_do_assert = v;
1740 return 0;
1741 }
1742
1743#ifdef CONFIG_IPV6_PIMSM_V2
1744 case MRT6_PIM:
1745 {
1746 int v;
1747
1748 if (optlen != sizeof(v))
1749 return -EINVAL;
1750 if (get_user(v, (int __user *)optval))
1751 return -EFAULT;
1752 v = !!v;
1753 rtnl_lock();
1754 ret = 0;
1755 if (v != mrt->mroute_do_pim) {
1756 mrt->mroute_do_pim = v;
1757 mrt->mroute_do_assert = v;
1758 }
1759 rtnl_unlock();
1760 return ret;
1761 }
1762
1763#endif
1764#ifdef CONFIG_IPV6_MROUTE_MULTIPLE_TABLES
1765 case MRT6_TABLE:
1766 {
1767 u32 v;
1768
1769 if (optlen != sizeof(u32))
1770 return -EINVAL;
1771 if (get_user(v, (u32 __user *)optval))
1772 return -EFAULT;
1773 /* "pim6reg%u" should not exceed 16 bytes (IFNAMSIZ) */
1774 if (v != RT_TABLE_DEFAULT && v >= 100000000)
1775 return -EINVAL;
1776 if (sk == rcu_access_pointer(mrt->mroute_sk))
1777 return -EBUSY;
1778
1779 rtnl_lock();
1780 ret = 0;
1781 mrt = ip6mr_new_table(net, v);
1782 if (IS_ERR(mrt))
1783 ret = PTR_ERR(mrt);
1784 else
1785 raw6_sk(sk)->ip6mr_table = v;
1786 rtnl_unlock();
1787 return ret;
1788 }
1789#endif
1790 /*
1791 * Spurious command, or MRT6_VERSION which you cannot
1792 * set.
1793 */
1794 default:
1795 return -ENOPROTOOPT;
1796 }
1797}
1798
1799/*
1800 * Getsock opt support for the multicast routing system.
1801 */
1802
1803int ip6_mroute_getsockopt(struct sock *sk, int optname, char __user *optval,
1804 int __user *optlen)
1805{
1806 int olr;
1807 int val;
1808 struct net *net = sock_net(sk);
1809 struct mr_table *mrt;
1810
1811 if (sk->sk_type != SOCK_RAW ||
1812 inet_sk(sk)->inet_num != IPPROTO_ICMPV6)
1813 return -EOPNOTSUPP;
1814
1815 mrt = ip6mr_get_table(net, raw6_sk(sk)->ip6mr_table ? : RT6_TABLE_DFLT);
1816 if (!mrt)
1817 return -ENOENT;
1818
1819 switch (optname) {
1820 case MRT6_VERSION:
1821 val = 0x0305;
1822 break;
1823#ifdef CONFIG_IPV6_PIMSM_V2
1824 case MRT6_PIM:
1825 val = mrt->mroute_do_pim;
1826 break;
1827#endif
1828 case MRT6_ASSERT:
1829 val = mrt->mroute_do_assert;
1830 break;
1831 default:
1832 return -ENOPROTOOPT;
1833 }
1834
1835 if (get_user(olr, optlen))
1836 return -EFAULT;
1837
1838 olr = min_t(int, olr, sizeof(int));
1839 if (olr < 0)
1840 return -EINVAL;
1841
1842 if (put_user(olr, optlen))
1843 return -EFAULT;
1844 if (copy_to_user(optval, &val, olr))
1845 return -EFAULT;
1846 return 0;
1847}
1848
1849/*
1850 * The IP multicast ioctl support routines.
1851 */
1852
1853int ip6mr_ioctl(struct sock *sk, int cmd, void __user *arg)
1854{
1855 struct sioc_sg_req6 sr;
1856 struct sioc_mif_req6 vr;
1857 struct vif_device *vif;
1858 struct mfc6_cache *c;
1859 struct net *net = sock_net(sk);
1860 struct mr_table *mrt;
1861
1862 mrt = ip6mr_get_table(net, raw6_sk(sk)->ip6mr_table ? : RT6_TABLE_DFLT);
1863 if (!mrt)
1864 return -ENOENT;
1865
1866 switch (cmd) {
1867 case SIOCGETMIFCNT_IN6:
1868 if (copy_from_user(&vr, arg, sizeof(vr)))
1869 return -EFAULT;
1870 if (vr.mifi >= mrt->maxvif)
1871 return -EINVAL;
1872 vr.mifi = array_index_nospec(vr.mifi, mrt->maxvif);
1873 read_lock(&mrt_lock);
1874 vif = &mrt->vif_table[vr.mifi];
1875 if (VIF_EXISTS(mrt, vr.mifi)) {
1876 vr.icount = vif->pkt_in;
1877 vr.ocount = vif->pkt_out;
1878 vr.ibytes = vif->bytes_in;
1879 vr.obytes = vif->bytes_out;
1880 read_unlock(&mrt_lock);
1881
1882 if (copy_to_user(arg, &vr, sizeof(vr)))
1883 return -EFAULT;
1884 return 0;
1885 }
1886 read_unlock(&mrt_lock);
1887 return -EADDRNOTAVAIL;
1888 case SIOCGETSGCNT_IN6:
1889 if (copy_from_user(&sr, arg, sizeof(sr)))
1890 return -EFAULT;
1891
1892 rcu_read_lock();
1893 c = ip6mr_cache_find(mrt, &sr.src.sin6_addr, &sr.grp.sin6_addr);
1894 if (c) {
1895 sr.pktcnt = c->_c.mfc_un.res.pkt;
1896 sr.bytecnt = c->_c.mfc_un.res.bytes;
1897 sr.wrong_if = c->_c.mfc_un.res.wrong_if;
1898 rcu_read_unlock();
1899
1900 if (copy_to_user(arg, &sr, sizeof(sr)))
1901 return -EFAULT;
1902 return 0;
1903 }
1904 rcu_read_unlock();
1905 return -EADDRNOTAVAIL;
1906 default:
1907 return -ENOIOCTLCMD;
1908 }
1909}
1910
1911#ifdef CONFIG_COMPAT
1912struct compat_sioc_sg_req6 {
1913 struct sockaddr_in6 src;
1914 struct sockaddr_in6 grp;
1915 compat_ulong_t pktcnt;
1916 compat_ulong_t bytecnt;
1917 compat_ulong_t wrong_if;
1918};
1919
1920struct compat_sioc_mif_req6 {
1921 mifi_t mifi;
1922 compat_ulong_t icount;
1923 compat_ulong_t ocount;
1924 compat_ulong_t ibytes;
1925 compat_ulong_t obytes;
1926};
1927
1928int ip6mr_compat_ioctl(struct sock *sk, unsigned int cmd, void __user *arg)
1929{
1930 struct compat_sioc_sg_req6 sr;
1931 struct compat_sioc_mif_req6 vr;
1932 struct vif_device *vif;
1933 struct mfc6_cache *c;
1934 struct net *net = sock_net(sk);
1935 struct mr_table *mrt;
1936
1937 mrt = ip6mr_get_table(net, raw6_sk(sk)->ip6mr_table ? : RT6_TABLE_DFLT);
1938 if (!mrt)
1939 return -ENOENT;
1940
1941 switch (cmd) {
1942 case SIOCGETMIFCNT_IN6:
1943 if (copy_from_user(&vr, arg, sizeof(vr)))
1944 return -EFAULT;
1945 if (vr.mifi >= mrt->maxvif)
1946 return -EINVAL;
1947 vr.mifi = array_index_nospec(vr.mifi, mrt->maxvif);
1948 read_lock(&mrt_lock);
1949 vif = &mrt->vif_table[vr.mifi];
1950 if (VIF_EXISTS(mrt, vr.mifi)) {
1951 vr.icount = vif->pkt_in;
1952 vr.ocount = vif->pkt_out;
1953 vr.ibytes = vif->bytes_in;
1954 vr.obytes = vif->bytes_out;
1955 read_unlock(&mrt_lock);
1956
1957 if (copy_to_user(arg, &vr, sizeof(vr)))
1958 return -EFAULT;
1959 return 0;
1960 }
1961 read_unlock(&mrt_lock);
1962 return -EADDRNOTAVAIL;
1963 case SIOCGETSGCNT_IN6:
1964 if (copy_from_user(&sr, arg, sizeof(sr)))
1965 return -EFAULT;
1966
1967 rcu_read_lock();
1968 c = ip6mr_cache_find(mrt, &sr.src.sin6_addr, &sr.grp.sin6_addr);
1969 if (c) {
1970 sr.pktcnt = c->_c.mfc_un.res.pkt;
1971 sr.bytecnt = c->_c.mfc_un.res.bytes;
1972 sr.wrong_if = c->_c.mfc_un.res.wrong_if;
1973 rcu_read_unlock();
1974
1975 if (copy_to_user(arg, &sr, sizeof(sr)))
1976 return -EFAULT;
1977 return 0;
1978 }
1979 rcu_read_unlock();
1980 return -EADDRNOTAVAIL;
1981 default:
1982 return -ENOIOCTLCMD;
1983 }
1984}
1985#endif
1986
1987static inline int ip6mr_forward2_finish(struct net *net, struct sock *sk, struct sk_buff *skb)
1988{
1989 IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
1990 IPSTATS_MIB_OUTFORWDATAGRAMS);
1991 IP6_ADD_STATS(net, ip6_dst_idev(skb_dst(skb)),
1992 IPSTATS_MIB_OUTOCTETS, skb->len);
1993 return dst_output(net, sk, skb);
1994}
1995
1996/*
1997 * Processing handlers for ip6mr_forward
1998 */
1999
2000static int ip6mr_forward2(struct net *net, struct mr_table *mrt,
2001 struct sk_buff *skb, int vifi)
2002{
2003 struct ipv6hdr *ipv6h;
2004 struct vif_device *vif = &mrt->vif_table[vifi];
2005 struct net_device *dev;
2006 struct dst_entry *dst;
2007 struct flowi6 fl6;
2008
2009 if (!vif->dev)
2010 goto out_free;
2011
2012#ifdef CONFIG_IPV6_PIMSM_V2
2013 if (vif->flags & MIFF_REGISTER) {
2014 vif->pkt_out++;
2015 vif->bytes_out += skb->len;
2016 vif->dev->stats.tx_bytes += skb->len;
2017 vif->dev->stats.tx_packets++;
2018 ip6mr_cache_report(mrt, skb, vifi, MRT6MSG_WHOLEPKT);
2019 goto out_free;
2020 }
2021#endif
2022
2023 ipv6h = ipv6_hdr(skb);
2024
2025 fl6 = (struct flowi6) {
2026 .flowi6_oif = vif->link,
2027 .daddr = ipv6h->daddr,
2028 };
2029
2030 dst = ip6_route_output(net, NULL, &fl6);
2031 if (dst->error) {
2032 dst_release(dst);
2033 goto out_free;
2034 }
2035
2036 skb_dst_drop(skb);
2037 skb_dst_set(skb, dst);
2038
2039 /*
2040 * RFC1584 teaches, that DVMRP/PIM router must deliver packets locally
2041 * not only before forwarding, but after forwarding on all output
2042 * interfaces. It is clear, if mrouter runs a multicasting
2043 * program, it should receive packets not depending to what interface
2044 * program is joined.
2045 * If we will not make it, the program will have to join on all
2046 * interfaces. On the other hand, multihoming host (or router, but
2047 * not mrouter) cannot join to more than one interface - it will
2048 * result in receiving multiple packets.
2049 */
2050 dev = vif->dev;
2051 skb->dev = dev;
2052 vif->pkt_out++;
2053 vif->bytes_out += skb->len;
2054
2055 /* We are about to write */
2056 /* XXX: extension headers? */
2057 if (skb_cow(skb, sizeof(*ipv6h) + LL_RESERVED_SPACE(dev)))
2058 goto out_free;
2059
2060 ipv6h = ipv6_hdr(skb);
2061 ipv6h->hop_limit--;
2062
2063 IP6CB(skb)->flags |= IP6SKB_FORWARDED;
2064
2065 return NF_HOOK(NFPROTO_IPV6, NF_INET_FORWARD,
2066 net, NULL, skb, skb->dev, dev,
2067 ip6mr_forward2_finish);
2068
2069out_free:
2070 kfree_skb(skb);
2071 return 0;
2072}
2073
2074static int ip6mr_find_vif(struct mr_table *mrt, struct net_device *dev)
2075{
2076 int ct;
2077
2078 for (ct = mrt->maxvif - 1; ct >= 0; ct--) {
2079 if (mrt->vif_table[ct].dev == dev)
2080 break;
2081 }
2082 return ct;
2083}
2084
2085static void ip6_mr_forward(struct net *net, struct mr_table *mrt,
2086 struct net_device *dev, struct sk_buff *skb,
2087 struct mfc6_cache *c)
2088{
2089 int psend = -1;
2090 int vif, ct;
2091 int true_vifi = ip6mr_find_vif(mrt, dev);
2092
2093 vif = c->_c.mfc_parent;
2094 c->_c.mfc_un.res.pkt++;
2095 c->_c.mfc_un.res.bytes += skb->len;
2096 c->_c.mfc_un.res.lastuse = jiffies;
2097
2098 if (ipv6_addr_any(&c->mf6c_origin) && true_vifi >= 0) {
2099 struct mfc6_cache *cache_proxy;
2100
2101 /* For an (*,G) entry, we only check that the incoming
2102 * interface is part of the static tree.
2103 */
2104 rcu_read_lock();
2105 cache_proxy = mr_mfc_find_any_parent(mrt, vif);
2106 if (cache_proxy &&
2107 cache_proxy->_c.mfc_un.res.ttls[true_vifi] < 255) {
2108 rcu_read_unlock();
2109 goto forward;
2110 }
2111 rcu_read_unlock();
2112 }
2113
2114 /*
2115 * Wrong interface: drop packet and (maybe) send PIM assert.
2116 */
2117 if (mrt->vif_table[vif].dev != dev) {
2118 c->_c.mfc_un.res.wrong_if++;
2119
2120 if (true_vifi >= 0 && mrt->mroute_do_assert &&
2121 /* pimsm uses asserts, when switching from RPT to SPT,
2122 so that we cannot check that packet arrived on an oif.
2123 It is bad, but otherwise we would need to move pretty
2124 large chunk of pimd to kernel. Ough... --ANK
2125 */
2126 (mrt->mroute_do_pim ||
2127 c->_c.mfc_un.res.ttls[true_vifi] < 255) &&
2128 time_after(jiffies,
2129 c->_c.mfc_un.res.last_assert +
2130 MFC_ASSERT_THRESH)) {
2131 c->_c.mfc_un.res.last_assert = jiffies;
2132 ip6mr_cache_report(mrt, skb, true_vifi, MRT6MSG_WRONGMIF);
2133 }
2134 goto dont_forward;
2135 }
2136
2137forward:
2138 mrt->vif_table[vif].pkt_in++;
2139 mrt->vif_table[vif].bytes_in += skb->len;
2140
2141 /*
2142 * Forward the frame
2143 */
2144 if (ipv6_addr_any(&c->mf6c_origin) &&
2145 ipv6_addr_any(&c->mf6c_mcastgrp)) {
2146 if (true_vifi >= 0 &&
2147 true_vifi != c->_c.mfc_parent &&
2148 ipv6_hdr(skb)->hop_limit >
2149 c->_c.mfc_un.res.ttls[c->_c.mfc_parent]) {
2150 /* It's an (*,*) entry and the packet is not coming from
2151 * the upstream: forward the packet to the upstream
2152 * only.
2153 */
2154 psend = c->_c.mfc_parent;
2155 goto last_forward;
2156 }
2157 goto dont_forward;
2158 }
2159 for (ct = c->_c.mfc_un.res.maxvif - 1;
2160 ct >= c->_c.mfc_un.res.minvif; ct--) {
2161 /* For (*,G) entry, don't forward to the incoming interface */
2162 if ((!ipv6_addr_any(&c->mf6c_origin) || ct != true_vifi) &&
2163 ipv6_hdr(skb)->hop_limit > c->_c.mfc_un.res.ttls[ct]) {
2164 if (psend != -1) {
2165 struct sk_buff *skb2 = skb_clone(skb, GFP_ATOMIC);
2166 if (skb2)
2167 ip6mr_forward2(net, mrt, skb2, psend);
2168 }
2169 psend = ct;
2170 }
2171 }
2172last_forward:
2173 if (psend != -1) {
2174 ip6mr_forward2(net, mrt, skb, psend);
2175 return;
2176 }
2177
2178dont_forward:
2179 kfree_skb(skb);
2180}
2181
2182
2183/*
2184 * Multicast packets for forwarding arrive here
2185 */
2186
2187int ip6_mr_input(struct sk_buff *skb)
2188{
2189 struct mfc6_cache *cache;
2190 struct net *net = dev_net(skb->dev);
2191 struct mr_table *mrt;
2192 struct flowi6 fl6 = {
2193 .flowi6_iif = skb->dev->ifindex,
2194 .flowi6_mark = skb->mark,
2195 };
2196 int err;
2197 struct net_device *dev;
2198
2199 /* skb->dev passed in is the master dev for vrfs.
2200 * Get the proper interface that does have a vif associated with it.
2201 */
2202 dev = skb->dev;
2203 if (netif_is_l3_master(skb->dev)) {
2204 dev = dev_get_by_index_rcu(net, IPCB(skb)->iif);
2205 if (!dev) {
2206 kfree_skb(skb);
2207 return -ENODEV;
2208 }
2209 }
2210
2211 err = ip6mr_fib_lookup(net, &fl6, &mrt);
2212 if (err < 0) {
2213 kfree_skb(skb);
2214 return err;
2215 }
2216
2217 read_lock(&mrt_lock);
2218 cache = ip6mr_cache_find(mrt,
2219 &ipv6_hdr(skb)->saddr, &ipv6_hdr(skb)->daddr);
2220 if (!cache) {
2221 int vif = ip6mr_find_vif(mrt, dev);
2222
2223 if (vif >= 0)
2224 cache = ip6mr_cache_find_any(mrt,
2225 &ipv6_hdr(skb)->daddr,
2226 vif);
2227 }
2228
2229 /*
2230 * No usable cache entry
2231 */
2232 if (!cache) {
2233 int vif;
2234
2235 vif = ip6mr_find_vif(mrt, dev);
2236 if (vif >= 0) {
2237 int err = ip6mr_cache_unresolved(mrt, vif, skb, dev);
2238 read_unlock(&mrt_lock);
2239
2240 return err;
2241 }
2242 read_unlock(&mrt_lock);
2243 kfree_skb(skb);
2244 return -ENODEV;
2245 }
2246
2247 ip6_mr_forward(net, mrt, dev, skb, cache);
2248
2249 read_unlock(&mrt_lock);
2250
2251 return 0;
2252}
2253
2254int ip6mr_get_route(struct net *net, struct sk_buff *skb, struct rtmsg *rtm,
2255 u32 portid)
2256{
2257 int err;
2258 struct mr_table *mrt;
2259 struct mfc6_cache *cache;
2260 struct rt6_info *rt = (struct rt6_info *)skb_dst(skb);
2261
2262 mrt = ip6mr_get_table(net, RT6_TABLE_DFLT);
2263 if (!mrt)
2264 return -ENOENT;
2265
2266 read_lock(&mrt_lock);
2267 cache = ip6mr_cache_find(mrt, &rt->rt6i_src.addr, &rt->rt6i_dst.addr);
2268 if (!cache && skb->dev) {
2269 int vif = ip6mr_find_vif(mrt, skb->dev);
2270
2271 if (vif >= 0)
2272 cache = ip6mr_cache_find_any(mrt, &rt->rt6i_dst.addr,
2273 vif);
2274 }
2275
2276 if (!cache) {
2277 struct sk_buff *skb2;
2278 struct ipv6hdr *iph;
2279 struct net_device *dev;
2280 int vif;
2281
2282 dev = skb->dev;
2283 if (!dev || (vif = ip6mr_find_vif(mrt, dev)) < 0) {
2284 read_unlock(&mrt_lock);
2285 return -ENODEV;
2286 }
2287
2288 /* really correct? */
2289 skb2 = alloc_skb(sizeof(struct ipv6hdr), GFP_ATOMIC);
2290 if (!skb2) {
2291 read_unlock(&mrt_lock);
2292 return -ENOMEM;
2293 }
2294
2295 NETLINK_CB(skb2).portid = portid;
2296 skb_reset_transport_header(skb2);
2297
2298 skb_put(skb2, sizeof(struct ipv6hdr));
2299 skb_reset_network_header(skb2);
2300
2301 iph = ipv6_hdr(skb2);
2302 iph->version = 0;
2303 iph->priority = 0;
2304 iph->flow_lbl[0] = 0;
2305 iph->flow_lbl[1] = 0;
2306 iph->flow_lbl[2] = 0;
2307 iph->payload_len = 0;
2308 iph->nexthdr = IPPROTO_NONE;
2309 iph->hop_limit = 0;
2310 iph->saddr = rt->rt6i_src.addr;
2311 iph->daddr = rt->rt6i_dst.addr;
2312
2313 err = ip6mr_cache_unresolved(mrt, vif, skb2, dev);
2314 read_unlock(&mrt_lock);
2315
2316 return err;
2317 }
2318
2319 err = mr_fill_mroute(mrt, skb, &cache->_c, rtm);
2320 read_unlock(&mrt_lock);
2321 return err;
2322}
2323
2324static int ip6mr_fill_mroute(struct mr_table *mrt, struct sk_buff *skb,
2325 u32 portid, u32 seq, struct mfc6_cache *c, int cmd,
2326 int flags)
2327{
2328 struct nlmsghdr *nlh;
2329 struct rtmsg *rtm;
2330 int err;
2331
2332 nlh = nlmsg_put(skb, portid, seq, cmd, sizeof(*rtm), flags);
2333 if (!nlh)
2334 return -EMSGSIZE;
2335
2336 rtm = nlmsg_data(nlh);
2337 rtm->rtm_family = RTNL_FAMILY_IP6MR;
2338 rtm->rtm_dst_len = 128;
2339 rtm->rtm_src_len = 128;
2340 rtm->rtm_tos = 0;
2341 rtm->rtm_table = mrt->id;
2342 if (nla_put_u32(skb, RTA_TABLE, mrt->id))
2343 goto nla_put_failure;
2344 rtm->rtm_type = RTN_MULTICAST;
2345 rtm->rtm_scope = RT_SCOPE_UNIVERSE;
2346 if (c->_c.mfc_flags & MFC_STATIC)
2347 rtm->rtm_protocol = RTPROT_STATIC;
2348 else
2349 rtm->rtm_protocol = RTPROT_MROUTED;
2350 rtm->rtm_flags = 0;
2351
2352 if (nla_put_in6_addr(skb, RTA_SRC, &c->mf6c_origin) ||
2353 nla_put_in6_addr(skb, RTA_DST, &c->mf6c_mcastgrp))
2354 goto nla_put_failure;
2355 err = mr_fill_mroute(mrt, skb, &c->_c, rtm);
2356 /* do not break the dump if cache is unresolved */
2357 if (err < 0 && err != -ENOENT)
2358 goto nla_put_failure;
2359
2360 nlmsg_end(skb, nlh);
2361 return 0;
2362
2363nla_put_failure:
2364 nlmsg_cancel(skb, nlh);
2365 return -EMSGSIZE;
2366}
2367
2368static int _ip6mr_fill_mroute(struct mr_table *mrt, struct sk_buff *skb,
2369 u32 portid, u32 seq, struct mr_mfc *c,
2370 int cmd, int flags)
2371{
2372 return ip6mr_fill_mroute(mrt, skb, portid, seq, (struct mfc6_cache *)c,
2373 cmd, flags);
2374}
2375
2376static int mr6_msgsize(bool unresolved, int maxvif)
2377{
2378 size_t len =
2379 NLMSG_ALIGN(sizeof(struct rtmsg))
2380 + nla_total_size(4) /* RTA_TABLE */
2381 + nla_total_size(sizeof(struct in6_addr)) /* RTA_SRC */
2382 + nla_total_size(sizeof(struct in6_addr)) /* RTA_DST */
2383 ;
2384
2385 if (!unresolved)
2386 len = len
2387 + nla_total_size(4) /* RTA_IIF */
2388 + nla_total_size(0) /* RTA_MULTIPATH */
2389 + maxvif * NLA_ALIGN(sizeof(struct rtnexthop))
2390 /* RTA_MFC_STATS */
2391 + nla_total_size_64bit(sizeof(struct rta_mfc_stats))
2392 ;
2393
2394 return len;
2395}
2396
2397static void mr6_netlink_event(struct mr_table *mrt, struct mfc6_cache *mfc,
2398 int cmd)
2399{
2400 struct net *net = read_pnet(&mrt->net);
2401 struct sk_buff *skb;
2402 int err = -ENOBUFS;
2403
2404 skb = nlmsg_new(mr6_msgsize(mfc->_c.mfc_parent >= MAXMIFS, mrt->maxvif),
2405 GFP_ATOMIC);
2406 if (!skb)
2407 goto errout;
2408
2409 err = ip6mr_fill_mroute(mrt, skb, 0, 0, mfc, cmd, 0);
2410 if (err < 0)
2411 goto errout;
2412
2413 rtnl_notify(skb, net, 0, RTNLGRP_IPV6_MROUTE, NULL, GFP_ATOMIC);
2414 return;
2415
2416errout:
2417 kfree_skb(skb);
2418 if (err < 0)
2419 rtnl_set_sk_err(net, RTNLGRP_IPV6_MROUTE, err);
2420}
2421
2422static size_t mrt6msg_netlink_msgsize(size_t payloadlen)
2423{
2424 size_t len =
2425 NLMSG_ALIGN(sizeof(struct rtgenmsg))
2426 + nla_total_size(1) /* IP6MRA_CREPORT_MSGTYPE */
2427 + nla_total_size(4) /* IP6MRA_CREPORT_MIF_ID */
2428 /* IP6MRA_CREPORT_SRC_ADDR */
2429 + nla_total_size(sizeof(struct in6_addr))
2430 /* IP6MRA_CREPORT_DST_ADDR */
2431 + nla_total_size(sizeof(struct in6_addr))
2432 /* IP6MRA_CREPORT_PKT */
2433 + nla_total_size(payloadlen)
2434 ;
2435
2436 return len;
2437}
2438
2439static void mrt6msg_netlink_event(struct mr_table *mrt, struct sk_buff *pkt)
2440{
2441 struct net *net = read_pnet(&mrt->net);
2442 struct nlmsghdr *nlh;
2443 struct rtgenmsg *rtgenm;
2444 struct mrt6msg *msg;
2445 struct sk_buff *skb;
2446 struct nlattr *nla;
2447 int payloadlen;
2448
2449 payloadlen = pkt->len - sizeof(struct mrt6msg);
2450 msg = (struct mrt6msg *)skb_transport_header(pkt);
2451
2452 skb = nlmsg_new(mrt6msg_netlink_msgsize(payloadlen), GFP_ATOMIC);
2453 if (!skb)
2454 goto errout;
2455
2456 nlh = nlmsg_put(skb, 0, 0, RTM_NEWCACHEREPORT,
2457 sizeof(struct rtgenmsg), 0);
2458 if (!nlh)
2459 goto errout;
2460 rtgenm = nlmsg_data(nlh);
2461 rtgenm->rtgen_family = RTNL_FAMILY_IP6MR;
2462 if (nla_put_u8(skb, IP6MRA_CREPORT_MSGTYPE, msg->im6_msgtype) ||
2463 nla_put_u32(skb, IP6MRA_CREPORT_MIF_ID, msg->im6_mif) ||
2464 nla_put_in6_addr(skb, IP6MRA_CREPORT_SRC_ADDR,
2465 &msg->im6_src) ||
2466 nla_put_in6_addr(skb, IP6MRA_CREPORT_DST_ADDR,
2467 &msg->im6_dst))
2468 goto nla_put_failure;
2469
2470 nla = nla_reserve(skb, IP6MRA_CREPORT_PKT, payloadlen);
2471 if (!nla || skb_copy_bits(pkt, sizeof(struct mrt6msg),
2472 nla_data(nla), payloadlen))
2473 goto nla_put_failure;
2474
2475 nlmsg_end(skb, nlh);
2476
2477 rtnl_notify(skb, net, 0, RTNLGRP_IPV6_MROUTE_R, NULL, GFP_ATOMIC);
2478 return;
2479
2480nla_put_failure:
2481 nlmsg_cancel(skb, nlh);
2482errout:
2483 kfree_skb(skb);
2484 rtnl_set_sk_err(net, RTNLGRP_IPV6_MROUTE_R, -ENOBUFS);
2485}
2486
2487static int ip6mr_rtm_dumproute(struct sk_buff *skb, struct netlink_callback *cb)
2488{
2489 const struct nlmsghdr *nlh = cb->nlh;
2490 struct fib_dump_filter filter = {};
2491 int err;
2492
2493 if (cb->strict_check) {
2494 err = ip_valid_fib_dump_req(sock_net(skb->sk), nlh,
2495 &filter, cb);
2496 if (err < 0)
2497 return err;
2498 }
2499
2500 if (filter.table_id) {
2501 struct mr_table *mrt;
2502
2503 mrt = ip6mr_get_table(sock_net(skb->sk), filter.table_id);
2504 if (!mrt) {
2505 if (rtnl_msg_family(cb->nlh) != RTNL_FAMILY_IP6MR)
2506 return skb->len;
2507
2508 NL_SET_ERR_MSG_MOD(cb->extack, "MR table does not exist");
2509 return -ENOENT;
2510 }
2511 err = mr_table_dump(mrt, skb, cb, _ip6mr_fill_mroute,
2512 &mfc_unres_lock, &filter);
2513 return skb->len ? : err;
2514 }
2515
2516 return mr_rtm_dumproute(skb, cb, ip6mr_mr_table_iter,
2517 _ip6mr_fill_mroute, &mfc_unres_lock, &filter);
2518}