ipv4.h 2.7 KB
Newer Older
1 2 3 4 5 6
/*
 * ipv4 in net namespaces
 */

#ifndef __NETNS_IPV4_H__
#define __NETNS_IPV4_H__
7

8
#include <linux/uidgid.h>
9
#include <net/inet_frag.h>
10
#include <linux/rcupdate.h>
11

12
struct tcpm_hash_bucket;
13 14
struct ctl_table_header;
struct ipv4_devconf;
15
struct fib_rules_ops;
16
struct hlist_head;
17
struct fib_table;
18
struct sock;
19 20 21
struct local_ports {
	seqlock_t	lock;
	int		range[2];
22
	bool		warned;
23
};
24

25 26 27 28 29
struct ping_group_range {
	seqlock_t	lock;
	kgid_t		range[2];
};

30
struct netns_ipv4 {
31
#ifdef CONFIG_SYSCTL
32
	struct ctl_table_header	*forw_hdr;
33
	struct ctl_table_header	*frags_hdr;
34
	struct ctl_table_header	*ipv4_hdr;
35
	struct ctl_table_header *route_hdr;
36
	struct ctl_table_header *xfrm4_hdr;
37
#endif
38 39
	struct ipv4_devconf	*devconf_all;
	struct ipv4_devconf	*devconf_dflt;
40 41
#ifdef CONFIG_IP_MULTIPLE_TABLES
	struct fib_rules_ops	*rules_ops;
42
	bool			fib_has_custom_rules;
43 44 45
	struct fib_table __rcu	*fib_local;
	struct fib_table __rcu	*fib_main;
	struct fib_table __rcu	*fib_default;
46 47 48
#endif
#ifdef CONFIG_IP_ROUTE_CLASSID
	int			fib_num_tclassid_users;
49
#endif
50
	struct hlist_head	*fib_table_hash;
51
	bool			fib_offload_disabled;
52
	struct sock		*fibnl;
53

E
Eric Dumazet 已提交
54
	struct sock  * __percpu	*icmp_sk;
55
	struct sock		*mc_autojoin_sk;
E
Eric Dumazet 已提交
56

57
	struct inet_peer_base	*peers;
58
	struct sock  * __percpu	*tcp_sk;
59
	struct netns_frags	frags;
60 61 62 63
#ifdef CONFIG_NETFILTER
	struct xt_table		*iptable_filter;
	struct xt_table		*iptable_mangle;
	struct xt_table		*iptable_raw;
64
	struct xt_table		*arptable_filter;
65
#ifdef CONFIG_SECURITY
66
	struct xt_table		*iptable_security;
67
#endif
68
	struct xt_table		*nat_table;
69
#endif
70 71 72 73 74 75 76

	int sysctl_icmp_echo_ignore_all;
	int sysctl_icmp_echo_ignore_broadcasts;
	int sysctl_icmp_ignore_bogus_error_responses;
	int sysctl_icmp_ratelimit;
	int sysctl_icmp_ratemask;
	int sysctl_icmp_errors_use_inbound_ifaddr;
77

78
	struct local_ports ip_local_ports;
79

80
	int sysctl_tcp_ecn;
81 82
	int sysctl_tcp_ecn_fallback;

83
	int sysctl_ip_no_pmtu_disc;
84
	int sysctl_ip_fwd_use_pmtu;
85
	int sysctl_ip_nonlocal_bind;
86

87
	int sysctl_fwmark_reflect;
88
	int sysctl_tcp_fwmark_accept;
89 90 91
#ifdef CONFIG_NET_L3_MASTER_DEV
	int sysctl_tcp_l3mdev_accept;
#endif
F
Fan Du 已提交
92 93
	int sysctl_tcp_mtu_probing;
	int sysctl_tcp_base_mss;
94
	int sysctl_tcp_probe_threshold;
95
	u32 sysctl_tcp_probe_interval;
96

97
	int sysctl_tcp_keepalive_time;
98
	int sysctl_tcp_keepalive_probes;
99
	int sysctl_tcp_keepalive_intvl;
100

101
	int sysctl_tcp_syn_retries;
102
	int sysctl_tcp_synack_retries;
103
	int sysctl_tcp_syncookies;
104
	int sysctl_tcp_reordering;
105

106
	struct ping_group_range ping_group_range;
107

108
	atomic_t dev_addr_genid;
109

110 111 112 113
#ifdef CONFIG_SYSCTL
	unsigned long *sysctl_local_reserved_ports;
#endif

114
#ifdef CONFIG_IP_MROUTE
115
#ifndef CONFIG_IP_MROUTE_MULTIPLE_TABLES
116
	struct mr_table		*mrt;
117 118 119 120
#else
	struct list_head	mr_tables;
	struct fib_rules_ops	*mr_rules_ops;
#endif
121
#endif
F
fan.du 已提交
122
	atomic_t	rt_genid;
123 124
};
#endif