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 13 struct ctl_table_header; 14 15 struct 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 u32 ioam6_id; 55 u64 ioam6_id_wide; 56 u8 skip_notify_on_dev_down; 57 u8 fib_notify_on_flag_change; 58 u8 icmpv6_error_anycast_as_unicast; 59 }; 60 61 struct netns_ipv6 { 62 /* Keep ip6_dst_ops at the beginning of netns_sysctl_ipv6 */ 63 struct dst_ops ip6_dst_ops; 64 65 struct netns_sysctl_ipv6 sysctl; 66 struct ipv6_devconf *devconf_all; 67 struct ipv6_devconf *devconf_dflt; 68 struct inet_peer_base *peers; 69 struct fqdir *fqdir; 70 struct fib6_info *fib6_null_entry; 71 struct rt6_info *ip6_null_entry; 72 struct rt6_statistics *rt6_stats; 73 struct timer_list ip6_fib_timer; 74 struct hlist_head *fib_table_hash; 75 struct fib6_table *fib6_main_tbl; 76 struct list_head fib6_walkers; 77 rwlock_t fib6_walker_lock; 78 spinlock_t fib6_gc_lock; 79 atomic_t ip6_rt_gc_expire; 80 unsigned long ip6_rt_last_gc; 81 unsigned char flowlabel_has_excl; 82 #ifdef CONFIG_IPV6_MULTIPLE_TABLES 83 bool fib6_has_custom_rules; 84 unsigned int fib6_rules_require_fldissect; 85 #ifdef CONFIG_IPV6_SUBTREES 86 unsigned int fib6_routes_require_src; 87 #endif 88 struct rt6_info *ip6_prohibit_entry; 89 struct rt6_info *ip6_blk_hole_entry; 90 struct fib6_table *fib6_local_tbl; 91 struct fib_rules_ops *fib6_rules_ops; 92 #endif 93 struct sock *ndisc_sk; 94 struct sock *tcp_sk; 95 struct sock *igmp_sk; 96 struct sock *mc_autojoin_sk; 97 98 struct hlist_head *inet6_addr_lst; 99 spinlock_t addrconf_hash_lock; 100 struct delayed_work addr_chk_work; 101 102 #ifdef CONFIG_IPV6_MROUTE 103 #ifndef CONFIG_IPV6_MROUTE_MULTIPLE_TABLES 104 struct mr_table *mrt6; 105 #else 106 struct list_head mr6_tables; 107 struct fib_rules_ops *mr6_rules_ops; 108 #endif 109 #endif 110 atomic_t dev_addr_genid; 111 atomic_t fib6_sernum; 112 struct seg6_pernet_data *seg6_data; 113 struct fib_notifier_ops *notifier_ops; 114 struct fib_notifier_ops *ip6mr_notifier_ops; 115 unsigned int ipmr_seq; /* protected by rtnl_mutex */ 116 struct { 117 struct hlist_head head; 118 spinlock_t lock; 119 u32 seq; 120 } ip6addrlbl_table; 121 struct ioam6_pernet_data *ioam6_data; 122 }; 123 124 #if IS_ENABLED(CONFIG_NF_DEFRAG_IPV6) 125 struct netns_nf_frag { 126 struct fqdir *fqdir; 127 }; 128 #endif 129 130 #endif 131