blob: 3014c52bfd86e6f971ec9e569732d34bf8702282 [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>
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090010
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090011#ifdef CONFIG_IPV6_MROUTE
12static inline int ip6_mroute_opt(int opt)
13{
Nicolas Dichtelbbb923a2013-01-21 06:00:25 +000014 return (opt >= MRT6_BASE) && (opt <= MRT6_MAX);
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090015}
16#else
17static inline int ip6_mroute_opt(int opt)
18{
19 return 0;
20}
21#endif
22
23struct sock;
24
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090025#ifdef CONFIG_IPV6_MROUTE
David S. Millerb7058842009-09-30 16:12:20 -070026extern int ip6_mroute_setsockopt(struct sock *, int, char __user *, unsigned int);
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090027extern int ip6_mroute_getsockopt(struct sock *, int, char __user *, int __user *);
28extern int ip6_mr_input(struct sk_buff *skb);
29extern int ip6mr_ioctl(struct sock *sk, int cmd, void __user *arg);
David S. Millere2d57762011-02-03 17:59:32 -080030extern int ip6mr_compat_ioctl(struct sock *sk, unsigned int cmd, void __user *arg);
Wang Chen623d1a12008-07-03 12:13:30 +080031extern int ip6_mr_init(void);
32extern void ip6_mr_cleanup(void);
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090033#else
34static inline
35int ip6_mroute_setsockopt(struct sock *sock,
David S. Millerb7058842009-09-30 16:12:20 -070036 int optname, char __user *optval, unsigned int optlen)
YOSHIFUJI Hideakie0835f82008-07-03 16:51:22 +090037{
38 return -ENOPROTOOPT;
39}
40
41static inline
42int ip6_mroute_getsockopt(struct sock *sock,
43 int optname, char __user *optval, int __user *optlen)
44{
45 return -ENOPROTOOPT;
46}
47
48static inline
49int ip6mr_ioctl(struct sock *sk, int cmd, void __user *arg)
50{
51 return -ENOIOCTLCMD;
52}
53
54static inline int ip6_mr_init(void)
55{
56 return 0;
57}
58
59static inline void ip6_mr_cleanup(void)
60{
61 return;
62}
63#endif
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090064
Eric Dumazetd94d9fe2009-11-04 09:50:58 -080065struct mif_device {
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090066 struct net_device *dev; /* Device we are using */
67 unsigned long bytes_in,bytes_out;
68 unsigned long pkt_in,pkt_out; /* Statistics */
69 unsigned long rate_limit; /* Traffic shaping (NI) */
70 unsigned char threshold; /* TTL threshold */
71 unsigned short flags; /* Control flags */
72 int link; /* Physical interface index */
73};
74
75#define VIFF_STATIC 0x8000
76
Eric Dumazetd94d9fe2009-11-04 09:50:58 -080077struct mfc6_cache {
Patrick McHardyf30a77842010-05-11 14:40:51 +020078 struct list_head list;
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090079 struct in6_addr mf6c_mcastgrp; /* Group the entry belongs to */
80 struct in6_addr mf6c_origin; /* Source of packet */
81 mifi_t mf6c_parent; /* Source interface */
82 int mfc_flags; /* Flags on line */
83
84 union {
85 struct {
86 unsigned long expires;
87 struct sk_buff_head unresolved; /* Unresolved buffers */
88 } unres;
89 struct {
90 unsigned long last_assert;
91 int minvif;
92 int maxvif;
93 unsigned long bytes;
94 unsigned long pkt;
95 unsigned long wrong_if;
Nikolay Aleksandrov43b9e122016-07-14 19:28:27 +030096 unsigned long lastuse;
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +090097 unsigned char ttls[MAXMIFS]; /* TTL thresholds */
98 } res;
99 } mfc_un;
100};
101
102#define MFC_STATIC 1
103#define MFC_NOTIFY 2
104
105#define MFC6_LINES 64
106
107#define MFC6_HASH(a, g) (((__force u32)(a)->s6_addr32[0] ^ \
108 (__force u32)(a)->s6_addr32[1] ^ \
109 (__force u32)(a)->s6_addr32[2] ^ \
110 (__force u32)(a)->s6_addr32[3] ^ \
111 (__force u32)(g)->s6_addr32[0] ^ \
112 (__force u32)(g)->s6_addr32[1] ^ \
113 (__force u32)(g)->s6_addr32[2] ^ \
114 (__force u32)(g)->s6_addr32[3]) % MFC6_LINES)
115
116#define MFC_ASSERT_THRESH (3*HZ) /* Maximal freq. of asserts */
117
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900118struct rtmsg;
Benjamin Thery8229efd2008-12-10 16:30:15 -0800119extern int ip6mr_get_route(struct net *net, struct sk_buff *skb,
David Ahernfd61c6b2017-01-17 15:51:07 -0800120 struct rtmsg *rtm, u32 portid);
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900121
122#ifdef CONFIG_IPV6_MROUTE
Patrick McHardyd1db2752010-05-11 14:40:55 +0200123extern struct sock *mroute6_socket(struct net *net, struct sk_buff *skb);
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900124extern int ip6mr_sk_done(struct sock *sk);
125#else
Patrick McHardyd1db2752010-05-11 14:40:55 +0200126static inline struct sock *mroute6_socket(struct net *net, struct sk_buff *skb)
127{
128 return NULL;
129}
130static inline int ip6mr_sk_done(struct sock *sk)
131{
132 return 0;
133}
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900134#endif
135#endif