blob: 9a36fad9e068f6bea9e7f4a93ec3d21f2c38046c [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002#ifndef __LINUX_MROUTE_H
3#define __LINUX_MROUTE_H
4
Linus Torvalds1da177e2005-04-16 15:20:36 -07005#include <linux/in.h>
David S. Miller7c19a3d2008-08-29 14:37:23 -07006#include <linux/pim.h>
Yotam Gigi478e4c22017-09-27 08:23:16 +02007#include <net/fib_rules.h>
Yotam Gigi4d65b942017-09-27 08:23:13 +02008#include <net/fib_notifier.h>
David Howells607ca462012-10-13 10:46:48 +01009#include <uapi/linux/mroute.h>
Yuval Mintz6853f212018-02-28 23:29:29 +020010#include <linux/mroute_base.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070011
Pavel Emelyanov6a9fb942007-11-05 21:32:31 -080012#ifdef CONFIG_IP_MROUTE
13static inline int ip_mroute_opt(int opt)
14{
Nikolay Aleksandrov520191b2015-11-26 15:23:46 +010015 return opt >= MRT_BASE && opt <= MRT_MAX;
Pavel Emelyanov6a9fb942007-11-05 21:32:31 -080016}
Pavel Emelyanov6a9fb942007-11-05 21:32:31 -080017
Nikolay Aleksandrov520191b2015-11-26 15:23:46 +010018int ip_mroute_setsockopt(struct sock *, int, char __user *, unsigned int);
19int ip_mroute_getsockopt(struct sock *, int, char __user *, int __user *);
20int ipmr_ioctl(struct sock *sk, int cmd, void __user *arg);
21int ipmr_compat_ioctl(struct sock *sk, unsigned int cmd, void __user *arg);
22int ip_mr_init(void);
Yotam Gigi478e4c22017-09-27 08:23:16 +020023bool ipmr_rule_default(const struct fib_rule *rule);
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090024#else
Nikolay Aleksandrov520191b2015-11-26 15:23:46 +010025static inline int ip_mroute_setsockopt(struct sock *sock, int optname,
26 char __user *optval, unsigned int optlen)
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090027{
28 return -ENOPROTOOPT;
29}
30
Nikolay Aleksandrov520191b2015-11-26 15:23:46 +010031static inline int ip_mroute_getsockopt(struct sock *sock, int optname,
32 char __user *optval, int __user *optlen)
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090033{
34 return -ENOPROTOOPT;
35}
36
Nikolay Aleksandrov520191b2015-11-26 15:23:46 +010037static inline int ipmr_ioctl(struct sock *sk, int cmd, void __user *arg)
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090038{
39 return -ENOIOCTLCMD;
40}
41
42static inline int ip_mr_init(void)
43{
44 return 0;
45}
Nikolay Aleksandrov520191b2015-11-26 15:23:46 +010046
47static inline int ip_mroute_opt(int opt)
48{
49 return 0;
50}
Yotam Gigi478e4c22017-09-27 08:23:16 +020051
52static inline bool ipmr_rule_default(const struct fib_rule *rule)
53{
54 return true;
55}
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090056#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070057
Linus Torvalds1da177e2005-04-16 15:20:36 -070058#define VIFF_STATIC 0x8000
59
Nikolay Aleksandrov8fb472c2017-01-12 15:53:33 +010060struct mfc_cache_cmp_arg {
61 __be32 mfc_mcastgrp;
62 __be32 mfc_origin;
63};
64
65/**
66 * struct mfc_cache - multicast routing entries
Yuval Mintz494fff52018-02-28 23:29:34 +020067 * @_c: Common multicast routing information; has to be first [for casting]
Nikolay Aleksandrov8fb472c2017-01-12 15:53:33 +010068 * @mfc_mcastgrp: destination multicast group address
69 * @mfc_origin: source address
70 * @cmparg: used for rhashtable comparisons
Nikolay Aleksandrov8fb472c2017-01-12 15:53:33 +010071 */
Eric Dumazetd94d9fe2009-11-04 09:50:58 -080072struct mfc_cache {
Yuval Mintz494fff52018-02-28 23:29:34 +020073 struct mr_mfc _c;
Nikolay Aleksandrov8fb472c2017-01-12 15:53:33 +010074 union {
75 struct {
76 __be32 mfc_mcastgrp;
77 __be32 mfc_origin;
78 };
79 struct mfc_cache_cmp_arg cmparg;
80 };
Linus Torvalds1da177e2005-04-16 15:20:36 -070081};
82
Linus Torvalds1da177e2005-04-16 15:20:36 -070083struct rtmsg;
Nikolay Aleksandrov520191b2015-11-26 15:23:46 +010084int ipmr_get_route(struct net *net, struct sk_buff *skb,
85 __be32 saddr, __be32 daddr,
David Ahern9f09eae2017-01-06 17:39:06 -080086 struct rtmsg *rtm, u32 portid);
Linus Torvalds1da177e2005-04-16 15:20:36 -070087#endif