blob: e1b9fb06e1ea6609dcc4f2a2aada6329a9499ced [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>
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090011
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090012#ifdef CONFIG_IPV6_MROUTE
13static inline int ip6_mroute_opt(int opt)
14{
Nicolas Dichtelbbb923a2013-01-21 06:00:25 +000015 return (opt >= MRT6_BASE) && (opt <= MRT6_MAX);
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090016}
17#else
18static inline int ip6_mroute_opt(int opt)
19{
20 return 0;
21}
22#endif
23
24struct sock;
25
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090026#ifdef CONFIG_IPV6_MROUTE
David S. Millerb7058842009-09-30 16:12:20 -070027extern int ip6_mroute_setsockopt(struct sock *, int, char __user *, unsigned int);
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090028extern int ip6_mroute_getsockopt(struct sock *, int, char __user *, int __user *);
29extern int ip6_mr_input(struct sk_buff *skb);
30extern int ip6mr_ioctl(struct sock *sk, int cmd, void __user *arg);
David S. Millere2d57762011-02-03 17:59:32 -080031extern int ip6mr_compat_ioctl(struct sock *sk, unsigned int cmd, void __user *arg);
Wang Chen623d1a12008-07-03 12:13:30 +080032extern int ip6_mr_init(void);
33extern void ip6_mr_cleanup(void);
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090034#else
35static inline
36int ip6_mroute_setsockopt(struct sock *sock,
David S. Millerb7058842009-09-30 16:12:20 -070037 int optname, char __user *optval, unsigned int optlen)
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090038{
39 return -ENOPROTOOPT;
40}
41
42static inline
43int ip6_mroute_getsockopt(struct sock *sock,
44 int optname, char __user *optval, int __user *optlen)
45{
46 return -ENOPROTOOPT;
47}
48
49static inline
50int ip6mr_ioctl(struct sock *sk, int cmd, void __user *arg)
51{
52 return -ENOIOCTLCMD;
53}
54
55static inline int ip6_mr_init(void)
56{
57 return 0;
58}
59
60static inline void ip6_mr_cleanup(void)
61{
62 return;
63}
64#endif
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090065
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090066#define VIFF_STATIC 0x8000
67
Eric Dumazetd94d9fe2009-11-04 09:50:58 -080068struct mfc6_cache {
Patrick McHardyf30a77842010-05-11 14:40:51 +020069 struct list_head list;
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090070 struct in6_addr mf6c_mcastgrp; /* Group the entry belongs to */
71 struct in6_addr mf6c_origin; /* Source of packet */
72 mifi_t mf6c_parent; /* Source interface */
73 int mfc_flags; /* Flags on line */
74
75 union {
76 struct {
77 unsigned long expires;
78 struct sk_buff_head unresolved; /* Unresolved buffers */
79 } unres;
80 struct {
81 unsigned long last_assert;
82 int minvif;
83 int maxvif;
84 unsigned long bytes;
85 unsigned long pkt;
86 unsigned long wrong_if;
Nikolay Aleksandrov43b9e122016-07-14 19:28:27 +030087 unsigned long lastuse;
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090088 unsigned char ttls[MAXMIFS]; /* TTL thresholds */
89 } res;
90 } mfc_un;
91};
92
93#define MFC_STATIC 1
94#define MFC_NOTIFY 2
95
96#define MFC6_LINES 64
97
98#define MFC6_HASH(a, g) (((__force u32)(a)->s6_addr32[0] ^ \
99 (__force u32)(a)->s6_addr32[1] ^ \
100 (__force u32)(a)->s6_addr32[2] ^ \
101 (__force u32)(a)->s6_addr32[3] ^ \
102 (__force u32)(g)->s6_addr32[0] ^ \
103 (__force u32)(g)->s6_addr32[1] ^ \
104 (__force u32)(g)->s6_addr32[2] ^ \
105 (__force u32)(g)->s6_addr32[3]) % MFC6_LINES)
106
107#define MFC_ASSERT_THRESH (3*HZ) /* Maximal freq. of asserts */
108
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900109struct rtmsg;
Benjamin Thery8229efd2008-12-10 16:30:15 -0800110extern int ip6mr_get_route(struct net *net, struct sk_buff *skb,
David Ahernfd61c6b2017-01-17 15:51:07 -0800111 struct rtmsg *rtm, u32 portid);
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900112
113#ifdef CONFIG_IPV6_MROUTE
Yuval Mintz8571ab42018-02-28 23:29:30 +0200114bool mroute6_is_socket(struct net *net, struct sk_buff *skb);
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900115extern int ip6mr_sk_done(struct sock *sk);
116#else
Yuval Mintz8571ab42018-02-28 23:29:30 +0200117static inline bool mroute6_is_socket(struct net *net, struct sk_buff *skb)
Patrick McHardyd1db2752010-05-11 14:40:55 +0200118{
Yuval Mintz8571ab42018-02-28 23:29:30 +0200119 return false;
Patrick McHardyd1db2752010-05-11 14:40:55 +0200120}
121static inline int ip6mr_sk_done(struct sock *sk)
122{
123 return 0;
124}
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900125#endif
126#endif