blob: 987cc4569cb8ba6159946f9e87feb04cb681ac8c [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Daniel Lezcanob0f159d2008-01-10 02:49:06 -08002/*
3 * ipv6 in net namespaces
4 */
5
Daniel Lezcanoe71e0342008-01-10 02:56:03 -08006#include <net/inet_frag.h>
7
Daniel Lezcanob0f159d2008-01-10 02:49:06 -08008#ifndef __NETNS_IPV6_H__
9#define __NETNS_IPV6_H__
Alexey Dobriyan86393e52009-08-29 01:34:49 +000010#include <net/dst_ops.h>
Daniel Lezcanob0f159d2008-01-10 02:49:06 -080011
Daniel Lezcano760f2d02008-01-10 02:53:43 -080012struct ctl_table_header;
13
14struct netns_sysctl_ipv6 {
15#ifdef CONFIG_SYSCTL
Eric W. Biederman6dceb032012-04-19 13:37:09 +000016 struct ctl_table_header *hdr;
17 struct ctl_table_header *route_hdr;
18 struct ctl_table_header *icmp_hdr;
Pavel Emelyanove4a2d5c2008-01-22 06:08:36 -080019 struct ctl_table_header *frags_hdr;
Michal Kubecek8d068872013-02-06 10:46:33 +010020 struct ctl_table_header *xfrm6_hdr;
Daniel Lezcano760f2d02008-01-10 02:53:43 -080021#endif
Daniel Lezcano99bc9c42008-01-10 02:54:53 -080022 int bindv6only;
Daniel Lezcano49905092008-01-10 03:01:01 -080023 int flush_delay;
24 int ip6_rt_max_size;
25 int ip6_rt_gc_min_interval;
26 int ip6_rt_gc_timeout;
27 int ip6_rt_gc_interval;
28 int ip6_rt_gc_elasticity;
29 int ip6_rt_mtu_expires;
30 int ip6_rt_min_advmss;
Florent Fourcot6444f722014-01-17 17:15:05 +010031 int flowlabel_consistency;
Tom Herbertcb1ce2e2014-07-01 21:33:10 -070032 int auto_flowlabels;
Daniel Lezcano41a76902008-01-10 03:02:40 -080033 int icmpv6_time;
FX Le Bailec35b612014-01-13 15:59:01 +010034 int anycast_src_echo_reply;
Tom Herbert35a256f2015-07-08 16:58:22 -070035 int ip_nonlocal_bind;
Lorenzo Colittie1108612014-05-13 10:17:33 -070036 int fwmark_reflect;
Hannes Frederic Sowa1855b7c2015-03-23 23:36:05 +010037 int idgen_retries;
38 int idgen_delay;
Tom Herbert82a584b2015-04-29 15:33:21 -070039 int flowlabel_state_ranges;
Jakub Sitnicki22b67222017-08-23 09:55:41 +020040 int flowlabel_reflect;
Tom Herbert47d3d7a2017-10-30 14:16:00 -070041 int max_dst_opts_cnt;
42 int max_hbh_opts_cnt;
43 int max_dst_opts_len;
44 int max_hbh_opts_len;
Daniel Lezcano760f2d02008-01-10 02:53:43 -080045};
46
Daniel Lezcanob0f159d2008-01-10 02:49:06 -080047struct netns_ipv6 {
Daniel Lezcano760f2d02008-01-10 02:53:43 -080048 struct netns_sysctl_ipv6 sysctl;
Pavel Emelyanove0da5a42008-01-10 17:42:55 -080049 struct ipv6_devconf *devconf_all;
50 struct ipv6_devconf *devconf_dflt;
Gao fengc8a627e2012-06-08 01:20:41 +000051 struct inet_peer_base *peers;
Pavel Emelyanovac18e752008-01-22 06:02:14 -080052 struct netns_frags frags;
Alexey Dobriyan8280aa62008-01-31 04:04:13 -080053#ifdef CONFIG_NETFILTER
54 struct xt_table *ip6table_filter;
55 struct xt_table *ip6table_mangle;
56 struct xt_table *ip6table_raw;
Alexey Dobriyane9d38972010-01-18 08:08:37 +010057#ifdef CONFIG_SECURITY
James Morris17e6e592008-06-09 15:58:05 -070058 struct xt_table *ip6table_security;
Alexey Dobriyan8280aa62008-01-31 04:04:13 -080059#endif
Patrick McHardy58a317f2012-08-26 19:14:12 +020060 struct xt_table *ip6table_nat;
Alexey Dobriyane9d38972010-01-18 08:08:37 +010061#endif
Daniel Lezcano8ed67782008-03-04 13:48:30 -080062 struct rt6_info *ip6_null_entry;
Benjamin Theryc5728722008-03-03 23:34:17 -080063 struct rt6_statistics *rt6_stats;
Stephen Hemminger417f28b2008-07-22 14:33:45 -070064 struct timer_list ip6_fib_timer;
Daniel Lezcano58f09b72008-03-03 23:25:27 -080065 struct hlist_head *fib_table_hash;
66 struct fib6_table *fib6_main_tbl;
Michal Kubeček9a03cd82016-03-08 14:44:35 +010067 struct list_head fib6_walkers;
Alexey Dobriyan86393e52009-08-29 01:34:49 +000068 struct dst_ops ip6_dst_ops;
Michal Kubeček9a03cd82016-03-08 14:44:35 +010069 rwlock_t fib6_walker_lock;
Michal Kubeček3dc94f92016-03-08 14:44:45 +010070 spinlock_t fib6_gc_lock;
Benjamin Thery6891a342008-03-04 13:49:47 -080071 unsigned int ip6_rt_gc_expire;
72 unsigned long ip6_rt_last_gc;
Daniel Lezcano58f09b72008-03-03 23:25:27 -080073#ifdef CONFIG_IPV6_MULTIPLE_TABLES
Vincent Bernatfeca7d82017-08-08 20:23:49 +020074 bool fib6_has_custom_rules;
Daniel Lezcano8ed67782008-03-04 13:48:30 -080075 struct rt6_info *ip6_prohibit_entry;
76 struct rt6_info *ip6_blk_hole_entry;
Daniel Lezcano58f09b72008-03-03 23:25:27 -080077 struct fib6_table *fib6_local_tbl;
Daniel Lezcanodcabb812008-03-03 23:33:08 -080078 struct fib_rules_ops *fib6_rules_ops;
Daniel Lezcano58f09b72008-03-03 23:25:27 -080079#endif
Denis V. Lunev98c6d1b2008-02-29 11:21:22 -080080 struct sock **icmp_sk;
Daniel Lezcano1762f7e2008-03-07 11:15:34 -080081 struct sock *ndisc_sk;
Daniel Lezcano93ec9262008-03-07 11:16:02 -080082 struct sock *tcp_sk;
Daniel Lezcanob8ad0cb2008-03-07 11:16:55 -080083 struct sock *igmp_sk;
Madhu Challa93a714d2015-02-25 09:58:35 -080084 struct sock *mc_autojoin_sk;
Benjamin Therybd91b8b2008-12-10 16:07:08 -080085#ifdef CONFIG_IPV6_MROUTE
Patrick McHardyd1db2752010-05-11 14:40:55 +020086#ifndef CONFIG_IPV6_MROUTE_MULTIPLE_TABLES
Patrick McHardy6bd52142010-05-11 14:40:53 +020087 struct mr6_table *mrt6;
Patrick McHardyd1db2752010-05-11 14:40:55 +020088#else
89 struct list_head mr6_tables;
90 struct fib_rules_ops *mr6_rules_ops;
91#endif
Benjamin Therybd91b8b2008-12-10 16:07:08 -080092#endif
Nicolas Dichtel63998ac2013-03-22 06:28:43 +000093 atomic_t dev_addr_genid;
Hannes Frederic Sowa812918c2014-10-06 19:58:37 +020094 atomic_t fib6_sernum;
David Lebrun915d7e52016-11-08 14:57:40 +010095 struct seg6_pernet_data *seg6_data;
Ido Schimmel16ab6d72017-08-03 13:28:16 +020096 struct fib_notifier_ops *notifier_ops;
Eric Dumazeta90c9342017-09-19 16:27:06 -070097 struct {
98 struct hlist_head head;
99 spinlock_t lock;
100 u32 seq;
101 } ip6addrlbl_table;
Daniel Lezcanob0f159d2008-01-10 02:49:06 -0800102};
Amerigo Wangc038a762012-09-18 16:50:08 +0000103
104#if IS_ENABLED(CONFIG_NF_DEFRAG_IPV6)
105struct netns_nf_frag {
106 struct netns_sysctl_ipv6 sysctl;
107 struct netns_frags frags;
108};
109#endif
110
Daniel Lezcanob0f159d2008-01-10 02:49:06 -0800111#endif