blob: 086c97327b9b7bd02d9b2f3bedeafcfeab58d641 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * sysctl_net_ipv4.c: sysctl interface to net IPV4 subsystem.
3 *
Linus Torvalds1da177e2005-04-16 15:20:36 -07004 * Begun April 1, 1996, Mike Shaver.
5 * Added /proc/sys/net/ipv4 directory entry (empty =) ). [MS]
6 */
7
8#include <linux/mm.h>
9#include <linux/module.h>
10#include <linux/sysctl.h>
Arnaldo Carvalho de Melo20380732005-08-16 02:18:02 -030011#include <linux/igmp.h>
Arnaldo Carvalho de Melo14c85022005-12-27 02:43:12 -020012#include <linux/inetdevice.h>
Stephen Hemminger227b60f2007-10-10 17:30:46 -070013#include <linux/seqlock.h>
Pavel Emelyanov3e37c3f2007-12-05 01:41:26 -080014#include <linux/init.h>
Tejun Heo5a0e3ad2010-03-24 17:04:11 +090015#include <linux/slab.h>
Vasiliy Kulikovc319b4d2011-05-13 10:01:00 +000016#include <linux/nsproxy.h>
Glauber Costa3dc43e32011-12-11 21:47:05 +000017#include <linux/swap.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070018#include <net/snmp.h>
Arnaldo Carvalho de Melo20380732005-08-16 02:18:02 -030019#include <net/icmp.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070020#include <net/ip.h>
21#include <net/route.h>
22#include <net/tcp.h>
Hideo Aoki95766ff2007-12-31 00:29:24 -080023#include <net/udp.h>
Paul Moore446fda42006-08-03 16:48:06 -070024#include <net/cipso_ipv4.h>
Pavel Emelyanov04128f22007-10-15 02:33:45 -070025#include <net/inet_frag.h>
Vasiliy Kulikovc319b4d2011-05-13 10:01:00 +000026#include <net/ping.h>
Glauber Costa3aaabe22011-12-11 21:47:06 +000027#include <net/tcp_memcontrol.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070028
Herbert Xu89cee8b2005-12-13 23:14:27 -080029static int zero;
YOSHIFUJI Hideakie905a9e2007-02-09 23:24:47 +090030static int tcp_retr1_max = 255;
Linus Torvalds1da177e2005-04-16 15:20:36 -070031static int ip_local_port_range_min[] = { 1, 1 };
32static int ip_local_port_range_max[] = { 65535, 65535 };
Alexey Dobriyan0147fc02010-11-22 12:54:21 +000033static int tcp_adv_win_scale_min = -31;
34static int tcp_adv_win_scale_max = 31;
Eric Dumazet249fab72010-12-13 12:16:14 -080035static int ip_ttl_min = 1;
36static int ip_ttl_max = 255;
Michal Tesarf31dfea2013-07-19 14:09:01 +020037static int tcp_syn_retries_min = 1;
38static int tcp_syn_retries_max = MAX_TCP_SYNCNT;
Vasiliy Kulikovc319b4d2011-05-13 10:01:00 +000039static int ip_ping_group_range_min[] = { 0, 0 };
40static int ip_ping_group_range_max[] = { GID_T_MAX, GID_T_MAX };
Linus Torvalds1da177e2005-04-16 15:20:36 -070041
Stephen Hemminger227b60f2007-10-10 17:30:46 -070042/* Update system visible IP port range */
43static void set_local_port_range(int range[2])
44{
Eric Dumazet3c689b72008-10-08 14:18:04 -070045 write_seqlock(&sysctl_local_ports.lock);
46 sysctl_local_ports.range[0] = range[0];
47 sysctl_local_ports.range[1] = range[1];
48 write_sequnlock(&sysctl_local_ports.lock);
Stephen Hemminger227b60f2007-10-10 17:30:46 -070049}
50
51/* Validate changes from /proc interface. */
Alexey Dobriyan8d65af72009-09-23 15:57:19 -070052static int ipv4_local_port_range(ctl_table *table, int write,
Stephen Hemminger227b60f2007-10-10 17:30:46 -070053 void __user *buffer,
54 size_t *lenp, loff_t *ppos)
55{
56 int ret;
Eric Dumazet3c689b72008-10-08 14:18:04 -070057 int range[2];
Stephen Hemminger227b60f2007-10-10 17:30:46 -070058 ctl_table tmp = {
59 .data = &range,
60 .maxlen = sizeof(range),
61 .mode = table->mode,
62 .extra1 = &ip_local_port_range_min,
63 .extra2 = &ip_local_port_range_max,
64 };
65
Eric Dumazet3c689b72008-10-08 14:18:04 -070066 inet_get_local_port_range(range, range + 1);
Alexey Dobriyan8d65af72009-09-23 15:57:19 -070067 ret = proc_dointvec_minmax(&tmp, write, buffer, lenp, ppos);
Stephen Hemminger227b60f2007-10-10 17:30:46 -070068
69 if (write && ret == 0) {
Anton Arapova25de532007-10-18 22:00:17 -070070 if (range[1] < range[0])
Stephen Hemminger227b60f2007-10-10 17:30:46 -070071 ret = -EINVAL;
72 else
73 set_local_port_range(range);
74 }
75
76 return ret;
77}
78
Vasiliy Kulikovc319b4d2011-05-13 10:01:00 +000079
Eric Dumazete6560d42011-12-14 03:51:28 +000080static void inet_get_ping_group_range_table(struct ctl_table *table, gid_t *low, gid_t *high)
Vasiliy Kulikovc319b4d2011-05-13 10:01:00 +000081{
82 gid_t *data = table->data;
83 unsigned seq;
84 do {
85 seq = read_seqbegin(&sysctl_local_ports.lock);
86
87 *low = data[0];
88 *high = data[1];
89 } while (read_seqretry(&sysctl_local_ports.lock, seq));
90}
91
92/* Update system visible IP port range */
Eric Dumazete6560d42011-12-14 03:51:28 +000093static void set_ping_group_range(struct ctl_table *table, gid_t range[2])
Vasiliy Kulikovc319b4d2011-05-13 10:01:00 +000094{
95 gid_t *data = table->data;
96 write_seqlock(&sysctl_local_ports.lock);
97 data[0] = range[0];
98 data[1] = range[1];
99 write_sequnlock(&sysctl_local_ports.lock);
100}
101
102/* Validate changes from /proc interface. */
103static int ipv4_ping_group_range(ctl_table *table, int write,
104 void __user *buffer,
105 size_t *lenp, loff_t *ppos)
106{
107 int ret;
108 gid_t range[2];
109 ctl_table tmp = {
110 .data = &range,
111 .maxlen = sizeof(range),
112 .mode = table->mode,
113 .extra1 = &ip_ping_group_range_min,
114 .extra2 = &ip_ping_group_range_max,
115 };
116
117 inet_get_ping_group_range_table(table, range, range + 1);
118 ret = proc_dointvec_minmax(&tmp, write, buffer, lenp, ppos);
119
120 if (write && ret == 0)
121 set_ping_group_range(table, range);
122
123 return ret;
124}
125
Alexey Dobriyan8d65af72009-09-23 15:57:19 -0700126static int proc_tcp_congestion_control(ctl_table *ctl, int write,
Stephen Hemminger317a76f2005-06-23 12:19:55 -0700127 void __user *buffer, size_t *lenp, loff_t *ppos)
128{
129 char val[TCP_CA_NAME_MAX];
130 ctl_table tbl = {
131 .data = val,
132 .maxlen = TCP_CA_NAME_MAX,
133 };
134 int ret;
135
136 tcp_get_default_congestion_control(val);
137
Alexey Dobriyan8d65af72009-09-23 15:57:19 -0700138 ret = proc_dostring(&tbl, write, buffer, lenp, ppos);
Stephen Hemminger317a76f2005-06-23 12:19:55 -0700139 if (write && ret == 0)
140 ret = tcp_set_default_congestion_control(val);
141 return ret;
142}
143
Stephen Hemminger3ff825b2006-11-09 16:32:06 -0800144static int proc_tcp_available_congestion_control(ctl_table *ctl,
Alexey Dobriyan8d65af72009-09-23 15:57:19 -0700145 int write,
Stephen Hemminger3ff825b2006-11-09 16:32:06 -0800146 void __user *buffer, size_t *lenp,
147 loff_t *ppos)
148{
149 ctl_table tbl = { .maxlen = TCP_CA_BUF_MAX, };
150 int ret;
151
152 tbl.data = kmalloc(tbl.maxlen, GFP_USER);
153 if (!tbl.data)
154 return -ENOMEM;
155 tcp_get_available_congestion_control(tbl.data, TCP_CA_BUF_MAX);
Alexey Dobriyan8d65af72009-09-23 15:57:19 -0700156 ret = proc_dostring(&tbl, write, buffer, lenp, ppos);
Stephen Hemminger3ff825b2006-11-09 16:32:06 -0800157 kfree(tbl.data);
158 return ret;
159}
160
Stephen Hemmingerce7bc3b2006-11-09 16:35:15 -0800161static int proc_allowed_congestion_control(ctl_table *ctl,
Alexey Dobriyan8d65af72009-09-23 15:57:19 -0700162 int write,
Stephen Hemmingerce7bc3b2006-11-09 16:35:15 -0800163 void __user *buffer, size_t *lenp,
164 loff_t *ppos)
165{
166 ctl_table tbl = { .maxlen = TCP_CA_BUF_MAX };
167 int ret;
168
169 tbl.data = kmalloc(tbl.maxlen, GFP_USER);
170 if (!tbl.data)
171 return -ENOMEM;
172
173 tcp_get_allowed_congestion_control(tbl.data, tbl.maxlen);
Alexey Dobriyan8d65af72009-09-23 15:57:19 -0700174 ret = proc_dostring(&tbl, write, buffer, lenp, ppos);
Stephen Hemmingerce7bc3b2006-11-09 16:35:15 -0800175 if (write && ret == 0)
176 ret = tcp_set_allowed_congestion_control(tbl.data);
177 kfree(tbl.data);
178 return ret;
179}
180
Glauber Costa3dc43e32011-12-11 21:47:05 +0000181static int ipv4_tcp_mem(ctl_table *ctl, int write,
182 void __user *buffer, size_t *lenp,
183 loff_t *ppos)
184{
185 int ret;
186 unsigned long vec[3];
187 struct net *net = current->nsproxy->net_ns;
Glauber Costa3aaabe22011-12-11 21:47:06 +0000188#ifdef CONFIG_CGROUP_MEM_RES_CTLR_KMEM
189 struct mem_cgroup *memcg;
190#endif
Glauber Costa3dc43e32011-12-11 21:47:05 +0000191
192 ctl_table tmp = {
193 .data = &vec,
194 .maxlen = sizeof(vec),
195 .mode = ctl->mode,
196 };
197
198 if (!write) {
199 ctl->data = &net->ipv4.sysctl_tcp_mem;
200 return proc_doulongvec_minmax(ctl, write, buffer, lenp, ppos);
201 }
202
203 ret = proc_doulongvec_minmax(&tmp, write, buffer, lenp, ppos);
204 if (ret)
205 return ret;
206
Glauber Costa3aaabe22011-12-11 21:47:06 +0000207#ifdef CONFIG_CGROUP_MEM_RES_CTLR_KMEM
208 rcu_read_lock();
209 memcg = mem_cgroup_from_task(current);
210
211 tcp_prot_mem(memcg, vec[0], 0);
212 tcp_prot_mem(memcg, vec[1], 1);
213 tcp_prot_mem(memcg, vec[2], 2);
214 rcu_read_unlock();
215#endif
216
Glauber Costa3dc43e32011-12-11 21:47:05 +0000217 net->ipv4.sysctl_tcp_mem[0] = vec[0];
218 net->ipv4.sysctl_tcp_mem[1] = vec[1];
219 net->ipv4.sysctl_tcp_mem[2] = vec[2];
220
221 return 0;
222}
223
Pavel Emelyanov3e37c3f2007-12-05 01:41:26 -0800224static struct ctl_table ipv4_table[] = {
YOSHIFUJI Hideakie905a9e2007-02-09 23:24:47 +0900225 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700226 .procname = "tcp_timestamps",
227 .data = &sysctl_tcp_timestamps,
228 .maxlen = sizeof(int),
229 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800230 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700231 },
YOSHIFUJI Hideakie905a9e2007-02-09 23:24:47 +0900232 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700233 .procname = "tcp_window_scaling",
234 .data = &sysctl_tcp_window_scaling,
235 .maxlen = sizeof(int),
236 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800237 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700238 },
YOSHIFUJI Hideakie905a9e2007-02-09 23:24:47 +0900239 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700240 .procname = "tcp_sack",
241 .data = &sysctl_tcp_sack,
242 .maxlen = sizeof(int),
243 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800244 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700245 },
YOSHIFUJI Hideakie905a9e2007-02-09 23:24:47 +0900246 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700247 .procname = "tcp_retrans_collapse",
248 .data = &sysctl_tcp_retrans_collapse,
249 .maxlen = sizeof(int),
250 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800251 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700252 },
YOSHIFUJI Hideakie905a9e2007-02-09 23:24:47 +0900253 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700254 .procname = "ip_default_ttl",
YOSHIFUJI Hideakie905a9e2007-02-09 23:24:47 +0900255 .data = &sysctl_ip_default_ttl,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700256 .maxlen = sizeof(int),
257 .mode = 0644,
Eric Dumazet249fab72010-12-13 12:16:14 -0800258 .proc_handler = proc_dointvec_minmax,
259 .extra1 = &ip_ttl_min,
260 .extra2 = &ip_ttl_max,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700261 },
YOSHIFUJI Hideakie905a9e2007-02-09 23:24:47 +0900262 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700263 .procname = "ip_no_pmtu_disc",
264 .data = &ipv4_config.no_pmtu_disc,
265 .maxlen = sizeof(int),
266 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800267 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700268 },
269 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700270 .procname = "ip_nonlocal_bind",
271 .data = &sysctl_ip_nonlocal_bind,
272 .maxlen = sizeof(int),
273 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800274 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700275 },
276 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700277 .procname = "tcp_syn_retries",
278 .data = &sysctl_tcp_syn_retries,
279 .maxlen = sizeof(int),
280 .mode = 0644,
Michal Tesarf31dfea2013-07-19 14:09:01 +0200281 .proc_handler = proc_dointvec_minmax,
282 .extra1 = &tcp_syn_retries_min,
283 .extra2 = &tcp_syn_retries_max
Linus Torvalds1da177e2005-04-16 15:20:36 -0700284 },
285 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700286 .procname = "tcp_synack_retries",
287 .data = &sysctl_tcp_synack_retries,
288 .maxlen = sizeof(int),
289 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800290 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700291 },
292 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700293 .procname = "tcp_max_orphans",
294 .data = &sysctl_tcp_max_orphans,
295 .maxlen = sizeof(int),
296 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800297 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700298 },
299 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700300 .procname = "tcp_max_tw_buckets",
Arnaldo Carvalho de Melo295ff7e2005-08-09 20:44:40 -0700301 .data = &tcp_death_row.sysctl_max_tw_buckets,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700302 .maxlen = sizeof(int),
303 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800304 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700305 },
306 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700307 .procname = "ip_dynaddr",
308 .data = &sysctl_ip_dynaddr,
309 .maxlen = sizeof(int),
310 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800311 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700312 },
313 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700314 .procname = "tcp_keepalive_time",
315 .data = &sysctl_tcp_keepalive_time,
316 .maxlen = sizeof(int),
317 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800318 .proc_handler = proc_dointvec_jiffies,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700319 },
320 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700321 .procname = "tcp_keepalive_probes",
322 .data = &sysctl_tcp_keepalive_probes,
323 .maxlen = sizeof(int),
324 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800325 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700326 },
327 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700328 .procname = "tcp_keepalive_intvl",
329 .data = &sysctl_tcp_keepalive_intvl,
330 .maxlen = sizeof(int),
331 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800332 .proc_handler = proc_dointvec_jiffies,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700333 },
334 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700335 .procname = "tcp_retries1",
336 .data = &sysctl_tcp_retries1,
337 .maxlen = sizeof(int),
338 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800339 .proc_handler = proc_dointvec_minmax,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700340 .extra2 = &tcp_retr1_max
341 },
342 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700343 .procname = "tcp_retries2",
344 .data = &sysctl_tcp_retries2,
345 .maxlen = sizeof(int),
346 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800347 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700348 },
349 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700350 .procname = "tcp_fin_timeout",
351 .data = &sysctl_tcp_fin_timeout,
352 .maxlen = sizeof(int),
353 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800354 .proc_handler = proc_dointvec_jiffies,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700355 },
356#ifdef CONFIG_SYN_COOKIES
357 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700358 .procname = "tcp_syncookies",
359 .data = &sysctl_tcp_syncookies,
360 .maxlen = sizeof(int),
361 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800362 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700363 },
364#endif
365 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700366 .procname = "tcp_tw_recycle",
Arnaldo Carvalho de Melo295ff7e2005-08-09 20:44:40 -0700367 .data = &tcp_death_row.sysctl_tw_recycle,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700368 .maxlen = sizeof(int),
369 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800370 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700371 },
372 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700373 .procname = "tcp_abort_on_overflow",
374 .data = &sysctl_tcp_abort_on_overflow,
375 .maxlen = sizeof(int),
376 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800377 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700378 },
379 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700380 .procname = "tcp_stdurg",
381 .data = &sysctl_tcp_stdurg,
382 .maxlen = sizeof(int),
383 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800384 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700385 },
386 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700387 .procname = "tcp_rfc1337",
388 .data = &sysctl_tcp_rfc1337,
389 .maxlen = sizeof(int),
390 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800391 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700392 },
393 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700394 .procname = "tcp_max_syn_backlog",
395 .data = &sysctl_max_syn_backlog,
396 .maxlen = sizeof(int),
397 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800398 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700399 },
400 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700401 .procname = "ip_local_port_range",
Eric Dumazet3c689b72008-10-08 14:18:04 -0700402 .data = &sysctl_local_ports.range,
403 .maxlen = sizeof(sysctl_local_ports.range),
Linus Torvalds1da177e2005-04-16 15:20:36 -0700404 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800405 .proc_handler = ipv4_local_port_range,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700406 },
Amerigo Wange3826f12010-05-05 00:27:06 +0000407 {
408 .procname = "ip_local_reserved_ports",
409 .data = NULL, /* initialized in sysctl_ipv4_init */
410 .maxlen = 65536,
411 .mode = 0644,
412 .proc_handler = proc_do_large_bitmap,
413 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700414 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700415 .procname = "igmp_max_memberships",
416 .data = &sysctl_igmp_max_memberships,
417 .maxlen = sizeof(int),
418 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800419 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700420 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700421 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700422 .procname = "igmp_max_msf",
423 .data = &sysctl_igmp_max_msf,
424 .maxlen = sizeof(int),
425 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800426 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700427 },
428 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700429 .procname = "inet_peer_threshold",
430 .data = &inet_peer_threshold,
431 .maxlen = sizeof(int),
432 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800433 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700434 },
435 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700436 .procname = "inet_peer_minttl",
437 .data = &inet_peer_minttl,
438 .maxlen = sizeof(int),
439 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800440 .proc_handler = proc_dointvec_jiffies,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700441 },
442 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700443 .procname = "inet_peer_maxttl",
444 .data = &inet_peer_maxttl,
445 .maxlen = sizeof(int),
446 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800447 .proc_handler = proc_dointvec_jiffies,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700448 },
449 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700450 .procname = "tcp_orphan_retries",
451 .data = &sysctl_tcp_orphan_retries,
452 .maxlen = sizeof(int),
453 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800454 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700455 },
456 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700457 .procname = "tcp_fack",
458 .data = &sysctl_tcp_fack,
459 .maxlen = sizeof(int),
460 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800461 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700462 },
463 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700464 .procname = "tcp_reordering",
465 .data = &sysctl_tcp_reordering,
466 .maxlen = sizeof(int),
467 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800468 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700469 },
470 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700471 .procname = "tcp_ecn",
472 .data = &sysctl_tcp_ecn,
473 .maxlen = sizeof(int),
474 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800475 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700476 },
477 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700478 .procname = "tcp_dsack",
479 .data = &sysctl_tcp_dsack,
480 .maxlen = sizeof(int),
481 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800482 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700483 },
484 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700485 .procname = "tcp_wmem",
486 .data = &sysctl_tcp_wmem,
487 .maxlen = sizeof(sysctl_tcp_wmem),
488 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800489 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700490 },
491 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700492 .procname = "tcp_rmem",
493 .data = &sysctl_tcp_rmem,
494 .maxlen = sizeof(sysctl_tcp_rmem),
495 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800496 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700497 },
498 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700499 .procname = "tcp_app_win",
500 .data = &sysctl_tcp_app_win,
501 .maxlen = sizeof(int),
502 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800503 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700504 },
505 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700506 .procname = "tcp_adv_win_scale",
507 .data = &sysctl_tcp_adv_win_scale,
508 .maxlen = sizeof(int),
509 .mode = 0644,
Alexey Dobriyan0147fc02010-11-22 12:54:21 +0000510 .proc_handler = proc_dointvec_minmax,
511 .extra1 = &tcp_adv_win_scale_min,
512 .extra2 = &tcp_adv_win_scale_max,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700513 },
514 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700515 .procname = "tcp_tw_reuse",
516 .data = &sysctl_tcp_tw_reuse,
517 .maxlen = sizeof(int),
518 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800519 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700520 },
521 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700522 .procname = "tcp_frto",
523 .data = &sysctl_tcp_frto,
524 .maxlen = sizeof(int),
525 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800526 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700527 },
528 {
Ilpo Järvinen3cfe3ba2007-02-27 10:09:49 -0800529 .procname = "tcp_frto_response",
530 .data = &sysctl_tcp_frto_response,
531 .maxlen = sizeof(int),
532 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800533 .proc_handler = proc_dointvec
Ilpo Järvinen3cfe3ba2007-02-27 10:09:49 -0800534 },
535 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700536 .procname = "tcp_low_latency",
537 .data = &sysctl_tcp_low_latency,
538 .maxlen = sizeof(int),
539 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800540 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -0700541 },
542 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700543 .procname = "tcp_no_metrics_save",
544 .data = &sysctl_tcp_nometrics_save,
545 .maxlen = sizeof(int),
546 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800547 .proc_handler = proc_dointvec,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700548 },
549 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700550 .procname = "tcp_moderate_rcvbuf",
551 .data = &sysctl_tcp_moderate_rcvbuf,
552 .maxlen = sizeof(int),
553 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800554 .proc_handler = proc_dointvec,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700555 },
556 {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700557 .procname = "tcp_tso_win_divisor",
558 .data = &sysctl_tcp_tso_win_divisor,
559 .maxlen = sizeof(int),
560 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800561 .proc_handler = proc_dointvec,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700562 },
563 {
Stephen Hemminger317a76f2005-06-23 12:19:55 -0700564 .procname = "tcp_congestion_control",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700565 .mode = 0644,
Stephen Hemminger317a76f2005-06-23 12:19:55 -0700566 .maxlen = TCP_CA_NAME_MAX,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800567 .proc_handler = proc_tcp_congestion_control,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700568 },
Stephen Hemminger9772efb2005-11-10 17:09:53 -0800569 {
Stephen Hemminger9772efb2005-11-10 17:09:53 -0800570 .procname = "tcp_abc",
571 .data = &sysctl_tcp_abc,
572 .maxlen = sizeof(int),
573 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800574 .proc_handler = proc_dointvec,
Stephen Hemminger9772efb2005-11-10 17:09:53 -0800575 },
John Heffner5d424d52006-03-20 17:53:41 -0800576 {
John Heffner5d424d52006-03-20 17:53:41 -0800577 .procname = "tcp_mtu_probing",
578 .data = &sysctl_tcp_mtu_probing,
579 .maxlen = sizeof(int),
580 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800581 .proc_handler = proc_dointvec,
John Heffner5d424d52006-03-20 17:53:41 -0800582 },
583 {
John Heffner5d424d52006-03-20 17:53:41 -0800584 .procname = "tcp_base_mss",
585 .data = &sysctl_tcp_base_mss,
586 .maxlen = sizeof(int),
587 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800588 .proc_handler = proc_dointvec,
John Heffner5d424d52006-03-20 17:53:41 -0800589 },
YOSHIFUJI Hideakie905a9e2007-02-09 23:24:47 +0900590 {
Rick Jones15d99e02006-03-20 22:40:29 -0800591 .procname = "tcp_workaround_signed_windows",
592 .data = &sysctl_tcp_workaround_signed_windows,
593 .maxlen = sizeof(int),
594 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800595 .proc_handler = proc_dointvec
Rick Jones15d99e02006-03-20 22:40:29 -0800596 },
Eric Dumazet34fb3502012-07-17 10:13:05 +0200597 {
598 .procname = "tcp_challenge_ack_limit",
599 .data = &sysctl_tcp_challenge_ack_limit,
600 .maxlen = sizeof(int),
601 .mode = 0644,
602 .proc_handler = proc_dointvec
603 },
Chris Leech95937822006-05-23 18:02:55 -0700604#ifdef CONFIG_NET_DMA
605 {
Chris Leech95937822006-05-23 18:02:55 -0700606 .procname = "tcp_dma_copybreak",
607 .data = &sysctl_tcp_dma_copybreak,
608 .maxlen = sizeof(int),
609 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800610 .proc_handler = proc_dointvec
Chris Leech95937822006-05-23 18:02:55 -0700611 },
612#endif
David S. Miller35089bb2006-06-13 22:33:04 -0700613 {
David S. Miller35089bb2006-06-13 22:33:04 -0700614 .procname = "tcp_slow_start_after_idle",
615 .data = &sysctl_tcp_slow_start_after_idle,
616 .maxlen = sizeof(int),
617 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800618 .proc_handler = proc_dointvec
David S. Miller35089bb2006-06-13 22:33:04 -0700619 },
Paul Moore446fda42006-08-03 16:48:06 -0700620#ifdef CONFIG_NETLABEL
621 {
Paul Moore446fda42006-08-03 16:48:06 -0700622 .procname = "cipso_cache_enable",
623 .data = &cipso_v4_cache_enabled,
624 .maxlen = sizeof(int),
625 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800626 .proc_handler = proc_dointvec,
Paul Moore446fda42006-08-03 16:48:06 -0700627 },
628 {
Paul Moore446fda42006-08-03 16:48:06 -0700629 .procname = "cipso_cache_bucket_size",
630 .data = &cipso_v4_cache_bucketsize,
631 .maxlen = sizeof(int),
632 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800633 .proc_handler = proc_dointvec,
Paul Moore446fda42006-08-03 16:48:06 -0700634 },
635 {
Paul Moore446fda42006-08-03 16:48:06 -0700636 .procname = "cipso_rbm_optfmt",
637 .data = &cipso_v4_rbm_optfmt,
638 .maxlen = sizeof(int),
639 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800640 .proc_handler = proc_dointvec,
Paul Moore446fda42006-08-03 16:48:06 -0700641 },
642 {
Paul Moore446fda42006-08-03 16:48:06 -0700643 .procname = "cipso_rbm_strictvalid",
644 .data = &cipso_v4_rbm_strictvalid,
645 .maxlen = sizeof(int),
646 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800647 .proc_handler = proc_dointvec,
Paul Moore446fda42006-08-03 16:48:06 -0700648 },
649#endif /* CONFIG_NETLABEL */
Stephen Hemminger3ff825b2006-11-09 16:32:06 -0800650 {
Stephen Hemminger3ff825b2006-11-09 16:32:06 -0800651 .procname = "tcp_available_congestion_control",
652 .maxlen = TCP_CA_BUF_MAX,
653 .mode = 0444,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800654 .proc_handler = proc_tcp_available_congestion_control,
Stephen Hemminger3ff825b2006-11-09 16:32:06 -0800655 },
Stephen Hemmingerce7bc3b2006-11-09 16:35:15 -0800656 {
Stephen Hemmingerce7bc3b2006-11-09 16:35:15 -0800657 .procname = "tcp_allowed_congestion_control",
658 .maxlen = TCP_CA_BUF_MAX,
659 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800660 .proc_handler = proc_allowed_congestion_control,
Stephen Hemmingerce7bc3b2006-11-09 16:35:15 -0800661 },
John Heffner886236c2007-03-25 19:21:45 -0700662 {
John Heffner886236c2007-03-25 19:21:45 -0700663 .procname = "tcp_max_ssthresh",
664 .data = &sysctl_tcp_max_ssthresh,
665 .maxlen = sizeof(int),
666 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800667 .proc_handler = proc_dointvec,
John Heffner886236c2007-03-25 19:21:45 -0700668 },
Hideo Aoki95766ff2007-12-31 00:29:24 -0800669 {
William Allen Simpson519855c2009-12-02 18:14:19 +0000670 .procname = "tcp_cookie_size",
671 .data = &sysctl_tcp_cookie_size,
672 .maxlen = sizeof(int),
673 .mode = 0644,
674 .proc_handler = proc_dointvec
675 },
676 {
Andreas Petlund36e31b02010-02-18 02:47:01 +0000677 .procname = "tcp_thin_linear_timeouts",
678 .data = &sysctl_tcp_thin_linear_timeouts,
679 .maxlen = sizeof(int),
680 .mode = 0644,
681 .proc_handler = proc_dointvec
682 },
Andreas Petlund7e380172010-02-18 04:48:19 +0000683 {
684 .procname = "tcp_thin_dupack",
685 .data = &sysctl_tcp_thin_dupack,
686 .maxlen = sizeof(int),
687 .mode = 0644,
688 .proc_handler = proc_dointvec
689 },
Andreas Petlund36e31b02010-02-18 02:47:01 +0000690 {
Hideo Aoki95766ff2007-12-31 00:29:24 -0800691 .procname = "udp_mem",
692 .data = &sysctl_udp_mem,
693 .maxlen = sizeof(sysctl_udp_mem),
694 .mode = 0644,
Eric Dumazet8d987e52010-11-09 23:24:26 +0000695 .proc_handler = proc_doulongvec_minmax,
Hideo Aoki95766ff2007-12-31 00:29:24 -0800696 },
697 {
Hideo Aoki95766ff2007-12-31 00:29:24 -0800698 .procname = "udp_rmem_min",
699 .data = &sysctl_udp_rmem_min,
700 .maxlen = sizeof(sysctl_udp_rmem_min),
701 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800702 .proc_handler = proc_dointvec_minmax,
Hideo Aoki95766ff2007-12-31 00:29:24 -0800703 .extra1 = &zero
704 },
705 {
Hideo Aoki95766ff2007-12-31 00:29:24 -0800706 .procname = "udp_wmem_min",
707 .data = &sysctl_udp_wmem_min,
708 .maxlen = sizeof(sysctl_udp_wmem_min),
709 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800710 .proc_handler = proc_dointvec_minmax,
Hideo Aoki95766ff2007-12-31 00:29:24 -0800711 .extra1 = &zero
712 },
Eric W. Biedermanf8572d82009-11-05 13:32:03 -0800713 { }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700714};
Pavel Emelyanov3e37c3f2007-12-05 01:41:26 -0800715
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700716static struct ctl_table ipv4_net_table[] = {
717 {
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700718 .procname = "icmp_echo_ignore_all",
719 .data = &init_net.ipv4.sysctl_icmp_echo_ignore_all,
720 .maxlen = sizeof(int),
721 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800722 .proc_handler = proc_dointvec
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700723 },
724 {
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700725 .procname = "icmp_echo_ignore_broadcasts",
726 .data = &init_net.ipv4.sysctl_icmp_echo_ignore_broadcasts,
727 .maxlen = sizeof(int),
728 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800729 .proc_handler = proc_dointvec
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700730 },
731 {
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700732 .procname = "icmp_ignore_bogus_error_responses",
733 .data = &init_net.ipv4.sysctl_icmp_ignore_bogus_error_responses,
734 .maxlen = sizeof(int),
735 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800736 .proc_handler = proc_dointvec
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700737 },
738 {
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700739 .procname = "icmp_errors_use_inbound_ifaddr",
740 .data = &init_net.ipv4.sysctl_icmp_errors_use_inbound_ifaddr,
741 .maxlen = sizeof(int),
742 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800743 .proc_handler = proc_dointvec
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700744 },
745 {
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700746 .procname = "icmp_ratelimit",
747 .data = &init_net.ipv4.sysctl_icmp_ratelimit,
748 .maxlen = sizeof(int),
749 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800750 .proc_handler = proc_dointvec_ms_jiffies,
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700751 },
752 {
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700753 .procname = "icmp_ratemask",
754 .data = &init_net.ipv4.sysctl_icmp_ratemask,
755 .maxlen = sizeof(int),
756 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800757 .proc_handler = proc_dointvec
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700758 },
Neil Horman1080d702008-10-27 12:28:25 -0700759 {
Neil Horman1080d702008-10-27 12:28:25 -0700760 .procname = "rt_cache_rebuild_count",
761 .data = &init_net.ipv4.sysctl_rt_cache_rebuild_count,
762 .maxlen = sizeof(int),
763 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -0800764 .proc_handler = proc_dointvec
Neil Horman1080d702008-10-27 12:28:25 -0700765 },
Vasiliy Kulikovc319b4d2011-05-13 10:01:00 +0000766 {
767 .procname = "ping_group_range",
768 .data = &init_net.ipv4.sysctl_ping_group_range,
769 .maxlen = sizeof(init_net.ipv4.sysctl_ping_group_range),
770 .mode = 0644,
771 .proc_handler = ipv4_ping_group_range,
772 },
Glauber Costa3dc43e32011-12-11 21:47:05 +0000773 {
774 .procname = "tcp_mem",
775 .maxlen = sizeof(init_net.ipv4.sysctl_tcp_mem),
776 .mode = 0644,
777 .proc_handler = ipv4_tcp_mem,
778 },
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700779 { }
780};
781
Pavel Emelyanov3d7cc2b2008-01-09 00:33:11 -0800782struct ctl_path net_ipv4_ctl_path[] = {
Eric W. Biedermanf8572d82009-11-05 13:32:03 -0800783 { .procname = "net", },
784 { .procname = "ipv4", },
Pavel Emelyanov3e37c3f2007-12-05 01:41:26 -0800785 { },
786};
Pavel Emelyanov3d7cc2b2008-01-09 00:33:11 -0800787EXPORT_SYMBOL_GPL(net_ipv4_ctl_path);
Pavel Emelyanov3e37c3f2007-12-05 01:41:26 -0800788
Pavel Emelyanov15775192008-03-26 01:54:18 -0700789static __net_init int ipv4_sysctl_init_net(struct net *net)
790{
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700791 struct ctl_table *table;
792
793 table = ipv4_net_table;
Octavian Purdila09ad9bc2009-11-25 15:14:13 -0800794 if (!net_eq(net, &init_net)) {
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700795 table = kmemdup(table, sizeof(ipv4_net_table), GFP_KERNEL);
796 if (table == NULL)
797 goto err_alloc;
798
799 table[0].data =
800 &net->ipv4.sysctl_icmp_echo_ignore_all;
801 table[1].data =
802 &net->ipv4.sysctl_icmp_echo_ignore_broadcasts;
803 table[2].data =
804 &net->ipv4.sysctl_icmp_ignore_bogus_error_responses;
805 table[3].data =
806 &net->ipv4.sysctl_icmp_errors_use_inbound_ifaddr;
807 table[4].data =
808 &net->ipv4.sysctl_icmp_ratelimit;
809 table[5].data =
810 &net->ipv4.sysctl_icmp_ratemask;
Neil Horman1080d702008-10-27 12:28:25 -0700811 table[6].data =
812 &net->ipv4.sysctl_rt_cache_rebuild_count;
Vasiliy Kulikovc319b4d2011-05-13 10:01:00 +0000813 table[7].data =
814 &net->ipv4.sysctl_ping_group_range;
815
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700816 }
817
Vasiliy Kulikovc319b4d2011-05-13 10:01:00 +0000818 /*
819 * Sane defaults - nobody may create ping sockets.
820 * Boot scripts should set this to distro-specific group.
821 */
822 net->ipv4.sysctl_ping_group_range[0] = 1;
823 net->ipv4.sysctl_ping_group_range[1] = 0;
824
Neil Horman1080d702008-10-27 12:28:25 -0700825 net->ipv4.sysctl_rt_cache_rebuild_count = 4;
826
Glauber Costa4acb4192012-01-30 01:20:17 +0000827 tcp_init_mem(net);
Glauber Costa3dc43e32011-12-11 21:47:05 +0000828
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700829 net->ipv4.ipv4_hdr = register_net_sysctl_table(net,
830 net_ipv4_ctl_path, table);
831 if (net->ipv4.ipv4_hdr == NULL)
832 goto err_reg;
833
Pavel Emelyanov15775192008-03-26 01:54:18 -0700834 return 0;
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700835
836err_reg:
Octavian Purdila09ad9bc2009-11-25 15:14:13 -0800837 if (!net_eq(net, &init_net))
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700838 kfree(table);
839err_alloc:
840 return -ENOMEM;
Pavel Emelyanov15775192008-03-26 01:54:18 -0700841}
842
843static __net_exit void ipv4_sysctl_exit_net(struct net *net)
844{
Pavel Emelyanov68528f02008-03-26 01:56:24 -0700845 struct ctl_table *table;
846
847 table = net->ipv4.ipv4_hdr->ctl_table_arg;
848 unregister_net_sysctl_table(net->ipv4.ipv4_hdr);
849 kfree(table);
Pavel Emelyanov15775192008-03-26 01:54:18 -0700850}
851
852static __net_initdata struct pernet_operations ipv4_sysctl_ops = {
853 .init = ipv4_sysctl_init_net,
854 .exit = ipv4_sysctl_exit_net,
855};
856
Pavel Emelyanov3e37c3f2007-12-05 01:41:26 -0800857static __init int sysctl_ipv4_init(void)
858{
859 struct ctl_table_header *hdr;
Amerigo Wange3826f12010-05-05 00:27:06 +0000860 struct ctl_table *i;
861
862 for (i = ipv4_table; i->procname; i++) {
863 if (strcmp(i->procname, "ip_local_reserved_ports") == 0) {
864 i->data = sysctl_local_reserved_ports;
865 break;
866 }
867 }
868 if (!i->procname)
869 return -EINVAL;
Pavel Emelyanov3e37c3f2007-12-05 01:41:26 -0800870
Pavel Emelyanov3d7cc2b2008-01-09 00:33:11 -0800871 hdr = register_sysctl_paths(net_ipv4_ctl_path, ipv4_table);
Pavel Emelyanov15775192008-03-26 01:54:18 -0700872 if (hdr == NULL)
873 return -ENOMEM;
874
875 if (register_pernet_subsys(&ipv4_sysctl_ops)) {
876 unregister_sysctl_table(hdr);
877 return -ENOMEM;
878 }
879
880 return 0;
Pavel Emelyanov3e37c3f2007-12-05 01:41:26 -0800881}
882
883__initcall(sysctl_ipv4_init);