blob: 2544f9760a4263b7f1b8d622331ca63038586137 [file] [log] [blame]
Daniel Lezcanob0f159d2008-01-10 02:49:06 -08001/*
2 * ipv6 in net namespaces
3 */
4
Daniel Lezcanoe71e0342008-01-10 02:56:03 -08005#include <net/inet_frag.h>
6
Daniel Lezcanob0f159d2008-01-10 02:49:06 -08007#ifndef __NETNS_IPV6_H__
8#define __NETNS_IPV6_H__
Alexey Dobriyan86393e52009-08-29 01:34:49 +00009#include <net/dst_ops.h>
Daniel Lezcanob0f159d2008-01-10 02:49:06 -080010
Daniel Lezcano760f2d02008-01-10 02:53:43 -080011struct ctl_table_header;
12
13struct netns_sysctl_ipv6 {
14#ifdef CONFIG_SYSCTL
Eric W. Biederman6dceb032012-04-19 13:37:09 +000015 struct ctl_table_header *hdr;
16 struct ctl_table_header *route_hdr;
17 struct ctl_table_header *icmp_hdr;
Pavel Emelyanove4a2d5c2008-01-22 06:08:36 -080018 struct ctl_table_header *frags_hdr;
Michal Kubecek8d068872013-02-06 10:46:33 +010019 struct ctl_table_header *xfrm6_hdr;
Daniel Lezcano760f2d02008-01-10 02:53:43 -080020#endif
Daniel Lezcano99bc9c42008-01-10 02:54:53 -080021 int bindv6only;
Daniel Lezcano49905092008-01-10 03:01:01 -080022 int flush_delay;
23 int ip6_rt_max_size;
24 int ip6_rt_gc_min_interval;
25 int ip6_rt_gc_timeout;
26 int ip6_rt_gc_interval;
27 int ip6_rt_gc_elasticity;
28 int ip6_rt_mtu_expires;
29 int ip6_rt_min_advmss;
Florent Fourcot6444f722014-01-17 17:15:05 +010030 int flowlabel_consistency;
Tom Herbertcb1ce2e2014-07-01 21:33:10 -070031 int auto_flowlabels;
Daniel Lezcano41a76902008-01-10 03:02:40 -080032 int icmpv6_time;
FX Le Bailec35b612014-01-13 15:59:01 +010033 int anycast_src_echo_reply;
Tom Herbert35a256f2015-07-08 16:58:22 -070034 int ip_nonlocal_bind;
Lorenzo Colittie1108612014-05-13 10:17:33 -070035 int fwmark_reflect;
Hannes Frederic Sowa1855b7c2015-03-23 23:36:05 +010036 int idgen_retries;
37 int idgen_delay;
Tom Herbert82a584b2015-04-29 15:33:21 -070038 int flowlabel_state_ranges;
Jakub Sitnicki22b67222017-08-23 09:55:41 +020039 int flowlabel_reflect;
Daniel Lezcano760f2d02008-01-10 02:53:43 -080040};
41
Daniel Lezcanob0f159d2008-01-10 02:49:06 -080042struct netns_ipv6 {
Daniel Lezcano760f2d02008-01-10 02:53:43 -080043 struct netns_sysctl_ipv6 sysctl;
Pavel Emelyanove0da5a42008-01-10 17:42:55 -080044 struct ipv6_devconf *devconf_all;
45 struct ipv6_devconf *devconf_dflt;
Gao fengc8a627e2012-06-08 01:20:41 +000046 struct inet_peer_base *peers;
Pavel Emelyanovac18e752008-01-22 06:02:14 -080047 struct netns_frags frags;
Alexey Dobriyan8280aa62008-01-31 04:04:13 -080048#ifdef CONFIG_NETFILTER
49 struct xt_table *ip6table_filter;
50 struct xt_table *ip6table_mangle;
51 struct xt_table *ip6table_raw;
Alexey Dobriyane9d38972010-01-18 08:08:37 +010052#ifdef CONFIG_SECURITY
James Morris17e6e592008-06-09 15:58:05 -070053 struct xt_table *ip6table_security;
Alexey Dobriyan8280aa62008-01-31 04:04:13 -080054#endif
Patrick McHardy58a317f2012-08-26 19:14:12 +020055 struct xt_table *ip6table_nat;
Alexey Dobriyane9d38972010-01-18 08:08:37 +010056#endif
Daniel Lezcano8ed67782008-03-04 13:48:30 -080057 struct rt6_info *ip6_null_entry;
Benjamin Theryc5728722008-03-03 23:34:17 -080058 struct rt6_statistics *rt6_stats;
Stephen Hemminger417f28b2008-07-22 14:33:45 -070059 struct timer_list ip6_fib_timer;
Daniel Lezcano58f09b72008-03-03 23:25:27 -080060 struct hlist_head *fib_table_hash;
61 struct fib6_table *fib6_main_tbl;
Michal Kubeček9a03cd82016-03-08 14:44:35 +010062 struct list_head fib6_walkers;
Alexey Dobriyan86393e52009-08-29 01:34:49 +000063 struct dst_ops ip6_dst_ops;
Michal Kubeček9a03cd82016-03-08 14:44:35 +010064 rwlock_t fib6_walker_lock;
Michal Kubeček3dc94f92016-03-08 14:44:45 +010065 spinlock_t fib6_gc_lock;
Benjamin Thery6891a342008-03-04 13:49:47 -080066 unsigned int ip6_rt_gc_expire;
67 unsigned long ip6_rt_last_gc;
Daniel Lezcano58f09b72008-03-03 23:25:27 -080068#ifdef CONFIG_IPV6_MULTIPLE_TABLES
Vincent Bernatfeca7d82017-08-08 20:23:49 +020069 bool fib6_has_custom_rules;
Daniel Lezcano8ed67782008-03-04 13:48:30 -080070 struct rt6_info *ip6_prohibit_entry;
71 struct rt6_info *ip6_blk_hole_entry;
Daniel Lezcano58f09b72008-03-03 23:25:27 -080072 struct fib6_table *fib6_local_tbl;
Daniel Lezcanodcabb812008-03-03 23:33:08 -080073 struct fib_rules_ops *fib6_rules_ops;
Daniel Lezcano58f09b72008-03-03 23:25:27 -080074#endif
Denis V. Lunev98c6d1b2008-02-29 11:21:22 -080075 struct sock **icmp_sk;
Daniel Lezcano1762f7e2008-03-07 11:15:34 -080076 struct sock *ndisc_sk;
Daniel Lezcano93ec9262008-03-07 11:16:02 -080077 struct sock *tcp_sk;
Daniel Lezcanob8ad0cb2008-03-07 11:16:55 -080078 struct sock *igmp_sk;
Madhu Challa93a714d2015-02-25 09:58:35 -080079 struct sock *mc_autojoin_sk;
Benjamin Therybd91b8b2008-12-10 16:07:08 -080080#ifdef CONFIG_IPV6_MROUTE
Patrick McHardyd1db2752010-05-11 14:40:55 +020081#ifndef CONFIG_IPV6_MROUTE_MULTIPLE_TABLES
Patrick McHardy6bd52142010-05-11 14:40:53 +020082 struct mr6_table *mrt6;
Patrick McHardyd1db2752010-05-11 14:40:55 +020083#else
84 struct list_head mr6_tables;
85 struct fib_rules_ops *mr6_rules_ops;
86#endif
Benjamin Therybd91b8b2008-12-10 16:07:08 -080087#endif
Nicolas Dichtel63998ac2013-03-22 06:28:43 +000088 atomic_t dev_addr_genid;
Hannes Frederic Sowa812918c2014-10-06 19:58:37 +020089 atomic_t fib6_sernum;
David Lebrun915d7e52016-11-08 14:57:40 +010090 struct seg6_pernet_data *seg6_data;
Ido Schimmel16ab6d72017-08-03 13:28:16 +020091 struct fib_notifier_ops *notifier_ops;
Daniel Lezcanob0f159d2008-01-10 02:49:06 -080092};
Amerigo Wangc038a762012-09-18 16:50:08 +000093
94#if IS_ENABLED(CONFIG_NF_DEFRAG_IPV6)
95struct netns_nf_frag {
96 struct netns_sysctl_ipv6 sysctl;
97 struct netns_frags frags;
98};
99#endif
100
Daniel Lezcanob0f159d2008-01-10 02:49:06 -0800101#endif