blob: e2dac199861e354b069913fdbce1bde763da6c62 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +09002#ifndef __LINUX_MROUTE6_H
3#define __LINUX_MROUTE6_H
4
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +09005
David S. Miller7c19a3d2008-08-29 14:37:23 -07006#include <linux/pim.h>
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +09007#include <linux/skbuff.h> /* for struct sk_buff_head */
Benjamin Therybd91b8b2008-12-10 16:07:08 -08008#include <net/net_namespace.h>
David Howells607ca462012-10-13 10:46:48 +01009#include <uapi/linux/mroute6.h>
Yuval Mintz6853f212018-02-28 23:29:29 +020010#include <linux/mroute_base.h>
Yuval Mintz87c418b2018-02-28 23:29:31 +020011#include <linux/rhashtable.h>
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090012
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090013#ifdef CONFIG_IPV6_MROUTE
14static inline int ip6_mroute_opt(int opt)
15{
Nicolas Dichtelbbb923a2013-01-21 06:00:25 +000016 return (opt >= MRT6_BASE) && (opt <= MRT6_MAX);
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090017}
18#else
19static inline int ip6_mroute_opt(int opt)
20{
21 return 0;
22}
23#endif
24
25struct sock;
26
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090027#ifdef CONFIG_IPV6_MROUTE
David S. Millerb7058842009-09-30 16:12:20 -070028extern int ip6_mroute_setsockopt(struct sock *, int, char __user *, unsigned int);
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090029extern int ip6_mroute_getsockopt(struct sock *, int, char __user *, int __user *);
30extern int ip6_mr_input(struct sk_buff *skb);
31extern int ip6mr_ioctl(struct sock *sk, int cmd, void __user *arg);
David S. Millere2d57762011-02-03 17:59:32 -080032extern int ip6mr_compat_ioctl(struct sock *sk, unsigned int cmd, void __user *arg);
Wang Chen623d1a12008-07-03 12:13:30 +080033extern int ip6_mr_init(void);
34extern void ip6_mr_cleanup(void);
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090035#else
36static inline
37int ip6_mroute_setsockopt(struct sock *sock,
David S. Millerb7058842009-09-30 16:12:20 -070038 int optname, char __user *optval, unsigned int optlen)
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090039{
40 return -ENOPROTOOPT;
41}
42
43static inline
44int ip6_mroute_getsockopt(struct sock *sock,
45 int optname, char __user *optval, int __user *optlen)
46{
47 return -ENOPROTOOPT;
48}
49
50static inline
51int ip6mr_ioctl(struct sock *sk, int cmd, void __user *arg)
52{
53 return -ENOIOCTLCMD;
54}
55
56static inline int ip6_mr_init(void)
57{
58 return 0;
59}
60
61static inline void ip6_mr_cleanup(void)
62{
63 return;
64}
65#endif
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090066
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090067#define VIFF_STATIC 0x8000
68
Yuval Mintz87c418b2018-02-28 23:29:31 +020069struct mfc6_cache_cmp_arg {
70 struct in6_addr mf6c_mcastgrp;
71 struct in6_addr mf6c_origin;
72};
73
Eric Dumazetd94d9fe2009-11-04 09:50:58 -080074struct mfc6_cache {
Yuval Mintz87c418b2018-02-28 23:29:31 +020075 struct rhlist_head mnode;
76 union {
77 struct {
78 struct in6_addr mf6c_mcastgrp;
79 struct in6_addr mf6c_origin;
80 };
81 struct mfc6_cache_cmp_arg cmparg;
82 };
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090083 mifi_t mf6c_parent; /* Source interface */
84 int mfc_flags; /* Flags on line */
85
86 union {
87 struct {
88 unsigned long expires;
89 struct sk_buff_head unresolved; /* Unresolved buffers */
90 } unres;
91 struct {
92 unsigned long last_assert;
93 int minvif;
94 int maxvif;
95 unsigned long bytes;
96 unsigned long pkt;
97 unsigned long wrong_if;
Nikolay Aleksandrov43b9e122016-07-14 19:28:27 +030098 unsigned long lastuse;
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090099 unsigned char ttls[MAXMIFS]; /* TTL thresholds */
100 } res;
101 } mfc_un;
Yuval Mintz87c418b2018-02-28 23:29:31 +0200102 struct list_head list;
103 struct rcu_head rcu;
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900104};
105
106#define MFC_STATIC 1
107#define MFC_NOTIFY 2
108
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900109#define MFC_ASSERT_THRESH (3*HZ) /* Maximal freq. of asserts */
110
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900111struct rtmsg;
Benjamin Thery8229efd2008-12-10 16:30:15 -0800112extern int ip6mr_get_route(struct net *net, struct sk_buff *skb,
David Ahernfd61c6b2017-01-17 15:51:07 -0800113 struct rtmsg *rtm, u32 portid);
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900114
115#ifdef CONFIG_IPV6_MROUTE
Yuval Mintz8571ab42018-02-28 23:29:30 +0200116bool mroute6_is_socket(struct net *net, struct sk_buff *skb);
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900117extern int ip6mr_sk_done(struct sock *sk);
118#else
Yuval Mintz8571ab42018-02-28 23:29:30 +0200119static inline bool mroute6_is_socket(struct net *net, struct sk_buff *skb)
Patrick McHardyd1db2752010-05-11 14:40:55 +0200120{
Yuval Mintz8571ab42018-02-28 23:29:30 +0200121 return false;
Patrick McHardyd1db2752010-05-11 14:40:55 +0200122}
123static inline int ip6mr_sk_done(struct sock *sk)
124{
125 return 0;
126}
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900127#endif
128#endif