Loading...
1/*
2 * ipv6 in net namespaces
3 */
4
5#include <net/inet_frag.h>
6
7#ifndef __NETNS_IPV6_H__
8#define __NETNS_IPV6_H__
9#include <net/dst_ops.h>
10
11struct ctl_table_header;
12
13struct netns_sysctl_ipv6 {
14#ifdef CONFIG_SYSCTL
15 struct ctl_table_header *hdr;
16 struct ctl_table_header *route_hdr;
17 struct ctl_table_header *icmp_hdr;
18 struct ctl_table_header *frags_hdr;
19 struct ctl_table_header *xfrm6_hdr;
20#endif
21 int bindv6only;
22 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;
30 int flowlabel_consistency;
31 int icmpv6_time;
32 int anycast_src_echo_reply;
33};
34
35struct netns_ipv6 {
36 struct netns_sysctl_ipv6 sysctl;
37 struct ipv6_devconf *devconf_all;
38 struct ipv6_devconf *devconf_dflt;
39 struct inet_peer_base *peers;
40 struct netns_frags frags;
41#ifdef CONFIG_NETFILTER
42 struct xt_table *ip6table_filter;
43 struct xt_table *ip6table_mangle;
44 struct xt_table *ip6table_raw;
45#ifdef CONFIG_SECURITY
46 struct xt_table *ip6table_security;
47#endif
48 struct xt_table *ip6table_nat;
49#endif
50 struct rt6_info *ip6_null_entry;
51 struct rt6_statistics *rt6_stats;
52 struct timer_list ip6_fib_timer;
53 struct hlist_head *fib_table_hash;
54 struct fib6_table *fib6_main_tbl;
55 struct dst_ops ip6_dst_ops;
56 unsigned int ip6_rt_gc_expire;
57 unsigned long ip6_rt_last_gc;
58#ifdef CONFIG_IPV6_MULTIPLE_TABLES
59 struct rt6_info *ip6_prohibit_entry;
60 struct rt6_info *ip6_blk_hole_entry;
61 struct fib6_table *fib6_local_tbl;
62 struct fib_rules_ops *fib6_rules_ops;
63#endif
64 struct sock **icmp_sk;
65 struct sock *ndisc_sk;
66 struct sock *tcp_sk;
67 struct sock *igmp_sk;
68#ifdef CONFIG_IPV6_MROUTE
69#ifndef CONFIG_IPV6_MROUTE_MULTIPLE_TABLES
70 struct mr6_table *mrt6;
71#else
72 struct list_head mr6_tables;
73 struct fib_rules_ops *mr6_rules_ops;
74#endif
75#endif
76 atomic_t dev_addr_genid;
77 atomic_t rt_genid;
78};
79
80#if IS_ENABLED(CONFIG_NF_DEFRAG_IPV6)
81struct netns_nf_frag {
82 struct netns_sysctl_ipv6 sysctl;
83 struct netns_frags frags;
84};
85#endif
86
87#endif
1/* SPDX-License-Identifier: GPL-2.0 */
2/*
3 * ipv6 in net namespaces
4 */
5
6#include <net/inet_frag.h>
7
8#ifndef __NETNS_IPV6_H__
9#define __NETNS_IPV6_H__
10#include <net/dst_ops.h>
11#include <uapi/linux/icmpv6.h>
12
13struct ctl_table_header;
14
15struct netns_sysctl_ipv6 {
16#ifdef CONFIG_SYSCTL
17 struct ctl_table_header *hdr;
18 struct ctl_table_header *route_hdr;
19 struct ctl_table_header *icmp_hdr;
20 struct ctl_table_header *frags_hdr;
21 struct ctl_table_header *xfrm6_hdr;
22#endif
23 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;
31 u32 multipath_hash_fields;
32 u8 multipath_hash_policy;
33 u8 bindv6only;
34 u8 flowlabel_consistency;
35 u8 auto_flowlabels;
36 int icmpv6_time;
37 u8 icmpv6_echo_ignore_all;
38 u8 icmpv6_echo_ignore_multicast;
39 u8 icmpv6_echo_ignore_anycast;
40 DECLARE_BITMAP(icmpv6_ratemask, ICMPV6_MSG_MAX + 1);
41 unsigned long *icmpv6_ratemask_ptr;
42 u8 anycast_src_echo_reply;
43 u8 ip_nonlocal_bind;
44 u8 fwmark_reflect;
45 u8 flowlabel_state_ranges;
46 int idgen_retries;
47 int idgen_delay;
48 int flowlabel_reflect;
49 int max_dst_opts_cnt;
50 int max_hbh_opts_cnt;
51 int max_dst_opts_len;
52 int max_hbh_opts_len;
53 int seg6_flowlabel;
54 bool skip_notify_on_dev_down;
55 u8 fib_notify_on_flag_change;
56};
57
58struct netns_ipv6 {
59 /* Keep ip6_dst_ops at the beginning of netns_sysctl_ipv6 */
60 struct dst_ops ip6_dst_ops;
61
62 struct netns_sysctl_ipv6 sysctl;
63 struct ipv6_devconf *devconf_all;
64 struct ipv6_devconf *devconf_dflt;
65 struct inet_peer_base *peers;
66 struct fqdir *fqdir;
67 struct fib6_info *fib6_null_entry;
68 struct rt6_info *ip6_null_entry;
69 struct rt6_statistics *rt6_stats;
70 struct timer_list ip6_fib_timer;
71 struct hlist_head *fib_table_hash;
72 struct fib6_table *fib6_main_tbl;
73 struct list_head fib6_walkers;
74 rwlock_t fib6_walker_lock;
75 spinlock_t fib6_gc_lock;
76 unsigned int ip6_rt_gc_expire;
77 unsigned long ip6_rt_last_gc;
78#ifdef CONFIG_IPV6_MULTIPLE_TABLES
79 unsigned int fib6_rules_require_fldissect;
80 bool fib6_has_custom_rules;
81#ifdef CONFIG_IPV6_SUBTREES
82 unsigned int fib6_routes_require_src;
83#endif
84 struct rt6_info *ip6_prohibit_entry;
85 struct rt6_info *ip6_blk_hole_entry;
86 struct fib6_table *fib6_local_tbl;
87 struct fib_rules_ops *fib6_rules_ops;
88#endif
89 struct sock * __percpu *icmp_sk;
90 struct sock *ndisc_sk;
91 struct sock *tcp_sk;
92 struct sock *igmp_sk;
93 struct sock *mc_autojoin_sk;
94#ifdef CONFIG_IPV6_MROUTE
95#ifndef CONFIG_IPV6_MROUTE_MULTIPLE_TABLES
96 struct mr_table *mrt6;
97#else
98 struct list_head mr6_tables;
99 struct fib_rules_ops *mr6_rules_ops;
100#endif
101#endif
102 atomic_t dev_addr_genid;
103 atomic_t fib6_sernum;
104 struct seg6_pernet_data *seg6_data;
105 struct fib_notifier_ops *notifier_ops;
106 struct fib_notifier_ops *ip6mr_notifier_ops;
107 unsigned int ipmr_seq; /* protected by rtnl_mutex */
108 struct {
109 struct hlist_head head;
110 spinlock_t lock;
111 u32 seq;
112 } ip6addrlbl_table;
113};
114
115#if IS_ENABLED(CONFIG_NF_DEFRAG_IPV6)
116struct netns_nf_frag {
117 struct fqdir *fqdir;
118};
119#endif
120
121#endif