blob: 600ba1c1befc642434135db5e908ca2fe067e8e1 [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;
Tom Herbert47d3d7a2017-10-30 14:16:00 -070040 int max_dst_opts_cnt;
41 int max_hbh_opts_cnt;
42 int max_dst_opts_len;
43 int max_hbh_opts_len;
Daniel Lezcano760f2d02008-01-10 02:53:43 -080044};
45
Daniel Lezcanob0f159d2008-01-10 02:49:06 -080046struct netns_ipv6 {
Daniel Lezcano760f2d02008-01-10 02:53:43 -080047 struct netns_sysctl_ipv6 sysctl;
Pavel Emelyanove0da5a42008-01-10 17:42:55 -080048 struct ipv6_devconf *devconf_all;
49 struct ipv6_devconf *devconf_dflt;
Gao fengc8a627e2012-06-08 01:20:41 +000050 struct inet_peer_base *peers;
Pavel Emelyanovac18e752008-01-22 06:02:14 -080051 struct netns_frags frags;
Alexey Dobriyan8280aa62008-01-31 04:04:13 -080052#ifdef CONFIG_NETFILTER
53 struct xt_table *ip6table_filter;
54 struct xt_table *ip6table_mangle;
55 struct xt_table *ip6table_raw;
Alexey Dobriyane9d38972010-01-18 08:08:37 +010056#ifdef CONFIG_SECURITY
James Morris17e6e592008-06-09 15:58:05 -070057 struct xt_table *ip6table_security;
Alexey Dobriyan8280aa62008-01-31 04:04:13 -080058#endif
Patrick McHardy58a317f2012-08-26 19:14:12 +020059 struct xt_table *ip6table_nat;
Alexey Dobriyane9d38972010-01-18 08:08:37 +010060#endif
Daniel Lezcano8ed67782008-03-04 13:48:30 -080061 struct rt6_info *ip6_null_entry;
Benjamin Theryc5728722008-03-03 23:34:17 -080062 struct rt6_statistics *rt6_stats;
Stephen Hemminger417f28b2008-07-22 14:33:45 -070063 struct timer_list ip6_fib_timer;
Daniel Lezcano58f09b72008-03-03 23:25:27 -080064 struct hlist_head *fib_table_hash;
65 struct fib6_table *fib6_main_tbl;
Michal Kubeček9a03cd82016-03-08 14:44:35 +010066 struct list_head fib6_walkers;
Alexey Dobriyan86393e52009-08-29 01:34:49 +000067 struct dst_ops ip6_dst_ops;
Michal Kubeček9a03cd82016-03-08 14:44:35 +010068 rwlock_t fib6_walker_lock;
Michal Kubeček3dc94f92016-03-08 14:44:45 +010069 spinlock_t fib6_gc_lock;
Benjamin Thery6891a342008-03-04 13:49:47 -080070 unsigned int ip6_rt_gc_expire;
71 unsigned long ip6_rt_last_gc;
Daniel Lezcano58f09b72008-03-03 23:25:27 -080072#ifdef CONFIG_IPV6_MULTIPLE_TABLES
Vincent Bernatfeca7d82017-08-08 20:23:49 +020073 bool fib6_has_custom_rules;
Daniel Lezcano8ed67782008-03-04 13:48:30 -080074 struct rt6_info *ip6_prohibit_entry;
75 struct rt6_info *ip6_blk_hole_entry;
Daniel Lezcano58f09b72008-03-03 23:25:27 -080076 struct fib6_table *fib6_local_tbl;
Daniel Lezcanodcabb812008-03-03 23:33:08 -080077 struct fib_rules_ops *fib6_rules_ops;
Daniel Lezcano58f09b72008-03-03 23:25:27 -080078#endif
Denis V. Lunev98c6d1b2008-02-29 11:21:22 -080079 struct sock **icmp_sk;
Daniel Lezcano1762f7e2008-03-07 11:15:34 -080080 struct sock *ndisc_sk;
Daniel Lezcano93ec9262008-03-07 11:16:02 -080081 struct sock *tcp_sk;
Daniel Lezcanob8ad0cb2008-03-07 11:16:55 -080082 struct sock *igmp_sk;
Madhu Challa93a714d2015-02-25 09:58:35 -080083 struct sock *mc_autojoin_sk;
Benjamin Therybd91b8b2008-12-10 16:07:08 -080084#ifdef CONFIG_IPV6_MROUTE
Patrick McHardyd1db2752010-05-11 14:40:55 +020085#ifndef CONFIG_IPV6_MROUTE_MULTIPLE_TABLES
Patrick McHardy6bd52142010-05-11 14:40:53 +020086 struct mr6_table *mrt6;
Patrick McHardyd1db2752010-05-11 14:40:55 +020087#else
88 struct list_head mr6_tables;
89 struct fib_rules_ops *mr6_rules_ops;
90#endif
Benjamin Therybd91b8b2008-12-10 16:07:08 -080091#endif
Nicolas Dichtel63998ac2013-03-22 06:28:43 +000092 atomic_t dev_addr_genid;
Hannes Frederic Sowa812918c2014-10-06 19:58:37 +020093 atomic_t fib6_sernum;
David Lebrun915d7e52016-11-08 14:57:40 +010094 struct seg6_pernet_data *seg6_data;
Ido Schimmel16ab6d72017-08-03 13:28:16 +020095 struct fib_notifier_ops *notifier_ops;
Eric Dumazeta90c9342017-09-19 16:27:06 -070096 struct {
97 struct hlist_head head;
98 spinlock_t lock;
99 u32 seq;
100 } ip6addrlbl_table;
Daniel Lezcanob0f159d2008-01-10 02:49:06 -0800101};
Amerigo Wangc038a762012-09-18 16:50:08 +0000102
103#if IS_ENABLED(CONFIG_NF_DEFRAG_IPV6)
104struct netns_nf_frag {
105 struct netns_sysctl_ipv6 sysctl;
106 struct netns_frags frags;
107};
108#endif
109
Daniel Lezcanob0f159d2008-01-10 02:49:06 -0800110#endif