forked from mirrors/linux
		
	sysctl net: Remove unused binary sysctl code
Now that sys_sysctl is a compatiblity wrapper around /proc/sys all sysctl strategy routines, and all ctl_name and strategy entries in the sysctl tables are unused, and can be revmoed. In addition neigh_sysctl_register has been modified to no longer take a strategy argument and it's callers have been modified not to pass one. Cc: "David Miller" <davem@davemloft.net> Cc: Hideaki YOSHIFUJI <yoshfuji@linux-ipv6.org> Cc: netdev@vger.kernel.org Signed-off-by: Eric W. Biederman <ebiederm@xmission.com>
This commit is contained in:
		
							parent
							
								
									86b1bc68e2
								
							
						
					
					
						commit
						f8572d8f2a
					
				
					 62 changed files with 162 additions and 1130 deletions
				
			
		|  | @ -75,7 +75,6 @@ struct dn_dev_parms { | |||
| 	unsigned long t3;         /* Default value of t3                */ | ||||
| 	int priority;             /* Priority to be a router            */ | ||||
| 	char *name;               /* Name for sysctl                    */ | ||||
| 	int ctl_name;             /* Index for sysctl                   */ | ||||
| 	int  (*up)(struct net_device *); | ||||
| 	void (*down)(struct net_device *); | ||||
| 	void (*timer3)(struct net_device *, struct dn_ifaddr *ifa); | ||||
|  |  | |||
|  | @ -264,8 +264,7 @@ extern int			neigh_sysctl_register(struct net_device *dev, | |||
| 						      struct neigh_parms *p, | ||||
| 						      int p_id, int pdev_id, | ||||
| 						      char *p_name, | ||||
| 						      proc_handler *proc_handler, | ||||
| 						      ctl_handler *strategy); | ||||
| 						      proc_handler *proc_handler); | ||||
| extern void			neigh_sysctl_unregister(struct neigh_parms *p); | ||||
| 
 | ||||
| static inline void __neigh_parms_put(struct neigh_parms *parms) | ||||
|  |  | |||
|  | @ -635,19 +635,18 @@ struct net_device *alloc_trdev(int sizeof_priv) | |||
| #ifdef CONFIG_SYSCTL | ||||
| static struct ctl_table tr_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TR_RIF_TIMEOUT, | ||||
| 		.procname	= "rif_timeout", | ||||
| 		.data		= &sysctl_tr_rif_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ 0 }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| static __initdata struct ctl_path tr_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "token-ring", .ctl_name = NET_TR, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "token-ring", }, | ||||
| 	{ } | ||||
| }; | ||||
| #endif | ||||
|  |  | |||
|  | @ -12,25 +12,20 @@ | |||
| 
 | ||||
| static struct ctl_table atalk_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ATALK_AARP_EXPIRY_TIME, | ||||
| 		.procname	= "aarp-expiry-time", | ||||
| 		.data		= &sysctl_aarp_expiry_time, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ATALK_AARP_TICK_TIME, | ||||
| 		.procname	= "aarp-tick-time", | ||||
| 		.data		= &sysctl_aarp_tick_time, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ATALK_AARP_RETRANSMIT_LIMIT, | ||||
| 		.procname	= "aarp-retransmit-limit", | ||||
| 		.data		= &sysctl_aarp_retransmit_limit, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -38,20 +33,18 @@ static struct ctl_table atalk_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ATALK_AARP_RESOLVE_TIME, | ||||
| 		.procname	= "aarp-resolve-time", | ||||
| 		.data		= &sysctl_aarp_resolve_time, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ 0 }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path atalk_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "appletalk", .ctl_name = NET_ATALK, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "appletalk", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -34,156 +34,128 @@ static ctl_table *ax25_table; | |||
| static int ax25_table_size; | ||||
| 
 | ||||
| static struct ctl_path ax25_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "ax25", .ctl_name = NET_AX25, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "ax25", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static const ctl_table ax25_param_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_IP_DEFAULT_MODE, | ||||
| 		.procname	= "ip_default_mode", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_ipdefmode, | ||||
| 		.extra2		= &max_ipdefmode | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_DEFAULT_MODE, | ||||
| 		.procname	= "ax25_default_mode", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_axdefmode, | ||||
| 		.extra2		= &max_axdefmode | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_BACKOFF_TYPE, | ||||
| 		.procname	= "backoff_type", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_backoff, | ||||
| 		.extra2		= &max_backoff | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_CONNECT_MODE, | ||||
| 		.procname	= "connect_mode", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_conmode, | ||||
| 		.extra2		= &max_conmode | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_STANDARD_WINDOW, | ||||
| 		.procname	= "standard_window_size", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_window, | ||||
| 		.extra2		= &max_window | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_EXTENDED_WINDOW, | ||||
| 		.procname	= "extended_window_size", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_ewindow, | ||||
| 		.extra2		= &max_ewindow | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_T1_TIMEOUT, | ||||
| 		.procname	= "t1_timeout", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_t1, | ||||
| 		.extra2		= &max_t1 | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_T2_TIMEOUT, | ||||
| 		.procname	= "t2_timeout", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_t2, | ||||
| 		.extra2		= &max_t2 | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_T3_TIMEOUT, | ||||
| 		.procname	= "t3_timeout", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_t3, | ||||
| 		.extra2		= &max_t3 | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_IDLE_TIMEOUT, | ||||
| 		.procname	= "idle_timeout", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_idle, | ||||
| 		.extra2		= &max_idle | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_N2, | ||||
| 		.procname	= "maximum_retry_count", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_n2, | ||||
| 		.extra2		= &max_n2 | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_PACLEN, | ||||
| 		.procname	= "maximum_packet_length", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_paclen, | ||||
| 		.extra2		= &max_paclen | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_PROTOCOL, | ||||
| 		.procname	= "protocol", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_proto, | ||||
| 		.extra2		= &max_proto | ||||
| 	}, | ||||
| #ifdef CONFIG_AX25_DAMA_SLAVE | ||||
| 	{ | ||||
| 		.ctl_name	= NET_AX25_DAMA_SLAVE_TIMEOUT, | ||||
| 		.procname	= "dama_slave_timeout", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_ds_timeout, | ||||
| 		.extra2		= &max_ds_timeout | ||||
| 	}, | ||||
| #endif | ||||
| 
 | ||||
| 	{ .ctl_name = 0 }	/* that's all, folks! */ | ||||
| 	{ }	/* that's all, folks! */ | ||||
| }; | ||||
| 
 | ||||
| void ax25_register_sysctl(void) | ||||
|  | @ -212,11 +184,9 @@ void ax25_register_sysctl(void) | |||
| 			return; | ||||
| 		} | ||||
| 		ax25_table[n].child = ax25_dev->systable = child; | ||||
| 		ax25_table[n].ctl_name     = n + 1; | ||||
| 		ax25_table[n].procname     = ax25_dev->dev->name; | ||||
| 		ax25_table[n].mode         = 0555; | ||||
| 
 | ||||
| 		child[AX25_MAX_VALUES].ctl_name = 0;	/* just in case... */ | ||||
| 
 | ||||
| 		for (k = 0; k < AX25_MAX_VALUES; k++) | ||||
| 			child[k].data = &ax25_dev->values[k]; | ||||
|  | @ -233,7 +203,7 @@ void ax25_unregister_sysctl(void) | |||
| 	ctl_table *p; | ||||
| 	unregister_sysctl_table(ax25_table_header); | ||||
| 
 | ||||
| 	for (p = ax25_table; p->ctl_name; p++) | ||||
| 	for (p = ax25_table; p->procname; p++) | ||||
| 		kfree(p->child); | ||||
| 	kfree(ax25_table); | ||||
| } | ||||
|  |  | |||
|  | @ -1013,12 +1013,12 @@ static ctl_table brnf_table[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= brnf_sysctl_call_tables, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path brnf_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "bridge", .ctl_name = NET_BRIDGE, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "bridge", }, | ||||
| 	{ } | ||||
| }; | ||||
| #endif | ||||
|  |  | |||
|  | @ -2566,21 +2566,18 @@ static struct neigh_sysctl_table { | |||
| } neigh_sysctl_template __read_mostly = { | ||||
| 	.neigh_vars = { | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_MCAST_SOLICIT, | ||||
| 			.procname	= "mcast_solicit", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
| 			.proc_handler	= proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_UCAST_SOLICIT, | ||||
| 			.procname	= "ucast_solicit", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
| 			.proc_handler	= proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_APP_SOLICIT, | ||||
| 			.procname	= "app_solicit", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
|  | @ -2593,38 +2590,30 @@ static struct neigh_sysctl_table { | |||
| 			.proc_handler	= proc_dointvec_userhz_jiffies, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_REACHABLE_TIME, | ||||
| 			.procname	= "base_reachable_time", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
| 			.proc_handler	= proc_dointvec_jiffies, | ||||
| 			.strategy	= sysctl_jiffies, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_DELAY_PROBE_TIME, | ||||
| 			.procname	= "delay_first_probe_time", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
| 			.proc_handler	= proc_dointvec_jiffies, | ||||
| 			.strategy	= sysctl_jiffies, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_GC_STALE_TIME, | ||||
| 			.procname	= "gc_stale_time", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
| 			.proc_handler	= proc_dointvec_jiffies, | ||||
| 			.strategy	= sysctl_jiffies, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_UNRES_QLEN, | ||||
| 			.procname	= "unres_qlen", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
| 			.proc_handler	= proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_PROXY_QLEN, | ||||
| 			.procname	= "proxy_qlen", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
|  | @ -2649,45 +2638,36 @@ static struct neigh_sysctl_table { | |||
| 			.proc_handler	= proc_dointvec_userhz_jiffies, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_RETRANS_TIME_MS, | ||||
| 			.procname	= "retrans_time_ms", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
| 			.proc_handler	= proc_dointvec_ms_jiffies, | ||||
| 			.strategy	= sysctl_ms_jiffies, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_REACHABLE_TIME_MS, | ||||
| 			.procname	= "base_reachable_time_ms", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
| 			.proc_handler	= proc_dointvec_ms_jiffies, | ||||
| 			.strategy	= sysctl_ms_jiffies, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_GC_INTERVAL, | ||||
| 			.procname	= "gc_interval", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
| 			.proc_handler	= proc_dointvec_jiffies, | ||||
| 			.strategy	= sysctl_jiffies, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_GC_THRESH1, | ||||
| 			.procname	= "gc_thresh1", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
| 			.proc_handler	= proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_GC_THRESH2, | ||||
| 			.procname	= "gc_thresh2", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
| 			.proc_handler	= proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	= NET_NEIGH_GC_THRESH3, | ||||
| 			.procname	= "gc_thresh3", | ||||
| 			.maxlen		= sizeof(int), | ||||
| 			.mode		= 0644, | ||||
|  | @ -2699,7 +2679,7 @@ static struct neigh_sysctl_table { | |||
| 
 | ||||
| int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p, | ||||
| 			  int p_id, int pdev_id, char *p_name, | ||||
| 			  proc_handler *handler, ctl_handler *strategy) | ||||
| 			  proc_handler *handler) | ||||
| { | ||||
| 	struct neigh_sysctl_table *t; | ||||
| 	const char *dev_name_source = NULL; | ||||
|  | @ -2710,10 +2690,10 @@ int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p, | |||
| #define NEIGH_CTL_PATH_DEV	3 | ||||
| 
 | ||||
| 	struct ctl_path neigh_path[] = { | ||||
| 		{ .procname = "net",	 .ctl_name = CTL_NET, }, | ||||
| 		{ .procname = "proto",	 .ctl_name = 0, }, | ||||
| 		{ .procname = "neigh",	 .ctl_name = 0, }, | ||||
| 		{ .procname = "default", .ctl_name = NET_PROTO_CONF_DEFAULT, }, | ||||
| 		{ .procname = "net",	 }, | ||||
| 		{ .procname = "proto",	 }, | ||||
| 		{ .procname = "neigh",	 }, | ||||
| 		{ .procname = "default", }, | ||||
| 		{ }, | ||||
| 	}; | ||||
| 
 | ||||
|  | @ -2738,7 +2718,6 @@ int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p, | |||
| 
 | ||||
| 	if (dev) { | ||||
| 		dev_name_source = dev->name; | ||||
| 		neigh_path[NEIGH_CTL_PATH_DEV].ctl_name = dev->ifindex; | ||||
| 		/* Terminate the table early */ | ||||
| 		memset(&t->neigh_vars[14], 0, sizeof(t->neigh_vars[14])); | ||||
| 	} else { | ||||
|  | @ -2750,31 +2729,19 @@ int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p, | |||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| 	if (handler || strategy) { | ||||
| 	if (handler) { | ||||
| 		/* RetransTime */ | ||||
| 		t->neigh_vars[3].proc_handler = handler; | ||||
| 		t->neigh_vars[3].strategy = strategy; | ||||
| 		t->neigh_vars[3].extra1 = dev; | ||||
| 		if (!strategy) | ||||
| 			t->neigh_vars[3].ctl_name = CTL_UNNUMBERED; | ||||
| 		/* ReachableTime */ | ||||
| 		t->neigh_vars[4].proc_handler = handler; | ||||
| 		t->neigh_vars[4].strategy = strategy; | ||||
| 		t->neigh_vars[4].extra1 = dev; | ||||
| 		if (!strategy) | ||||
| 			t->neigh_vars[4].ctl_name = CTL_UNNUMBERED; | ||||
| 		/* RetransTime (in milliseconds)*/ | ||||
| 		t->neigh_vars[12].proc_handler = handler; | ||||
| 		t->neigh_vars[12].strategy = strategy; | ||||
| 		t->neigh_vars[12].extra1 = dev; | ||||
| 		if (!strategy) | ||||
| 			t->neigh_vars[12].ctl_name = CTL_UNNUMBERED; | ||||
| 		/* ReachableTime (in milliseconds) */ | ||||
| 		t->neigh_vars[13].proc_handler = handler; | ||||
| 		t->neigh_vars[13].strategy = strategy; | ||||
| 		t->neigh_vars[13].extra1 = dev; | ||||
| 		if (!strategy) | ||||
| 			t->neigh_vars[13].ctl_name = CTL_UNNUMBERED; | ||||
| 	} | ||||
| 
 | ||||
| 	t->dev_name = kstrdup(dev_name_source, GFP_KERNEL); | ||||
|  | @ -2782,9 +2749,7 @@ int neigh_sysctl_register(struct net_device *dev, struct neigh_parms *p, | |||
| 		goto free; | ||||
| 
 | ||||
| 	neigh_path[NEIGH_CTL_PATH_DEV].procname = t->dev_name; | ||||
| 	neigh_path[NEIGH_CTL_PATH_NEIGH].ctl_name = pdev_id; | ||||
| 	neigh_path[NEIGH_CTL_PATH_PROTO].procname = p_name; | ||||
| 	neigh_path[NEIGH_CTL_PATH_PROTO].ctl_name = p_id; | ||||
| 
 | ||||
| 	t->sysctl_header = | ||||
| 		register_net_sysctl_table(neigh_parms_net(p), neigh_path, t->neigh_vars); | ||||
|  |  | |||
|  | @ -17,7 +17,6 @@ | |||
| static struct ctl_table net_core_table[] = { | ||||
| #ifdef CONFIG_NET | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_WMEM_MAX, | ||||
| 		.procname	= "wmem_max", | ||||
| 		.data		= &sysctl_wmem_max, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -25,7 +24,6 @@ static struct ctl_table net_core_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_RMEM_MAX, | ||||
| 		.procname	= "rmem_max", | ||||
| 		.data		= &sysctl_rmem_max, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -33,7 +31,6 @@ static struct ctl_table net_core_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_WMEM_DEFAULT, | ||||
| 		.procname	= "wmem_default", | ||||
| 		.data		= &sysctl_wmem_default, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -41,7 +38,6 @@ static struct ctl_table net_core_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_RMEM_DEFAULT, | ||||
| 		.procname	= "rmem_default", | ||||
| 		.data		= &sysctl_rmem_default, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -49,7 +45,6 @@ static struct ctl_table net_core_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_DEV_WEIGHT, | ||||
| 		.procname	= "dev_weight", | ||||
| 		.data		= &weight_p, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -57,7 +52,6 @@ static struct ctl_table net_core_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_MAX_BACKLOG, | ||||
| 		.procname	= "netdev_max_backlog", | ||||
| 		.data		= &netdev_max_backlog, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -65,16 +59,13 @@ static struct ctl_table net_core_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_MSG_COST, | ||||
| 		.procname	= "message_cost", | ||||
| 		.data		= &net_ratelimit_state.interval, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_MSG_BURST, | ||||
| 		.procname	= "message_burst", | ||||
| 		.data		= &net_ratelimit_state.burst, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -82,7 +73,6 @@ static struct ctl_table net_core_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_OPTMEM_MAX, | ||||
| 		.procname	= "optmem_max", | ||||
| 		.data		= &sysctl_optmem_max, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -91,7 +81,6 @@ static struct ctl_table net_core_table[] = { | |||
| 	}, | ||||
| #endif /* CONFIG_NET */ | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_BUDGET, | ||||
| 		.procname	= "netdev_budget", | ||||
| 		.data		= &netdev_budget, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -99,31 +88,29 @@ static struct ctl_table net_core_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_WARNINGS, | ||||
| 		.procname	= "warnings", | ||||
| 		.data		= &net_msg_warn, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_table netns_core_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_SOMAXCONN, | ||||
| 		.procname	= "somaxconn", | ||||
| 		.data		= &init_net.core.sysctl_somaxconn, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| __net_initdata struct ctl_path net_core_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "core", .ctl_name = NET_CORE, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "core", }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -93,13 +93,13 @@ static struct ctl_table dccp_default_table[] = { | |||
| 		.proc_handler	= proc_dointvec_ms_jiffies, | ||||
| 	}, | ||||
| 
 | ||||
| 	{ .ctl_name = 0, } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path dccp_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "dccp", .ctl_name = NET_DCCP, }, | ||||
| 	{ .procname = "default", .ctl_name = NET_DCCP_DEFAULT, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "dccp", }, | ||||
| 	{ .procname = "default", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -89,7 +89,6 @@ static struct dn_dev_parms dn_dev_list[] =  { | |||
| 	.t2 =		1, | ||||
| 	.t3 =		10, | ||||
| 	.name =		"ethernet", | ||||
| 	.ctl_name =	NET_DECNET_CONF_ETHER, | ||||
| 	.up =		dn_eth_up, | ||||
| 	.down = 	dn_eth_down, | ||||
| 	.timer3 =	dn_send_brd_hello, | ||||
|  | @ -101,7 +100,6 @@ static struct dn_dev_parms dn_dev_list[] =  { | |||
| 	.t2 =		1, | ||||
| 	.t3 =		10, | ||||
| 	.name =		"ipgre", | ||||
| 	.ctl_name =	NET_DECNET_CONF_GRE, | ||||
| 	.timer3 =	dn_send_brd_hello, | ||||
| }, | ||||
| #if 0 | ||||
|  | @ -112,7 +110,6 @@ static struct dn_dev_parms dn_dev_list[] =  { | |||
| 	.t2 =		1, | ||||
| 	.t3 =		120, | ||||
| 	.name =		"x25", | ||||
| 	.ctl_name =	NET_DECNET_CONF_X25, | ||||
| 	.timer3 =	dn_send_ptp_hello, | ||||
| }, | ||||
| #endif | ||||
|  | @ -124,7 +121,6 @@ static struct dn_dev_parms dn_dev_list[] =  { | |||
| 	.t2 =		1, | ||||
| 	.t3 =		10, | ||||
| 	.name =		"ppp", | ||||
| 	.ctl_name =	NET_DECNET_CONF_PPP, | ||||
| 	.timer3 =	dn_send_brd_hello, | ||||
| }, | ||||
| #endif | ||||
|  | @ -135,7 +131,6 @@ static struct dn_dev_parms dn_dev_list[] =  { | |||
| 	.t2 =		1, | ||||
| 	.t3 =		120, | ||||
| 	.name =		"ddcmp", | ||||
| 	.ctl_name =	NET_DECNET_CONF_DDCMP, | ||||
| 	.timer3 =	dn_send_ptp_hello, | ||||
| }, | ||||
| { | ||||
|  | @ -145,7 +140,6 @@ static struct dn_dev_parms dn_dev_list[] =  { | |||
| 	.t2 =		1, | ||||
| 	.t3 =		10, | ||||
| 	.name =		"loopback", | ||||
| 	.ctl_name =	NET_DECNET_CONF_LOOPBACK, | ||||
| 	.timer3 =	dn_send_brd_hello, | ||||
| } | ||||
| }; | ||||
|  | @ -166,10 +160,6 @@ static int max_priority[] = { 127 }; /* From DECnet spec */ | |||
| 
 | ||||
| static int dn_forwarding_proc(ctl_table *, int, | ||||
| 			void __user *, size_t *, loff_t *); | ||||
| static int dn_forwarding_sysctl(ctl_table *table, | ||||
| 			void __user *oldval, size_t __user *oldlenp, | ||||
| 			void __user *newval, size_t newlen); | ||||
| 
 | ||||
| static struct dn_dev_sysctl_table { | ||||
| 	struct ctl_table_header *sysctl_header; | ||||
| 	ctl_table dn_dev_vars[5]; | ||||
|  | @ -177,44 +167,36 @@ static struct dn_dev_sysctl_table { | |||
| 	NULL, | ||||
| 	{ | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_CONF_DEV_FORWARDING, | ||||
| 		.procname = "forwarding", | ||||
| 		.data = (void *)DN_DEV_PARMS_OFFSET(forwarding), | ||||
| 		.maxlen = sizeof(int), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = dn_forwarding_proc, | ||||
| 		.strategy = dn_forwarding_sysctl, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_CONF_DEV_PRIORITY, | ||||
| 		.procname = "priority", | ||||
| 		.data = (void *)DN_DEV_PARMS_OFFSET(priority), | ||||
| 		.maxlen = sizeof(int), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dointvec_minmax, | ||||
| 		.strategy = sysctl_intvec, | ||||
| 		.extra1 = &min_priority, | ||||
| 		.extra2 = &max_priority | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_CONF_DEV_T2, | ||||
| 		.procname = "t2", | ||||
| 		.data = (void *)DN_DEV_PARMS_OFFSET(t2), | ||||
| 		.maxlen = sizeof(int), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dointvec_minmax, | ||||
| 		.strategy = sysctl_intvec, | ||||
| 		.extra1 = &min_t2, | ||||
| 		.extra2 = &max_t2 | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_CONF_DEV_T3, | ||||
| 		.procname = "t3", | ||||
| 		.data = (void *)DN_DEV_PARMS_OFFSET(t3), | ||||
| 		.maxlen = sizeof(int), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dointvec_minmax, | ||||
| 		.strategy = sysctl_intvec, | ||||
| 		.extra1 = &min_t3, | ||||
| 		.extra2 = &max_t3 | ||||
| 	}, | ||||
|  | @ -230,9 +212,9 @@ static void dn_dev_sysctl_register(struct net_device *dev, struct dn_dev_parms * | |||
| #define DN_CTL_PATH_DEV	3 | ||||
| 
 | ||||
| 	struct ctl_path dn_ctl_path[] = { | ||||
| 		{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 		{ .procname = "decnet", .ctl_name = NET_DECNET, }, | ||||
| 		{ .procname = "conf", .ctl_name = NET_DECNET_CONF, }, | ||||
| 		{ .procname = "net",  }, | ||||
| 		{ .procname = "decnet",  }, | ||||
| 		{ .procname = "conf",  }, | ||||
| 		{ /* to be set */ }, | ||||
| 		{ }, | ||||
| 	}; | ||||
|  | @ -248,10 +230,8 @@ static void dn_dev_sysctl_register(struct net_device *dev, struct dn_dev_parms * | |||
| 
 | ||||
| 	if (dev) { | ||||
| 		dn_ctl_path[DN_CTL_PATH_DEV].procname = dev->name; | ||||
| 		dn_ctl_path[DN_CTL_PATH_DEV].ctl_name = dev->ifindex; | ||||
| 	} else { | ||||
| 		dn_ctl_path[DN_CTL_PATH_DEV].procname = parms->name; | ||||
| 		dn_ctl_path[DN_CTL_PATH_DEV].ctl_name = parms->ctl_name; | ||||
| 	} | ||||
| 
 | ||||
| 	t->dn_dev_vars[0].extra1 = (void *)dev; | ||||
|  | @ -317,44 +297,6 @@ static int dn_forwarding_proc(ctl_table *table, int write, | |||
| #endif | ||||
| } | ||||
| 
 | ||||
| static int dn_forwarding_sysctl(ctl_table *table, | ||||
| 			void __user *oldval, size_t __user *oldlenp, | ||||
| 			void __user *newval, size_t newlen) | ||||
| { | ||||
| #ifdef CONFIG_DECNET_ROUTER | ||||
| 	struct net_device *dev = table->extra1; | ||||
| 	struct dn_dev *dn_db; | ||||
| 	int value; | ||||
| 
 | ||||
| 	if (table->extra1 == NULL) | ||||
| 		return -EINVAL; | ||||
| 
 | ||||
| 	dn_db = dev->dn_ptr; | ||||
| 
 | ||||
| 	if (newval && newlen) { | ||||
| 		if (newlen != sizeof(int)) | ||||
| 			return -EINVAL; | ||||
| 
 | ||||
| 		if (get_user(value, (int __user *)newval)) | ||||
| 			return -EFAULT; | ||||
| 		if (value < 0) | ||||
| 			return -EINVAL; | ||||
| 		if (value > 2) | ||||
| 			return -EINVAL; | ||||
| 
 | ||||
| 		if (dn_db->parms.down) | ||||
| 			dn_db->parms.down(dev); | ||||
| 		dn_db->parms.forwarding = value; | ||||
| 		if (dn_db->parms.up) | ||||
| 			dn_db->parms.up(dev); | ||||
| 	} | ||||
| 
 | ||||
| 	return 0; | ||||
| #else | ||||
| 	return -EINVAL; | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
| #else /* CONFIG_SYSCTL */ | ||||
| static void dn_dev_sysctl_unregister(struct dn_dev_parms *parms) | ||||
| { | ||||
|  |  | |||
|  | @ -131,39 +131,6 @@ static int parse_addr(__le16 *addr, char *str) | |||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| static int dn_node_address_strategy(ctl_table *table, | ||||
| 				void __user *oldval, size_t __user *oldlenp, | ||||
| 				void __user *newval, size_t newlen) | ||||
| { | ||||
| 	size_t len; | ||||
| 	__le16 addr; | ||||
| 
 | ||||
| 	if (oldval && oldlenp) { | ||||
| 		if (get_user(len, oldlenp)) | ||||
| 			return -EFAULT; | ||||
| 		if (len) { | ||||
| 			if (len != sizeof(unsigned short)) | ||||
| 				return -EINVAL; | ||||
| 			if (put_user(decnet_address, (__le16 __user *)oldval)) | ||||
| 				return -EFAULT; | ||||
| 		} | ||||
| 	} | ||||
| 	if (newval && newlen) { | ||||
| 		if (newlen != sizeof(unsigned short)) | ||||
| 			return -EINVAL; | ||||
| 		if (get_user(addr, (__le16 __user *)newval)) | ||||
| 			return -EFAULT; | ||||
| 
 | ||||
| 		dn_dev_devices_off(); | ||||
| 
 | ||||
| 		decnet_address = addr; | ||||
| 
 | ||||
| 		dn_dev_devices_on(); | ||||
| 	} | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| static int dn_node_address_handler(ctl_table *table, int write, | ||||
| 				void __user *buffer, | ||||
| 				size_t *lenp, loff_t *ppos) | ||||
|  | @ -215,65 +182,6 @@ static int dn_node_address_handler(ctl_table *table, int write, | |||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| static int dn_def_dev_strategy(ctl_table *table, | ||||
| 				void __user *oldval, size_t __user *oldlenp, | ||||
| 				void __user *newval, size_t newlen) | ||||
| { | ||||
| 	size_t len; | ||||
| 	struct net_device *dev; | ||||
| 	char devname[17]; | ||||
| 	size_t namel; | ||||
| 	int rv = 0; | ||||
| 
 | ||||
| 	devname[0] = 0; | ||||
| 
 | ||||
| 	if (oldval && oldlenp) { | ||||
| 		if (get_user(len, oldlenp)) | ||||
| 			return -EFAULT; | ||||
| 		if (len) { | ||||
| 			dev = dn_dev_get_default(); | ||||
| 			if (dev) { | ||||
| 				strcpy(devname, dev->name); | ||||
| 				dev_put(dev); | ||||
| 			} | ||||
| 
 | ||||
| 			namel = strlen(devname) + 1; | ||||
| 			if (len > namel) len = namel; | ||||
| 
 | ||||
| 			if (copy_to_user(oldval, devname, len)) | ||||
| 				return -EFAULT; | ||||
| 
 | ||||
| 			if (put_user(len, oldlenp)) | ||||
| 				return -EFAULT; | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	if (newval && newlen) { | ||||
| 		if (newlen > 16) | ||||
| 			return -E2BIG; | ||||
| 
 | ||||
| 		if (copy_from_user(devname, newval, newlen)) | ||||
| 			return -EFAULT; | ||||
| 
 | ||||
| 		devname[newlen] = 0; | ||||
| 
 | ||||
| 		dev = dev_get_by_name(&init_net, devname); | ||||
| 		if (dev == NULL) | ||||
| 			return -ENODEV; | ||||
| 
 | ||||
| 		rv = -ENODEV; | ||||
| 		if (dev->dn_ptr != NULL) { | ||||
| 			rv = dn_dev_set_default(dev, 1); | ||||
| 			if (rv) | ||||
| 				dev_put(dev); | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return rv; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| static int dn_def_dev_handler(ctl_table *table, int write, | ||||
| 				void __user *buffer, | ||||
| 				size_t *lenp, loff_t *ppos) | ||||
|  | @ -339,138 +247,112 @@ static int dn_def_dev_handler(ctl_table *table, int write, | |||
| 
 | ||||
| static ctl_table dn_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_NODE_ADDRESS, | ||||
| 		.procname = "node_address", | ||||
| 		.maxlen = 7, | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = dn_node_address_handler, | ||||
| 		.strategy = dn_node_address_strategy, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_NODE_NAME, | ||||
| 		.procname = "node_name", | ||||
| 		.data = node_name, | ||||
| 		.maxlen = 7, | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dostring, | ||||
| 		.strategy = sysctl_string, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_DEFAULT_DEVICE, | ||||
| 		.procname = "default_device", | ||||
| 		.maxlen = 16, | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = dn_def_dev_handler, | ||||
| 		.strategy = dn_def_dev_strategy, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_TIME_WAIT, | ||||
| 		.procname = "time_wait", | ||||
| 		.data = &decnet_time_wait, | ||||
| 		.maxlen = sizeof(int), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dointvec_minmax, | ||||
| 		.strategy = sysctl_intvec, | ||||
| 		.extra1 = &min_decnet_time_wait, | ||||
| 		.extra2 = &max_decnet_time_wait | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_DN_COUNT, | ||||
| 		.procname = "dn_count", | ||||
| 		.data = &decnet_dn_count, | ||||
| 		.maxlen = sizeof(int), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dointvec_minmax, | ||||
| 		.strategy = sysctl_intvec, | ||||
| 		.extra1 = &min_state_count, | ||||
| 		.extra2 = &max_state_count | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_DI_COUNT, | ||||
| 		.procname = "di_count", | ||||
| 		.data = &decnet_di_count, | ||||
| 		.maxlen = sizeof(int), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dointvec_minmax, | ||||
| 		.strategy = sysctl_intvec, | ||||
| 		.extra1 = &min_state_count, | ||||
| 		.extra2 = &max_state_count | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_DR_COUNT, | ||||
| 		.procname = "dr_count", | ||||
| 		.data = &decnet_dr_count, | ||||
| 		.maxlen = sizeof(int), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dointvec_minmax, | ||||
| 		.strategy = sysctl_intvec, | ||||
| 		.extra1 = &min_state_count, | ||||
| 		.extra2 = &max_state_count | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_DST_GC_INTERVAL, | ||||
| 		.procname = "dst_gc_interval", | ||||
| 		.data = &decnet_dst_gc_interval, | ||||
| 		.maxlen = sizeof(int), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dointvec_minmax, | ||||
| 		.strategy = sysctl_intvec, | ||||
| 		.extra1 = &min_decnet_dst_gc_interval, | ||||
| 		.extra2 = &max_decnet_dst_gc_interval | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_NO_FC_MAX_CWND, | ||||
| 		.procname = "no_fc_max_cwnd", | ||||
| 		.data = &decnet_no_fc_max_cwnd, | ||||
| 		.maxlen = sizeof(int), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dointvec_minmax, | ||||
| 		.strategy = sysctl_intvec, | ||||
| 		.extra1 = &min_decnet_no_fc_max_cwnd, | ||||
| 		.extra2 = &max_decnet_no_fc_max_cwnd | ||||
| 	}, | ||||
|        { | ||||
| 		.ctl_name = NET_DECNET_MEM, | ||||
| 		.procname = "decnet_mem", | ||||
| 		.data = &sysctl_decnet_mem, | ||||
| 		.maxlen = sizeof(sysctl_decnet_mem), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dointvec, | ||||
| 		.strategy = sysctl_intvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_RMEM, | ||||
| 		.procname = "decnet_rmem", | ||||
| 		.data = &sysctl_decnet_rmem, | ||||
| 		.maxlen = sizeof(sysctl_decnet_rmem), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dointvec, | ||||
| 		.strategy = sysctl_intvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_WMEM, | ||||
| 		.procname = "decnet_wmem", | ||||
| 		.data = &sysctl_decnet_wmem, | ||||
| 		.maxlen = sizeof(sysctl_decnet_wmem), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dointvec, | ||||
| 		.strategy = sysctl_intvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = NET_DECNET_DEBUG_LEVEL, | ||||
| 		.procname = "debug", | ||||
| 		.data = &decnet_debug_level, | ||||
| 		.maxlen = sizeof(int), | ||||
| 		.mode = 0644, | ||||
| 		.proc_handler = proc_dointvec, | ||||
| 		.strategy = sysctl_intvec, | ||||
| 	}, | ||||
| 	{0} | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path dn_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "decnet", .ctl_name = NET_DECNET, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "decnet", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -1240,7 +1240,7 @@ void __init arp_init(void) | |||
| 	arp_proc_init(); | ||||
| #ifdef CONFIG_SYSCTL | ||||
| 	neigh_sysctl_register(NULL, &arp_tbl.parms, NET_IPV4, | ||||
| 			      NET_IPV4_NEIGH, "ipv4", NULL, NULL); | ||||
| 			      NET_IPV4_NEIGH, "ipv4", NULL); | ||||
| #endif | ||||
| 	register_netdevice_notifier(&arp_netdev_notifier); | ||||
| } | ||||
|  |  | |||
|  | @ -1293,58 +1293,6 @@ static int devinet_conf_proc(ctl_table *ctl, int write, | |||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| static int devinet_conf_sysctl(ctl_table *table, | ||||
| 			       void __user *oldval, size_t __user *oldlenp, | ||||
| 			       void __user *newval, size_t newlen) | ||||
| { | ||||
| 	struct ipv4_devconf *cnf; | ||||
| 	struct net *net; | ||||
| 	int *valp = table->data; | ||||
| 	int new; | ||||
| 	int i; | ||||
| 
 | ||||
| 	if (!newval || !newlen) | ||||
| 		return 0; | ||||
| 
 | ||||
| 	if (newlen != sizeof(int)) | ||||
| 		return -EINVAL; | ||||
| 
 | ||||
| 	if (get_user(new, (int __user *)newval)) | ||||
| 		return -EFAULT; | ||||
| 
 | ||||
| 	if (new == *valp) | ||||
| 		return 0; | ||||
| 
 | ||||
| 	if (oldval && oldlenp) { | ||||
| 		size_t len; | ||||
| 
 | ||||
| 		if (get_user(len, oldlenp)) | ||||
| 			return -EFAULT; | ||||
| 
 | ||||
| 		if (len) { | ||||
| 			if (len > table->maxlen) | ||||
| 				len = table->maxlen; | ||||
| 			if (copy_to_user(oldval, valp, len)) | ||||
| 				return -EFAULT; | ||||
| 			if (put_user(len, oldlenp)) | ||||
| 				return -EFAULT; | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	*valp = new; | ||||
| 
 | ||||
| 	cnf = table->extra1; | ||||
| 	net = table->extra2; | ||||
| 	i = (int *)table->data - cnf->data; | ||||
| 
 | ||||
| 	set_bit(i, cnf->state); | ||||
| 
 | ||||
| 	if (cnf == net->ipv4.devconf_dflt) | ||||
| 		devinet_copy_dflt_conf(net, i); | ||||
| 
 | ||||
| 	return 1; | ||||
| } | ||||
| 
 | ||||
| static int devinet_sysctl_forward(ctl_table *ctl, int write, | ||||
| 				  void __user *buffer, | ||||
| 				  size_t *lenp, loff_t *ppos) | ||||
|  | @ -1390,47 +1338,28 @@ int ipv4_doint_and_flush(ctl_table *ctl, int write, | |||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| int ipv4_doint_and_flush_strategy(ctl_table *table, | ||||
| 				  void __user *oldval, size_t __user *oldlenp, | ||||
| 				  void __user *newval, size_t newlen) | ||||
| { | ||||
| 	int ret = devinet_conf_sysctl(table, oldval, oldlenp, newval, newlen); | ||||
| 	struct net *net = table->extra2; | ||||
| 
 | ||||
| 	if (ret == 1) | ||||
| 		rt_cache_flush(net, 0); | ||||
| 
 | ||||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| #define DEVINET_SYSCTL_ENTRY(attr, name, mval, proc, sysctl) \ | ||||
| #define DEVINET_SYSCTL_ENTRY(attr, name, mval, proc) \ | ||||
| 	{ \ | ||||
| 		.ctl_name	= NET_IPV4_CONF_ ## attr, \ | ||||
| 		.procname	= name, \ | ||||
| 		.data		= ipv4_devconf.data + \ | ||||
| 				  NET_IPV4_CONF_ ## attr - 1, \ | ||||
| 		.maxlen		= sizeof(int), \ | ||||
| 		.mode		= mval, \ | ||||
| 		.proc_handler	= proc, \ | ||||
| 		.strategy	= sysctl, \ | ||||
| 		.extra1		= &ipv4_devconf, \ | ||||
| 	} | ||||
| 
 | ||||
| #define DEVINET_SYSCTL_RW_ENTRY(attr, name) \ | ||||
| 	DEVINET_SYSCTL_ENTRY(attr, name, 0644, devinet_conf_proc, \ | ||||
| 			     devinet_conf_sysctl) | ||||
| 	DEVINET_SYSCTL_ENTRY(attr, name, 0644, devinet_conf_proc) | ||||
| 
 | ||||
| #define DEVINET_SYSCTL_RO_ENTRY(attr, name) \ | ||||
| 	DEVINET_SYSCTL_ENTRY(attr, name, 0444, devinet_conf_proc, \ | ||||
| 			     devinet_conf_sysctl) | ||||
| 	DEVINET_SYSCTL_ENTRY(attr, name, 0444, devinet_conf_proc) | ||||
| 
 | ||||
| #define DEVINET_SYSCTL_COMPLEX_ENTRY(attr, name, proc, sysctl) \ | ||||
| 	DEVINET_SYSCTL_ENTRY(attr, name, 0644, proc, sysctl) | ||||
| #define DEVINET_SYSCTL_COMPLEX_ENTRY(attr, name, proc) \ | ||||
| 	DEVINET_SYSCTL_ENTRY(attr, name, 0644, proc) | ||||
| 
 | ||||
| #define DEVINET_SYSCTL_FLUSHING_ENTRY(attr, name) \ | ||||
| 	DEVINET_SYSCTL_COMPLEX_ENTRY(attr, name, ipv4_doint_and_flush, \ | ||||
| 				     ipv4_doint_and_flush_strategy) | ||||
| 	DEVINET_SYSCTL_COMPLEX_ENTRY(attr, name, ipv4_doint_and_flush) | ||||
| 
 | ||||
| static struct devinet_sysctl_table { | ||||
| 	struct ctl_table_header *sysctl_header; | ||||
|  | @ -1439,8 +1368,7 @@ static struct devinet_sysctl_table { | |||
| } devinet_sysctl = { | ||||
| 	.devinet_vars = { | ||||
| 		DEVINET_SYSCTL_COMPLEX_ENTRY(FORWARDING, "forwarding", | ||||
| 					     devinet_sysctl_forward, | ||||
| 					     devinet_conf_sysctl), | ||||
| 					     devinet_sysctl_forward), | ||||
| 		DEVINET_SYSCTL_RO_ENTRY(MC_FORWARDING, "mc_forwarding"), | ||||
| 
 | ||||
| 		DEVINET_SYSCTL_RW_ENTRY(ACCEPT_REDIRECTS, "accept_redirects"), | ||||
|  | @ -1471,7 +1399,7 @@ static struct devinet_sysctl_table { | |||
| }; | ||||
| 
 | ||||
| static int __devinet_sysctl_register(struct net *net, char *dev_name, | ||||
| 		int ctl_name, struct ipv4_devconf *p) | ||||
| 					struct ipv4_devconf *p) | ||||
| { | ||||
| 	int i; | ||||
| 	struct devinet_sysctl_table *t; | ||||
|  | @ -1479,9 +1407,9 @@ static int __devinet_sysctl_register(struct net *net, char *dev_name, | |||
| #define DEVINET_CTL_PATH_DEV	3 | ||||
| 
 | ||||
| 	struct ctl_path devinet_ctl_path[] = { | ||||
| 		{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 		{ .procname = "ipv4", .ctl_name = NET_IPV4, }, | ||||
| 		{ .procname = "conf", .ctl_name = NET_IPV4_CONF, }, | ||||
| 		{ .procname = "net",  }, | ||||
| 		{ .procname = "ipv4", }, | ||||
| 		{ .procname = "conf", }, | ||||
| 		{ /* to be set */ }, | ||||
| 		{ }, | ||||
| 	}; | ||||
|  | @ -1506,7 +1434,6 @@ static int __devinet_sysctl_register(struct net *net, char *dev_name, | |||
| 		goto free; | ||||
| 
 | ||||
| 	devinet_ctl_path[DEVINET_CTL_PATH_DEV].procname = t->dev_name; | ||||
| 	devinet_ctl_path[DEVINET_CTL_PATH_DEV].ctl_name = ctl_name; | ||||
| 
 | ||||
| 	t->sysctl_header = register_net_sysctl_table(net, devinet_ctl_path, | ||||
| 			t->devinet_vars); | ||||
|  | @ -1540,9 +1467,9 @@ static void __devinet_sysctl_unregister(struct ipv4_devconf *cnf) | |||
| static void devinet_sysctl_register(struct in_device *idev) | ||||
| { | ||||
| 	neigh_sysctl_register(idev->dev, idev->arp_parms, NET_IPV4, | ||||
| 			NET_IPV4_NEIGH, "ipv4", NULL, NULL); | ||||
| 			NET_IPV4_NEIGH, "ipv4", NULL); | ||||
| 	__devinet_sysctl_register(dev_net(idev->dev), idev->dev->name, | ||||
| 			idev->dev->ifindex, &idev->cnf); | ||||
| 					&idev->cnf); | ||||
| } | ||||
| 
 | ||||
| static void devinet_sysctl_unregister(struct in_device *idev) | ||||
|  | @ -1553,14 +1480,12 @@ static void devinet_sysctl_unregister(struct in_device *idev) | |||
| 
 | ||||
| static struct ctl_table ctl_forward_entry[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_FORWARD, | ||||
| 		.procname	= "ip_forward", | ||||
| 		.data		= &ipv4_devconf.data[ | ||||
| 					NET_IPV4_CONF_FORWARDING - 1], | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= devinet_sysctl_forward, | ||||
| 		.strategy	= devinet_conf_sysctl, | ||||
| 		.extra1		= &ipv4_devconf, | ||||
| 		.extra2		= &init_net, | ||||
| 	}, | ||||
|  | @ -1568,8 +1493,8 @@ static struct ctl_table ctl_forward_entry[] = { | |||
| }; | ||||
| 
 | ||||
| static __net_initdata struct ctl_path net_ipv4_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "ipv4", .ctl_name = NET_IPV4, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "ipv4", }, | ||||
| 	{ }, | ||||
| }; | ||||
| #endif | ||||
|  | @ -1608,13 +1533,11 @@ static __net_init int devinet_init_net(struct net *net) | |||
| 	} | ||||
| 
 | ||||
| #ifdef CONFIG_SYSCTL | ||||
| 	err = __devinet_sysctl_register(net, "all", | ||||
| 			NET_PROTO_CONF_ALL, all); | ||||
| 	err = __devinet_sysctl_register(net, "all", all); | ||||
| 	if (err < 0) | ||||
| 		goto err_reg_all; | ||||
| 
 | ||||
| 	err = __devinet_sysctl_register(net, "default", | ||||
| 			NET_PROTO_CONF_DEFAULT, dflt); | ||||
| 	err = __devinet_sysctl_register(net, "default", dflt); | ||||
| 	if (err < 0) | ||||
| 		goto err_reg_dflt; | ||||
| 
 | ||||
|  |  | |||
|  | @ -603,7 +603,6 @@ static int zero; | |||
| 
 | ||||
| static struct ctl_table ip4_frags_ns_ctl_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_IPFRAG_HIGH_THRESH, | ||||
| 		.procname	= "ipfrag_high_thresh", | ||||
| 		.data		= &init_net.ipv4.frags.high_thresh, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -611,7 +610,6 @@ static struct ctl_table ip4_frags_ns_ctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_IPFRAG_LOW_THRESH, | ||||
| 		.procname	= "ipfrag_low_thresh", | ||||
| 		.data		= &init_net.ipv4.frags.low_thresh, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -619,26 +617,22 @@ static struct ctl_table ip4_frags_ns_ctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_IPFRAG_TIME, | ||||
| 		.procname	= "ipfrag_time", | ||||
| 		.data		= &init_net.ipv4.frags.timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies | ||||
| 	}, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_table ip4_frags_ctl_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_IPFRAG_SECRET_INTERVAL, | ||||
| 		.procname	= "ipfrag_secret_interval", | ||||
| 		.data		= &ip4_frags.secret_interval, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies | ||||
| 	}, | ||||
| 	{ | ||||
| 		.procname	= "ipfrag_max_dist", | ||||
|  |  | |||
|  | @ -248,9 +248,9 @@ module_exit(ipv4_netfilter_fini); | |||
| 
 | ||||
| #ifdef CONFIG_SYSCTL | ||||
| struct ctl_path nf_net_ipv4_netfilter_sysctl_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "ipv4", .ctl_name = NET_IPV4, }, | ||||
| 	{ .procname = "netfilter", .ctl_name = NET_IPV4_NETFILTER, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "ipv4", }, | ||||
| 	{ .procname = "netfilter", }, | ||||
| 	{ } | ||||
| }; | ||||
| EXPORT_SYMBOL_GPL(nf_net_ipv4_netfilter_sysctl_path); | ||||
|  |  | |||
|  | @ -516,14 +516,13 @@ static struct ctl_table_header *ipq_sysctl_header; | |||
| 
 | ||||
| static ctl_table ipq_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPQ_QMAX, | ||||
| 		.procname	= NET_IPQ_QMAX_NAME, | ||||
| 		.data		= &queue_maxlen, | ||||
| 		.maxlen		= sizeof(queue_maxlen), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| #endif | ||||
| 
 | ||||
|  |  | |||
|  | @ -195,7 +195,6 @@ static int log_invalid_proto_max = 255; | |||
| 
 | ||||
| static ctl_table ip_ct_sysctl_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_NF_CONNTRACK_MAX, | ||||
| 		.procname	= "ip_conntrack_max", | ||||
| 		.data		= &nf_conntrack_max, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -203,7 +202,6 @@ static ctl_table ip_ct_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_NF_CONNTRACK_COUNT, | ||||
| 		.procname	= "ip_conntrack_count", | ||||
| 		.data		= &init_net.ct.count, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -211,7 +209,6 @@ static ctl_table ip_ct_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_NF_CONNTRACK_BUCKETS, | ||||
| 		.procname	= "ip_conntrack_buckets", | ||||
| 		.data		= &nf_conntrack_htable_size, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
|  | @ -219,7 +216,6 @@ static ctl_table ip_ct_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_NF_CONNTRACK_CHECKSUM, | ||||
| 		.procname	= "ip_conntrack_checksum", | ||||
| 		.data		= &init_net.ct.sysctl_checksum, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -227,19 +223,15 @@ static ctl_table ip_ct_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_NF_CONNTRACK_LOG_INVALID, | ||||
| 		.procname	= "ip_conntrack_log_invalid", | ||||
| 		.data		= &init_net.ct.sysctl_log_invalid, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &log_invalid_proto_min, | ||||
| 		.extra2		= &log_invalid_proto_max, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= 0 | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| #endif /* CONFIG_SYSCTL && CONFIG_NF_CONNTRACK_PROC_COMPAT */ | ||||
| 
 | ||||
|  |  | |||
|  | @ -270,9 +270,7 @@ static struct ctl_table icmp_sysctl_table[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = 0 | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| #ifdef CONFIG_NF_CONNTRACK_PROC_COMPAT | ||||
| static struct ctl_table icmp_compat_sysctl_table[] = { | ||||
|  | @ -283,9 +281,7 @@ static struct ctl_table icmp_compat_sysctl_table[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = 0 | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| #endif /* CONFIG_NF_CONNTRACK_PROC_COMPAT */ | ||||
| #endif /* CONFIG_SYSCTL */ | ||||
|  |  | |||
|  | @ -3056,23 +3056,6 @@ static int ipv4_sysctl_rtcache_flush(ctl_table *__ctl, int write, | |||
| 	return -EINVAL; | ||||
| } | ||||
| 
 | ||||
| static int ipv4_sysctl_rtcache_flush_strategy(ctl_table *table, | ||||
| 						void __user *oldval, | ||||
| 						size_t __user *oldlenp, | ||||
| 						void __user *newval, | ||||
| 						size_t newlen) | ||||
| { | ||||
| 	int delay; | ||||
| 	struct net *net; | ||||
| 	if (newlen != sizeof(int)) | ||||
| 		return -EINVAL; | ||||
| 	if (get_user(delay, (int __user *)newval)) | ||||
| 		return -EFAULT; | ||||
| 	net = (struct net *)table->extra1; | ||||
| 	rt_cache_flush(net, delay); | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| static void rt_secret_reschedule(int old) | ||||
| { | ||||
| 	struct net *net; | ||||
|  | @ -3117,23 +3100,8 @@ static int ipv4_sysctl_rt_secret_interval(ctl_table *ctl, int write, | |||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| static int ipv4_sysctl_rt_secret_interval_strategy(ctl_table *table, | ||||
| 						   void __user *oldval, | ||||
| 						   size_t __user *oldlenp, | ||||
| 						   void __user *newval, | ||||
| 						   size_t newlen) | ||||
| { | ||||
| 	int old = ip_rt_secret_interval; | ||||
| 	int ret = sysctl_jiffies(table, oldval, oldlenp, newval, newlen); | ||||
| 
 | ||||
| 	rt_secret_reschedule(old); | ||||
| 
 | ||||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| static ctl_table ipv4_route_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_GC_THRESH, | ||||
| 		.procname	= "gc_thresh", | ||||
| 		.data		= &ipv4_dst_ops.gc_thresh, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -3141,7 +3109,6 @@ static ctl_table ipv4_route_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_MAX_SIZE, | ||||
| 		.procname	= "max_size", | ||||
| 		.data		= &ip_rt_max_size, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -3151,43 +3118,34 @@ static ctl_table ipv4_route_table[] = { | |||
| 	{ | ||||
| 		/*  Deprecated. Use gc_min_interval_ms */ | ||||
| 
 | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_GC_MIN_INTERVAL, | ||||
| 		.procname	= "gc_min_interval", | ||||
| 		.data		= &ip_rt_gc_min_interval, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_GC_MIN_INTERVAL_MS, | ||||
| 		.procname	= "gc_min_interval_ms", | ||||
| 		.data		= &ip_rt_gc_min_interval, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_ms_jiffies, | ||||
| 		.strategy	= sysctl_ms_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_GC_TIMEOUT, | ||||
| 		.procname	= "gc_timeout", | ||||
| 		.data		= &ip_rt_gc_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_GC_INTERVAL, | ||||
| 		.procname	= "gc_interval", | ||||
| 		.data		= &ip_rt_gc_interval, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_REDIRECT_LOAD, | ||||
| 		.procname	= "redirect_load", | ||||
| 		.data		= &ip_rt_redirect_load, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -3195,7 +3153,6 @@ static ctl_table ipv4_route_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_REDIRECT_NUMBER, | ||||
| 		.procname	= "redirect_number", | ||||
| 		.data		= &ip_rt_redirect_number, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -3203,7 +3160,6 @@ static ctl_table ipv4_route_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_REDIRECT_SILENCE, | ||||
| 		.procname	= "redirect_silence", | ||||
| 		.data		= &ip_rt_redirect_silence, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -3211,7 +3167,6 @@ static ctl_table ipv4_route_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_ERROR_COST, | ||||
| 		.procname	= "error_cost", | ||||
| 		.data		= &ip_rt_error_cost, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -3219,7 +3174,6 @@ static ctl_table ipv4_route_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_ERROR_BURST, | ||||
| 		.procname	= "error_burst", | ||||
| 		.data		= &ip_rt_error_burst, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -3227,7 +3181,6 @@ static ctl_table ipv4_route_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_GC_ELASTICITY, | ||||
| 		.procname	= "gc_elasticity", | ||||
| 		.data		= &ip_rt_gc_elasticity, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -3235,16 +3188,13 @@ static ctl_table ipv4_route_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_MTU_EXPIRES, | ||||
| 		.procname	= "mtu_expires", | ||||
| 		.data		= &ip_rt_mtu_expires, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_MIN_PMTU, | ||||
| 		.procname	= "min_pmtu", | ||||
| 		.data		= &ip_rt_min_pmtu, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -3252,7 +3202,6 @@ static ctl_table ipv4_route_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_MIN_ADVMSS, | ||||
| 		.procname	= "min_adv_mss", | ||||
| 		.data		= &ip_rt_min_advmss, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -3260,50 +3209,46 @@ static ctl_table ipv4_route_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ROUTE_SECRET_INTERVAL, | ||||
| 		.procname	= "secret_interval", | ||||
| 		.data		= &ip_rt_secret_interval, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= ipv4_sysctl_rt_secret_interval, | ||||
| 		.strategy	= ipv4_sysctl_rt_secret_interval_strategy, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_table empty[1]; | ||||
| 
 | ||||
| static struct ctl_table ipv4_skeleton[] = | ||||
| { | ||||
| 	{ .procname = "route", .ctl_name = NET_IPV4_ROUTE, | ||||
| 	{ .procname = "route",  | ||||
| 	  .mode = 0555, .child = ipv4_route_table}, | ||||
| 	{ .procname = "neigh", .ctl_name = NET_IPV4_NEIGH, | ||||
| 	{ .procname = "neigh",  | ||||
| 	  .mode = 0555, .child = empty}, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static __net_initdata struct ctl_path ipv4_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "ipv4", .ctl_name = NET_IPV4, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "ipv4", }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_table ipv4_route_flush_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name 	= NET_IPV4_ROUTE_FLUSH, | ||||
| 		.procname	= "flush", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0200, | ||||
| 		.proc_handler	= ipv4_sysctl_rtcache_flush, | ||||
| 		.strategy	= ipv4_sysctl_rtcache_flush_strategy, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| static __net_initdata struct ctl_path ipv4_route_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "ipv4", .ctl_name = NET_IPV4, }, | ||||
| 	{ .procname = "route", .ctl_name = NET_IPV4_ROUTE, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "ipv4", }, | ||||
| 	{ .procname = "route", }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -63,34 +63,6 @@ static int ipv4_local_port_range(ctl_table *table, int write, | |||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| /* Validate changes from sysctl interface. */ | ||||
| static int ipv4_sysctl_local_port_range(ctl_table *table, | ||||
| 					 void __user *oldval, | ||||
| 					 size_t __user *oldlenp, | ||||
| 					void __user *newval, size_t newlen) | ||||
| { | ||||
| 	int ret; | ||||
| 	int range[2]; | ||||
| 	ctl_table tmp = { | ||||
| 		.data = &range, | ||||
| 		.maxlen = sizeof(range), | ||||
| 		.mode = table->mode, | ||||
| 		.extra1 = &ip_local_port_range_min, | ||||
| 		.extra2 = &ip_local_port_range_max, | ||||
| 	}; | ||||
| 
 | ||||
| 	inet_get_local_port_range(range, range + 1); | ||||
| 	ret = sysctl_intvec(&tmp, oldval, oldlenp, newval, newlen); | ||||
| 	if (ret == 0 && newval && newlen) { | ||||
| 		if (range[1] < range[0]) | ||||
| 			ret = -EINVAL; | ||||
| 		else | ||||
| 			set_local_port_range(range); | ||||
| 	} | ||||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| static int proc_tcp_congestion_control(ctl_table *ctl, int write, | ||||
| 				       void __user *buffer, size_t *lenp, loff_t *ppos) | ||||
| { | ||||
|  | @ -109,25 +81,6 @@ static int proc_tcp_congestion_control(ctl_table *ctl, int write, | |||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| static int sysctl_tcp_congestion_control(ctl_table *table, | ||||
| 					 void __user *oldval, | ||||
| 					 size_t __user *oldlenp, | ||||
| 					 void __user *newval, size_t newlen) | ||||
| { | ||||
| 	char val[TCP_CA_NAME_MAX]; | ||||
| 	ctl_table tbl = { | ||||
| 		.data = val, | ||||
| 		.maxlen = TCP_CA_NAME_MAX, | ||||
| 	}; | ||||
| 	int ret; | ||||
| 
 | ||||
| 	tcp_get_default_congestion_control(val); | ||||
| 	ret = sysctl_string(&tbl, oldval, oldlenp, newval, newlen); | ||||
| 	if (ret == 1 && newval && newlen) | ||||
| 		ret = tcp_set_default_congestion_control(val); | ||||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| static int proc_tcp_available_congestion_control(ctl_table *ctl, | ||||
| 						 int write, | ||||
| 						 void __user *buffer, size_t *lenp, | ||||
|  | @ -165,32 +118,8 @@ static int proc_allowed_congestion_control(ctl_table *ctl, | |||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| static int strategy_allowed_congestion_control(ctl_table *table, | ||||
| 					       void __user *oldval, | ||||
| 					       size_t __user *oldlenp, | ||||
| 					       void __user *newval, | ||||
| 					       size_t newlen) | ||||
| { | ||||
| 	ctl_table tbl = { .maxlen = TCP_CA_BUF_MAX }; | ||||
| 	int ret; | ||||
| 
 | ||||
| 	tbl.data = kmalloc(tbl.maxlen, GFP_USER); | ||||
| 	if (!tbl.data) | ||||
| 		return -ENOMEM; | ||||
| 
 | ||||
| 	tcp_get_available_congestion_control(tbl.data, tbl.maxlen); | ||||
| 	ret = sysctl_string(&tbl, oldval, oldlenp, newval, newlen); | ||||
| 	if (ret == 1 && newval && newlen) | ||||
| 		ret = tcp_set_allowed_congestion_control(tbl.data); | ||||
| 	kfree(tbl.data); | ||||
| 
 | ||||
| 	return ret; | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| static struct ctl_table ipv4_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_TCP_TIMESTAMPS, | ||||
| 		.procname	= "tcp_timestamps", | ||||
| 		.data		= &sysctl_tcp_timestamps, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -198,7 +127,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_TCP_WINDOW_SCALING, | ||||
| 		.procname	= "tcp_window_scaling", | ||||
| 		.data		= &sysctl_tcp_window_scaling, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -206,7 +134,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_TCP_SACK, | ||||
| 		.procname	= "tcp_sack", | ||||
| 		.data		= &sysctl_tcp_sack, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -214,7 +141,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_TCP_RETRANS_COLLAPSE, | ||||
| 		.procname	= "tcp_retrans_collapse", | ||||
| 		.data		= &sysctl_tcp_retrans_collapse, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -222,17 +148,14 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_DEFAULT_TTL, | ||||
| 		.procname	= "ip_default_ttl", | ||||
| 		.data		= &sysctl_ip_default_ttl, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= ipv4_doint_and_flush, | ||||
| 		.strategy	= ipv4_doint_and_flush_strategy, | ||||
| 		.extra2		= &init_net, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_NO_PMTU_DISC, | ||||
| 		.procname	= "ip_no_pmtu_disc", | ||||
| 		.data		= &ipv4_config.no_pmtu_disc, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -240,7 +163,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_NONLOCAL_BIND, | ||||
| 		.procname	= "ip_nonlocal_bind", | ||||
| 		.data		= &sysctl_ip_nonlocal_bind, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -248,7 +170,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_TCP_SYN_RETRIES, | ||||
| 		.procname	= "tcp_syn_retries", | ||||
| 		.data		= &sysctl_tcp_syn_retries, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -256,7 +177,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_SYNACK_RETRIES, | ||||
| 		.procname	= "tcp_synack_retries", | ||||
| 		.data		= &sysctl_tcp_synack_retries, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -264,7 +184,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_MAX_ORPHANS, | ||||
| 		.procname	= "tcp_max_orphans", | ||||
| 		.data		= &sysctl_tcp_max_orphans, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -272,7 +191,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_MAX_TW_BUCKETS, | ||||
| 		.procname	= "tcp_max_tw_buckets", | ||||
| 		.data		= &tcp_death_row.sysctl_max_tw_buckets, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -280,7 +198,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_DYNADDR, | ||||
| 		.procname	= "ip_dynaddr", | ||||
| 		.data		= &sysctl_ip_dynaddr, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -288,16 +205,13 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_TCP_KEEPALIVE_TIME, | ||||
| 		.procname	= "tcp_keepalive_time", | ||||
| 		.data		= &sysctl_tcp_keepalive_time, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_TCP_KEEPALIVE_PROBES, | ||||
| 		.procname	= "tcp_keepalive_probes", | ||||
| 		.data		= &sysctl_tcp_keepalive_probes, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -305,26 +219,21 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_TCP_KEEPALIVE_INTVL, | ||||
| 		.procname	= "tcp_keepalive_intvl", | ||||
| 		.data		= &sysctl_tcp_keepalive_intvl, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_TCP_RETRIES1, | ||||
| 		.procname	= "tcp_retries1", | ||||
| 		.data		= &sysctl_tcp_retries1, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra2		= &tcp_retr1_max | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_TCP_RETRIES2, | ||||
| 		.procname	= "tcp_retries2", | ||||
| 		.data		= &sysctl_tcp_retries2, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -332,17 +241,14 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_TCP_FIN_TIMEOUT, | ||||
| 		.procname	= "tcp_fin_timeout", | ||||
| 		.data		= &sysctl_tcp_fin_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies | ||||
| 	}, | ||||
| #ifdef CONFIG_SYN_COOKIES | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_SYNCOOKIES, | ||||
| 		.procname	= "tcp_syncookies", | ||||
| 		.data		= &sysctl_tcp_syncookies, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -351,7 +257,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 	}, | ||||
| #endif | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_TW_RECYCLE, | ||||
| 		.procname	= "tcp_tw_recycle", | ||||
| 		.data		= &tcp_death_row.sysctl_tw_recycle, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -359,7 +264,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_ABORT_ON_OVERFLOW, | ||||
| 		.procname	= "tcp_abort_on_overflow", | ||||
| 		.data		= &sysctl_tcp_abort_on_overflow, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -367,7 +271,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_STDURG, | ||||
| 		.procname	= "tcp_stdurg", | ||||
| 		.data		= &sysctl_tcp_stdurg, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -375,7 +278,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_RFC1337, | ||||
| 		.procname	= "tcp_rfc1337", | ||||
| 		.data		= &sysctl_tcp_rfc1337, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -383,7 +285,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_MAX_SYN_BACKLOG, | ||||
| 		.procname	= "tcp_max_syn_backlog", | ||||
| 		.data		= &sysctl_max_syn_backlog, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -391,17 +292,14 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_LOCAL_PORT_RANGE, | ||||
| 		.procname	= "ip_local_port_range", | ||||
| 		.data		= &sysctl_local_ports.range, | ||||
| 		.maxlen		= sizeof(sysctl_local_ports.range), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= ipv4_local_port_range, | ||||
| 		.strategy	= ipv4_sysctl_local_port_range, | ||||
| 	}, | ||||
| #ifdef CONFIG_IP_MULTICAST | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_IGMP_MAX_MEMBERSHIPS, | ||||
| 		.procname	= "igmp_max_memberships", | ||||
| 		.data		= &sysctl_igmp_max_memberships, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -411,7 +309,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 
 | ||||
| #endif | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_IGMP_MAX_MSF, | ||||
| 		.procname	= "igmp_max_msf", | ||||
| 		.data		= &sysctl_igmp_max_msf, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -419,7 +316,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_INET_PEER_THRESHOLD, | ||||
| 		.procname	= "inet_peer_threshold", | ||||
| 		.data		= &inet_peer_threshold, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -427,43 +323,34 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_INET_PEER_MINTTL, | ||||
| 		.procname	= "inet_peer_minttl", | ||||
| 		.data		= &inet_peer_minttl, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_INET_PEER_MAXTTL, | ||||
| 		.procname	= "inet_peer_maxttl", | ||||
| 		.data		= &inet_peer_maxttl, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_INET_PEER_GC_MINTIME, | ||||
| 		.procname	= "inet_peer_gc_mintime", | ||||
| 		.data		= &inet_peer_gc_mintime, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_INET_PEER_GC_MAXTIME, | ||||
| 		.procname	= "inet_peer_gc_maxtime", | ||||
| 		.data		= &inet_peer_gc_maxtime, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_ORPHAN_RETRIES, | ||||
| 		.procname	= "tcp_orphan_retries", | ||||
| 		.data		= &sysctl_tcp_orphan_retries, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -471,7 +358,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_FACK, | ||||
| 		.procname	= "tcp_fack", | ||||
| 		.data		= &sysctl_tcp_fack, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -479,7 +365,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_REORDERING, | ||||
| 		.procname	= "tcp_reordering", | ||||
| 		.data		= &sysctl_tcp_reordering, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -487,7 +372,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_ECN, | ||||
| 		.procname	= "tcp_ecn", | ||||
| 		.data		= &sysctl_tcp_ecn, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -495,7 +379,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_DSACK, | ||||
| 		.procname	= "tcp_dsack", | ||||
| 		.data		= &sysctl_tcp_dsack, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -503,7 +386,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_MEM, | ||||
| 		.procname	= "tcp_mem", | ||||
| 		.data		= &sysctl_tcp_mem, | ||||
| 		.maxlen		= sizeof(sysctl_tcp_mem), | ||||
|  | @ -511,7 +393,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_WMEM, | ||||
| 		.procname	= "tcp_wmem", | ||||
| 		.data		= &sysctl_tcp_wmem, | ||||
| 		.maxlen		= sizeof(sysctl_tcp_wmem), | ||||
|  | @ -519,7 +400,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_RMEM, | ||||
| 		.procname	= "tcp_rmem", | ||||
| 		.data		= &sysctl_tcp_rmem, | ||||
| 		.maxlen		= sizeof(sysctl_tcp_rmem), | ||||
|  | @ -527,7 +407,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_APP_WIN, | ||||
| 		.procname	= "tcp_app_win", | ||||
| 		.data		= &sysctl_tcp_app_win, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -535,7 +414,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_ADV_WIN_SCALE, | ||||
| 		.procname	= "tcp_adv_win_scale", | ||||
| 		.data		= &sysctl_tcp_adv_win_scale, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -543,7 +421,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_TW_REUSE, | ||||
| 		.procname	= "tcp_tw_reuse", | ||||
| 		.data		= &sysctl_tcp_tw_reuse, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -551,7 +428,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_FRTO, | ||||
| 		.procname	= "tcp_frto", | ||||
| 		.data		= &sysctl_tcp_frto, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -559,7 +435,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_FRTO_RESPONSE, | ||||
| 		.procname	= "tcp_frto_response", | ||||
| 		.data		= &sysctl_tcp_frto_response, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -567,7 +442,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_LOW_LATENCY, | ||||
| 		.procname	= "tcp_low_latency", | ||||
| 		.data		= &sysctl_tcp_low_latency, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -575,7 +449,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_NO_METRICS_SAVE, | ||||
| 		.procname	= "tcp_no_metrics_save", | ||||
| 		.data		= &sysctl_tcp_nometrics_save, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -583,7 +456,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_MODERATE_RCVBUF, | ||||
| 		.procname	= "tcp_moderate_rcvbuf", | ||||
| 		.data		= &sysctl_tcp_moderate_rcvbuf, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -591,7 +463,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_TSO_WIN_DIVISOR, | ||||
| 		.procname	= "tcp_tso_win_divisor", | ||||
| 		.data		= &sysctl_tcp_tso_win_divisor, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -599,15 +470,12 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_CONG_CONTROL, | ||||
| 		.procname	= "tcp_congestion_control", | ||||
| 		.mode		= 0644, | ||||
| 		.maxlen		= TCP_CA_NAME_MAX, | ||||
| 		.proc_handler	= proc_tcp_congestion_control, | ||||
| 		.strategy	= sysctl_tcp_congestion_control, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_ABC, | ||||
| 		.procname	= "tcp_abc", | ||||
| 		.data		= &sysctl_tcp_abc, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -615,7 +483,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_MTU_PROBING, | ||||
| 		.procname	= "tcp_mtu_probing", | ||||
| 		.data		= &sysctl_tcp_mtu_probing, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -623,7 +490,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_BASE_MSS, | ||||
| 		.procname	= "tcp_base_mss", | ||||
| 		.data		= &sysctl_tcp_base_mss, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -631,7 +497,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_TCP_WORKAROUND_SIGNED_WINDOWS, | ||||
| 		.procname	= "tcp_workaround_signed_windows", | ||||
| 		.data		= &sysctl_tcp_workaround_signed_windows, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -640,7 +505,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 	}, | ||||
| #ifdef CONFIG_NET_DMA | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_DMA_COPYBREAK, | ||||
| 		.procname	= "tcp_dma_copybreak", | ||||
| 		.data		= &sysctl_tcp_dma_copybreak, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -649,7 +513,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 	}, | ||||
| #endif | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_SLOW_START_AFTER_IDLE, | ||||
| 		.procname	= "tcp_slow_start_after_idle", | ||||
| 		.data		= &sysctl_tcp_slow_start_after_idle, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -658,7 +521,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 	}, | ||||
| #ifdef CONFIG_NETLABEL | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CIPSOV4_CACHE_ENABLE, | ||||
| 		.procname	= "cipso_cache_enable", | ||||
| 		.data		= &cipso_v4_cache_enabled, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -666,7 +528,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CIPSOV4_CACHE_BUCKET_SIZE, | ||||
| 		.procname	= "cipso_cache_bucket_size", | ||||
| 		.data		= &cipso_v4_cache_bucketsize, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -674,7 +535,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CIPSOV4_RBM_OPTFMT, | ||||
| 		.procname	= "cipso_rbm_optfmt", | ||||
| 		.data		= &cipso_v4_rbm_optfmt, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -682,7 +542,6 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CIPSOV4_RBM_STRICTVALID, | ||||
| 		.procname	= "cipso_rbm_strictvalid", | ||||
| 		.data		= &cipso_v4_rbm_strictvalid, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -697,15 +556,12 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler   = proc_tcp_available_congestion_control, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_ALLOWED_CONG_CONTROL, | ||||
| 		.procname	= "tcp_allowed_congestion_control", | ||||
| 		.maxlen		= TCP_CA_BUF_MAX, | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler   = proc_allowed_congestion_control, | ||||
| 		.strategy	= strategy_allowed_congestion_control, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_TCP_MAX_SSTHRESH, | ||||
| 		.procname	= "tcp_max_ssthresh", | ||||
| 		.data		= &sysctl_tcp_max_ssthresh, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -713,41 +569,34 @@ static struct ctl_table ipv4_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "udp_mem", | ||||
| 		.data		= &sysctl_udp_mem, | ||||
| 		.maxlen		= sizeof(sysctl_udp_mem), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &zero | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "udp_rmem_min", | ||||
| 		.data		= &sysctl_udp_rmem_min, | ||||
| 		.maxlen		= sizeof(sysctl_udp_rmem_min), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &zero | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "udp_wmem_min", | ||||
| 		.data		= &sysctl_udp_wmem_min, | ||||
| 		.maxlen		= sizeof(sysctl_udp_wmem_min), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &zero | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_table ipv4_net_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ICMP_ECHO_IGNORE_ALL, | ||||
| 		.procname	= "icmp_echo_ignore_all", | ||||
| 		.data		= &init_net.ipv4.sysctl_icmp_echo_ignore_all, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -755,7 +604,6 @@ static struct ctl_table ipv4_net_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ICMP_ECHO_IGNORE_BROADCASTS, | ||||
| 		.procname	= "icmp_echo_ignore_broadcasts", | ||||
| 		.data		= &init_net.ipv4.sysctl_icmp_echo_ignore_broadcasts, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -763,7 +611,6 @@ static struct ctl_table ipv4_net_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ICMP_IGNORE_BOGUS_ERROR_RESPONSES, | ||||
| 		.procname	= "icmp_ignore_bogus_error_responses", | ||||
| 		.data		= &init_net.ipv4.sysctl_icmp_ignore_bogus_error_responses, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -771,7 +618,6 @@ static struct ctl_table ipv4_net_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ICMP_ERRORS_USE_INBOUND_IFADDR, | ||||
| 		.procname	= "icmp_errors_use_inbound_ifaddr", | ||||
| 		.data		= &init_net.ipv4.sysctl_icmp_errors_use_inbound_ifaddr, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -779,16 +625,13 @@ static struct ctl_table ipv4_net_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ICMP_RATELIMIT, | ||||
| 		.procname	= "icmp_ratelimit", | ||||
| 		.data		= &init_net.ipv4.sysctl_icmp_ratelimit, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_ms_jiffies, | ||||
| 		.strategy	= sysctl_ms_jiffies | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_ICMP_RATEMASK, | ||||
| 		.procname	= "icmp_ratemask", | ||||
| 		.data		= &init_net.ipv4.sysctl_icmp_ratemask, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -796,7 +639,6 @@ static struct ctl_table ipv4_net_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "rt_cache_rebuild_count", | ||||
| 		.data		= &init_net.ipv4.sysctl_rt_cache_rebuild_count, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -807,8 +649,8 @@ static struct ctl_table ipv4_net_table[] = { | |||
| }; | ||||
| 
 | ||||
| struct ctl_path net_ipv4_ctl_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "ipv4", .ctl_name = NET_IPV4, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "ipv4", }, | ||||
| 	{ }, | ||||
| }; | ||||
| EXPORT_SYMBOL_GPL(net_ipv4_ctl_path); | ||||
|  |  | |||
|  | @ -267,7 +267,6 @@ static struct xfrm_policy_afinfo xfrm4_policy_afinfo = { | |||
| #ifdef CONFIG_SYSCTL | ||||
| static struct ctl_table xfrm4_policy_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "xfrm4_gc_thresh", | ||||
| 		.data           = &xfrm4_dst_ops.gc_thresh, | ||||
| 		.maxlen         = sizeof(int), | ||||
|  |  | |||
|  | @ -4000,41 +4000,6 @@ int addrconf_sysctl_forward(ctl_table *ctl, int write, | |||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| static int addrconf_sysctl_forward_strategy(ctl_table *table, | ||||
| 					    void __user *oldval, | ||||
| 					    size_t __user *oldlenp, | ||||
| 					    void __user *newval, size_t newlen) | ||||
| { | ||||
| 	int *valp = table->data; | ||||
| 	int val = *valp; | ||||
| 	int new; | ||||
| 
 | ||||
| 	if (!newval || !newlen) | ||||
| 		return 0; | ||||
| 	if (newlen != sizeof(int)) | ||||
| 		return -EINVAL; | ||||
| 	if (get_user(new, (int __user *)newval)) | ||||
| 		return -EFAULT; | ||||
| 	if (new == *valp) | ||||
| 		return 0; | ||||
| 	if (oldval && oldlenp) { | ||||
| 		size_t len; | ||||
| 		if (get_user(len, oldlenp)) | ||||
| 			return -EFAULT; | ||||
| 		if (len) { | ||||
| 			if (len > table->maxlen) | ||||
| 				len = table->maxlen; | ||||
| 			if (copy_to_user(oldval, valp, len)) | ||||
| 				return -EFAULT; | ||||
| 			if (put_user(len, oldlenp)) | ||||
| 				return -EFAULT; | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	*valp = new; | ||||
| 	return addrconf_fixup_forwarding(table, valp, val); | ||||
| } | ||||
| 
 | ||||
| static void dev_disable_change(struct inet6_dev *idev) | ||||
| { | ||||
| 	if (!idev || !idev->dev) | ||||
|  | @ -4113,16 +4078,13 @@ static struct addrconf_sysctl_table | |||
| 	.sysctl_header = NULL, | ||||
| 	.addrconf_vars = { | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_FORWARDING, | ||||
| 			.procname	=	"forwarding", | ||||
| 			.data		=	&ipv6_devconf.forwarding, | ||||
| 			.maxlen		=	sizeof(int), | ||||
| 			.mode		=	0644, | ||||
| 			.proc_handler	=	addrconf_sysctl_forward, | ||||
| 			.strategy	=	addrconf_sysctl_forward_strategy, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_HOP_LIMIT, | ||||
| 			.procname	=	"hop_limit", | ||||
| 			.data		=	&ipv6_devconf.hop_limit, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4130,7 +4092,6 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_MTU, | ||||
| 			.procname	=	"mtu", | ||||
| 			.data		=	&ipv6_devconf.mtu6, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4138,7 +4099,6 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_ACCEPT_RA, | ||||
| 			.procname	=	"accept_ra", | ||||
| 			.data		=	&ipv6_devconf.accept_ra, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4146,7 +4106,6 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_ACCEPT_REDIRECTS, | ||||
| 			.procname	=	"accept_redirects", | ||||
| 			.data		=	&ipv6_devconf.accept_redirects, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4154,7 +4113,6 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_AUTOCONF, | ||||
| 			.procname	=	"autoconf", | ||||
| 			.data		=	&ipv6_devconf.autoconf, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4162,7 +4120,6 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_DAD_TRANSMITS, | ||||
| 			.procname	=	"dad_transmits", | ||||
| 			.data		=	&ipv6_devconf.dad_transmits, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4170,7 +4127,6 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_RTR_SOLICITS, | ||||
| 			.procname	=	"router_solicitations", | ||||
| 			.data		=	&ipv6_devconf.rtr_solicits, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4178,25 +4134,20 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_RTR_SOLICIT_INTERVAL, | ||||
| 			.procname	=	"router_solicitation_interval", | ||||
| 			.data		=	&ipv6_devconf.rtr_solicit_interval, | ||||
| 			.maxlen		=	sizeof(int), | ||||
| 			.mode		=	0644, | ||||
| 			.proc_handler	=	proc_dointvec_jiffies, | ||||
| 			.strategy	=	sysctl_jiffies, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_RTR_SOLICIT_DELAY, | ||||
| 			.procname	=	"router_solicitation_delay", | ||||
| 			.data		=	&ipv6_devconf.rtr_solicit_delay, | ||||
| 			.maxlen		=	sizeof(int), | ||||
| 			.mode		=	0644, | ||||
| 			.proc_handler	=	proc_dointvec_jiffies, | ||||
| 			.strategy	=	sysctl_jiffies, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_FORCE_MLD_VERSION, | ||||
| 			.procname	=	"force_mld_version", | ||||
| 			.data		=	&ipv6_devconf.force_mld_version, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4205,7 +4156,6 @@ static struct addrconf_sysctl_table | |||
| 		}, | ||||
| #ifdef CONFIG_IPV6_PRIVACY | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_USE_TEMPADDR, | ||||
| 			.procname	=	"use_tempaddr", | ||||
| 			.data		=	&ipv6_devconf.use_tempaddr, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4213,7 +4163,6 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_TEMP_VALID_LFT, | ||||
| 			.procname	=	"temp_valid_lft", | ||||
| 			.data		=	&ipv6_devconf.temp_valid_lft, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4221,7 +4170,6 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_TEMP_PREFERED_LFT, | ||||
| 			.procname	=	"temp_prefered_lft", | ||||
| 			.data		=	&ipv6_devconf.temp_prefered_lft, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4229,7 +4177,6 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_REGEN_MAX_RETRY, | ||||
| 			.procname	=	"regen_max_retry", | ||||
| 			.data		=	&ipv6_devconf.regen_max_retry, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4237,7 +4184,6 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_MAX_DESYNC_FACTOR, | ||||
| 			.procname	=	"max_desync_factor", | ||||
| 			.data		=	&ipv6_devconf.max_desync_factor, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4246,7 +4192,6 @@ static struct addrconf_sysctl_table | |||
| 		}, | ||||
| #endif | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_MAX_ADDRESSES, | ||||
| 			.procname	=	"max_addresses", | ||||
| 			.data		=	&ipv6_devconf.max_addresses, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4254,7 +4199,6 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_ACCEPT_RA_DEFRTR, | ||||
| 			.procname	=	"accept_ra_defrtr", | ||||
| 			.data		=	&ipv6_devconf.accept_ra_defrtr, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4262,7 +4206,6 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_ACCEPT_RA_PINFO, | ||||
| 			.procname	=	"accept_ra_pinfo", | ||||
| 			.data		=	&ipv6_devconf.accept_ra_pinfo, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4271,7 +4214,6 @@ static struct addrconf_sysctl_table | |||
| 		}, | ||||
| #ifdef CONFIG_IPV6_ROUTER_PREF | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_ACCEPT_RA_RTR_PREF, | ||||
| 			.procname	=	"accept_ra_rtr_pref", | ||||
| 			.data		=	&ipv6_devconf.accept_ra_rtr_pref, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4279,17 +4221,14 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_RTR_PROBE_INTERVAL, | ||||
| 			.procname	=	"router_probe_interval", | ||||
| 			.data		=	&ipv6_devconf.rtr_probe_interval, | ||||
| 			.maxlen		=	sizeof(int), | ||||
| 			.mode		=	0644, | ||||
| 			.proc_handler	=	proc_dointvec_jiffies, | ||||
| 			.strategy	=	sysctl_jiffies, | ||||
| 		}, | ||||
| #ifdef CONFIG_IPV6_ROUTE_INFO | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_ACCEPT_RA_RT_INFO_MAX_PLEN, | ||||
| 			.procname	=	"accept_ra_rt_info_max_plen", | ||||
| 			.data		=	&ipv6_devconf.accept_ra_rt_info_max_plen, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4299,7 +4238,6 @@ static struct addrconf_sysctl_table | |||
| #endif | ||||
| #endif | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_PROXY_NDP, | ||||
| 			.procname	=	"proxy_ndp", | ||||
| 			.data		=	&ipv6_devconf.proxy_ndp, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4307,7 +4245,6 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	NET_IPV6_ACCEPT_SOURCE_ROUTE, | ||||
| 			.procname	=	"accept_source_route", | ||||
| 			.data		=	&ipv6_devconf.accept_source_route, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4316,7 +4253,6 @@ static struct addrconf_sysctl_table | |||
| 		}, | ||||
| #ifdef CONFIG_IPV6_OPTIMISTIC_DAD | ||||
| 		{ | ||||
| 			.ctl_name	=	CTL_UNNUMBERED, | ||||
| 			.procname       =       "optimistic_dad", | ||||
| 			.data           =       &ipv6_devconf.optimistic_dad, | ||||
| 			.maxlen         =       sizeof(int), | ||||
|  | @ -4327,7 +4263,6 @@ static struct addrconf_sysctl_table | |||
| #endif | ||||
| #ifdef CONFIG_IPV6_MROUTE | ||||
| 		{ | ||||
| 			.ctl_name	=	CTL_UNNUMBERED, | ||||
| 			.procname	=	"mc_forwarding", | ||||
| 			.data		=	&ipv6_devconf.mc_forwarding, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4336,16 +4271,13 @@ static struct addrconf_sysctl_table | |||
| 		}, | ||||
| #endif | ||||
| 		{ | ||||
| 			.ctl_name	=	CTL_UNNUMBERED, | ||||
| 			.procname	=	"disable_ipv6", | ||||
| 			.data		=	&ipv6_devconf.disable_ipv6, | ||||
| 			.maxlen		=	sizeof(int), | ||||
| 			.mode		=	0644, | ||||
| 			.proc_handler	=	addrconf_sysctl_disable, | ||||
| 			.strategy	=	sysctl_intvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	CTL_UNNUMBERED, | ||||
| 			.procname	=	"accept_dad", | ||||
| 			.data		=	&ipv6_devconf.accept_dad, | ||||
| 			.maxlen		=	sizeof(int), | ||||
|  | @ -4353,13 +4285,13 @@ static struct addrconf_sysctl_table | |||
| 			.proc_handler	=	proc_dointvec, | ||||
| 		}, | ||||
| 		{ | ||||
| 			.ctl_name	=	0,	/* sentinel */ | ||||
| 			/* sentinel */ | ||||
| 		} | ||||
| 	}, | ||||
| }; | ||||
| 
 | ||||
| static int __addrconf_sysctl_register(struct net *net, char *dev_name, | ||||
| 		int ctl_name, struct inet6_dev *idev, struct ipv6_devconf *p) | ||||
| 		struct inet6_dev *idev, struct ipv6_devconf *p) | ||||
| { | ||||
| 	int i; | ||||
| 	struct addrconf_sysctl_table *t; | ||||
|  | @ -4367,9 +4299,9 @@ static int __addrconf_sysctl_register(struct net *net, char *dev_name, | |||
| #define ADDRCONF_CTL_PATH_DEV	3 | ||||
| 
 | ||||
| 	struct ctl_path addrconf_ctl_path[] = { | ||||
| 		{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 		{ .procname = "ipv6", .ctl_name = NET_IPV6, }, | ||||
| 		{ .procname = "conf", .ctl_name = NET_IPV6_CONF, }, | ||||
| 		{ .procname = "net", }, | ||||
| 		{ .procname = "ipv6", }, | ||||
| 		{ .procname = "conf", }, | ||||
| 		{ /* to be set */ }, | ||||
| 		{ }, | ||||
| 	}; | ||||
|  | @ -4395,7 +4327,6 @@ static int __addrconf_sysctl_register(struct net *net, char *dev_name, | |||
| 		goto free; | ||||
| 
 | ||||
| 	addrconf_ctl_path[ADDRCONF_CTL_PATH_DEV].procname = t->dev_name; | ||||
| 	addrconf_ctl_path[ADDRCONF_CTL_PATH_DEV].ctl_name = ctl_name; | ||||
| 
 | ||||
| 	t->sysctl_header = register_net_sysctl_table(net, addrconf_ctl_path, | ||||
| 			t->addrconf_vars); | ||||
|  | @ -4431,10 +4362,9 @@ static void addrconf_sysctl_register(struct inet6_dev *idev) | |||
| { | ||||
| 	neigh_sysctl_register(idev->dev, idev->nd_parms, NET_IPV6, | ||||
| 			      NET_IPV6_NEIGH, "ipv6", | ||||
| 			      &ndisc_ifinfo_sysctl_change, | ||||
| 			      ndisc_ifinfo_sysctl_strategy); | ||||
| 			      &ndisc_ifinfo_sysctl_change); | ||||
| 	__addrconf_sysctl_register(dev_net(idev->dev), idev->dev->name, | ||||
| 			idev->dev->ifindex, idev, &idev->cnf); | ||||
| 					idev, &idev->cnf); | ||||
| } | ||||
| 
 | ||||
| static void addrconf_sysctl_unregister(struct inet6_dev *idev) | ||||
|  | @ -4473,13 +4403,11 @@ static int addrconf_init_net(struct net *net) | |||
| 	net->ipv6.devconf_dflt = dflt; | ||||
| 
 | ||||
| #ifdef CONFIG_SYSCTL | ||||
| 	err = __addrconf_sysctl_register(net, "all", NET_PROTO_CONF_ALL, | ||||
| 			NULL, all); | ||||
| 	err = __addrconf_sysctl_register(net, "all", NULL, all); | ||||
| 	if (err < 0) | ||||
| 		goto err_reg_all; | ||||
| 
 | ||||
| 	err = __addrconf_sysctl_register(net, "default", NET_PROTO_CONF_DEFAULT, | ||||
| 			NULL, dflt); | ||||
| 	err = __addrconf_sysctl_register(net, "default", NULL, dflt); | ||||
| 	if (err < 0) | ||||
| 		goto err_reg_dflt; | ||||
| #endif | ||||
|  |  | |||
|  | @ -942,15 +942,13 @@ EXPORT_SYMBOL(icmpv6_err_convert); | |||
| #ifdef CONFIG_SYSCTL | ||||
| ctl_table ipv6_icmp_table_template[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV6_ICMP_RATELIMIT, | ||||
| 		.procname	= "ratelimit", | ||||
| 		.data		= &init_net.ipv6.sysctl.icmpv6_time, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_ms_jiffies, | ||||
| 		.strategy	= sysctl_ms_jiffies | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| struct ctl_table *ipv6_icmp_sysctl_init(struct net *net) | ||||
|  |  | |||
|  | @ -1768,42 +1768,6 @@ int ndisc_ifinfo_sysctl_change(struct ctl_table *ctl, int write, void __user *bu | |||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| int ndisc_ifinfo_sysctl_strategy(ctl_table *ctl, | ||||
| 				 void __user *oldval, size_t __user *oldlenp, | ||||
| 				 void __user *newval, size_t newlen) | ||||
| { | ||||
| 	struct net_device *dev = ctl->extra1; | ||||
| 	struct inet6_dev *idev; | ||||
| 	int ret; | ||||
| 
 | ||||
| 	if (ctl->ctl_name == NET_NEIGH_RETRANS_TIME || | ||||
| 	    ctl->ctl_name == NET_NEIGH_REACHABLE_TIME) | ||||
| 		ndisc_warn_deprecated_sysctl(ctl, "procfs", dev ? dev->name : "default"); | ||||
| 
 | ||||
| 	switch (ctl->ctl_name) { | ||||
| 	case NET_NEIGH_REACHABLE_TIME: | ||||
| 		ret = sysctl_jiffies(ctl, oldval, oldlenp, newval, newlen); | ||||
| 		break; | ||||
| 	case NET_NEIGH_RETRANS_TIME_MS: | ||||
| 	case NET_NEIGH_REACHABLE_TIME_MS: | ||||
| 		 ret = sysctl_ms_jiffies(ctl, oldval, oldlenp, newval, newlen); | ||||
| 		 break; | ||||
| 	default: | ||||
| 		ret = 0; | ||||
| 	} | ||||
| 
 | ||||
| 	if (newval && newlen && ret > 0 && | ||||
| 	    dev && (idev = in6_dev_get(dev)) != NULL) { | ||||
| 		if (ctl->ctl_name == NET_NEIGH_REACHABLE_TIME || | ||||
| 		    ctl->ctl_name == NET_NEIGH_REACHABLE_TIME_MS) | ||||
| 			idev->nd_parms->reachable_time = neigh_rand_reach_time(idev->nd_parms->base_reachable_time); | ||||
| 		idev->tstamp = jiffies; | ||||
| 		inet6_ifinfo_notify(RTM_NEWLINK, idev); | ||||
| 		in6_dev_put(idev); | ||||
| 	} | ||||
| 
 | ||||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
|  | @ -1857,8 +1821,7 @@ int __init ndisc_init(void) | |||
| #ifdef CONFIG_SYSCTL | ||||
| 	err = neigh_sysctl_register(NULL, &nd_tbl.parms, NET_IPV6, | ||||
| 				    NET_IPV6_NEIGH, "ipv6", | ||||
| 				    &ndisc_ifinfo_sysctl_change, | ||||
| 				    &ndisc_ifinfo_sysctl_strategy); | ||||
| 				    &ndisc_ifinfo_sysctl_change); | ||||
| 	if (err) | ||||
| 		goto out_unregister_pernet; | ||||
| #endif | ||||
|  |  | |||
|  | @ -36,7 +36,6 @@ | |||
| 
 | ||||
| #define IPQ_QMAX_DEFAULT 1024 | ||||
| #define IPQ_PROC_FS_NAME "ip6_queue" | ||||
| #define NET_IPQ_QMAX 2088 | ||||
| #define NET_IPQ_QMAX_NAME "ip6_queue_maxlen" | ||||
| 
 | ||||
| typedef int (*ipq_cmpfn)(struct nf_queue_entry *, unsigned long); | ||||
|  | @ -518,14 +517,13 @@ static struct ctl_table_header *ipq_sysctl_header; | |||
| 
 | ||||
| static ctl_table ipq_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPQ_QMAX, | ||||
| 		.procname	= NET_IPQ_QMAX_NAME, | ||||
| 		.data		= &queue_maxlen, | ||||
| 		.maxlen		= sizeof(queue_maxlen), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| #endif | ||||
| 
 | ||||
|  |  | |||
|  | @ -277,9 +277,7 @@ static struct ctl_table icmpv6_sysctl_table[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= 0 | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| #endif /* CONFIG_SYSCTL */ | ||||
| 
 | ||||
|  |  | |||
|  | @ -83,7 +83,6 @@ struct ctl_table nf_ct_ipv6_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NF_CONNTRACK_FRAG6_LOW_THRESH, | ||||
| 		.procname	= "nf_conntrack_frag6_low_thresh", | ||||
| 		.data		= &nf_init_frags.low_thresh, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
|  | @ -91,14 +90,13 @@ struct ctl_table nf_ct_ipv6_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NF_CONNTRACK_FRAG6_HIGH_THRESH, | ||||
| 		.procname	= "nf_conntrack_frag6_high_thresh", | ||||
| 		.data		= &nf_init_frags.high_thresh, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| #endif | ||||
| 
 | ||||
|  |  | |||
|  | @ -636,7 +636,6 @@ static const struct inet6_protocol frag_protocol = | |||
| #ifdef CONFIG_SYSCTL | ||||
| static struct ctl_table ip6_frags_ns_ctl_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV6_IP6FRAG_HIGH_THRESH, | ||||
| 		.procname	= "ip6frag_high_thresh", | ||||
| 		.data		= &init_net.ipv6.frags.high_thresh, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -644,7 +643,6 @@ static struct ctl_table ip6_frags_ns_ctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV6_IP6FRAG_LOW_THRESH, | ||||
| 		.procname	= "ip6frag_low_thresh", | ||||
| 		.data		= &init_net.ipv6.frags.low_thresh, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -652,26 +650,22 @@ static struct ctl_table ip6_frags_ns_ctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV6_IP6FRAG_TIME, | ||||
| 		.procname	= "ip6frag_time", | ||||
| 		.data		= &init_net.ipv6.frags.timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_table ip6_frags_ctl_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV6_IP6FRAG_SECRET_INTERVAL, | ||||
| 		.procname	= "ip6frag_secret_interval", | ||||
| 		.data		= &ip6_frags.secret_interval, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies | ||||
| 	}, | ||||
| 	{ } | ||||
| }; | ||||
|  |  | |||
|  | @ -2546,7 +2546,6 @@ ctl_table ipv6_route_table_template[] = { | |||
| 		.proc_handler	=	ipv6_sysctl_rtcache_flush | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	=	NET_IPV6_ROUTE_GC_THRESH, | ||||
| 		.procname	=	"gc_thresh", | ||||
| 		.data		=	&ip6_dst_ops_template.gc_thresh, | ||||
| 		.maxlen		=	sizeof(int), | ||||
|  | @ -2554,7 +2553,6 @@ ctl_table ipv6_route_table_template[] = { | |||
| 		.proc_handler	=	proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	=	NET_IPV6_ROUTE_MAX_SIZE, | ||||
| 		.procname	=	"max_size", | ||||
| 		.data		=	&init_net.ipv6.sysctl.ip6_rt_max_size, | ||||
| 		.maxlen		=	sizeof(int), | ||||
|  | @ -2562,69 +2560,55 @@ ctl_table ipv6_route_table_template[] = { | |||
| 		.proc_handler	=	proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	=	NET_IPV6_ROUTE_GC_MIN_INTERVAL, | ||||
| 		.procname	=	"gc_min_interval", | ||||
| 		.data		=	&init_net.ipv6.sysctl.ip6_rt_gc_min_interval, | ||||
| 		.maxlen		=	sizeof(int), | ||||
| 		.mode		=	0644, | ||||
| 		.proc_handler	=	proc_dointvec_jiffies, | ||||
| 		.strategy	=	sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	=	NET_IPV6_ROUTE_GC_TIMEOUT, | ||||
| 		.procname	=	"gc_timeout", | ||||
| 		.data		=	&init_net.ipv6.sysctl.ip6_rt_gc_timeout, | ||||
| 		.maxlen		=	sizeof(int), | ||||
| 		.mode		=	0644, | ||||
| 		.proc_handler	=	proc_dointvec_jiffies, | ||||
| 		.strategy	=	sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	=	NET_IPV6_ROUTE_GC_INTERVAL, | ||||
| 		.procname	=	"gc_interval", | ||||
| 		.data		=	&init_net.ipv6.sysctl.ip6_rt_gc_interval, | ||||
| 		.maxlen		=	sizeof(int), | ||||
| 		.mode		=	0644, | ||||
| 		.proc_handler	=	proc_dointvec_jiffies, | ||||
| 		.strategy	=	sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	=	NET_IPV6_ROUTE_GC_ELASTICITY, | ||||
| 		.procname	=	"gc_elasticity", | ||||
| 		.data		=	&init_net.ipv6.sysctl.ip6_rt_gc_elasticity, | ||||
| 		.maxlen		=	sizeof(int), | ||||
| 		.mode		=	0644, | ||||
| 		.proc_handler	=	proc_dointvec_jiffies, | ||||
| 		.strategy	=	sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	=	NET_IPV6_ROUTE_MTU_EXPIRES, | ||||
| 		.procname	=	"mtu_expires", | ||||
| 		.data		=	&init_net.ipv6.sysctl.ip6_rt_mtu_expires, | ||||
| 		.maxlen		=	sizeof(int), | ||||
| 		.mode		=	0644, | ||||
| 		.proc_handler	=	proc_dointvec_jiffies, | ||||
| 		.strategy	=	sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	=	NET_IPV6_ROUTE_MIN_ADVMSS, | ||||
| 		.procname	=	"min_adv_mss", | ||||
| 		.data		=	&init_net.ipv6.sysctl.ip6_rt_min_advmss, | ||||
| 		.maxlen		=	sizeof(int), | ||||
| 		.mode		=	0644, | ||||
| 		.proc_handler	=	proc_dointvec_jiffies, | ||||
| 		.strategy	=	sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	=	NET_IPV6_ROUTE_GC_MIN_INTERVAL_MS, | ||||
| 		.procname	=	"gc_min_interval_ms", | ||||
| 		.data		=	&init_net.ipv6.sysctl.ip6_rt_gc_min_interval, | ||||
| 		.maxlen		=	sizeof(int), | ||||
| 		.mode		=	0644, | ||||
| 		.proc_handler	=	proc_dointvec_ms_jiffies, | ||||
| 		.strategy	=	sysctl_ms_jiffies, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| struct ctl_table *ipv6_route_sysctl_init(struct net *net) | ||||
|  |  | |||
|  | @ -16,45 +16,41 @@ | |||
| 
 | ||||
| static ctl_table ipv6_table_template[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV6_ROUTE, | ||||
| 		.procname	= "route", | ||||
| 		.maxlen		= 0, | ||||
| 		.mode		= 0555, | ||||
| 		.child		= ipv6_route_table_template | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV6_ICMP, | ||||
| 		.procname	= "icmp", | ||||
| 		.maxlen		= 0, | ||||
| 		.mode		= 0555, | ||||
| 		.child		= ipv6_icmp_table_template | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV6_BINDV6ONLY, | ||||
| 		.procname	= "bindv6only", | ||||
| 		.data		= &init_net.ipv6.sysctl.bindv6only, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static ctl_table ipv6_rotable[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV6_MLD_MAX_MSF, | ||||
| 		.procname	= "mld_max_msf", | ||||
| 		.data		= &sysctl_mld_max_msf, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| struct ctl_path net_ipv6_ctl_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "ipv6", .ctl_name = NET_IPV6, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "ipv6", }, | ||||
| 	{ }, | ||||
| }; | ||||
| EXPORT_SYMBOL_GPL(net_ipv6_ctl_path); | ||||
|  |  | |||
|  | @ -309,7 +309,6 @@ static void xfrm6_policy_fini(void) | |||
| #ifdef CONFIG_SYSCTL | ||||
| static struct ctl_table xfrm6_policy_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "xfrm6_gc_thresh", | ||||
| 		.data	   	= &xfrm6_dst_ops.gc_thresh, | ||||
| 		.maxlen	 	= sizeof(int), | ||||
|  |  | |||
|  | @ -18,19 +18,18 @@ extern int sysctl_ipx_pprop_broadcasting; | |||
| 
 | ||||
| static struct ctl_table ipx_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPX_PPROP_BROADCASTING, | ||||
| 		.procname	= "ipx_pprop_broadcasting", | ||||
| 		.data		= &sysctl_ipx_pprop_broadcasting, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ 0 }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path ipx_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "ipx", .ctl_name = NET_IPX, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "ipx", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -113,26 +113,21 @@ static int do_discovery(ctl_table *table, int write, | |||
| /* One file */ | ||||
| static ctl_table irda_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_DISCOVERY, | ||||
| 		.procname	= "discovery", | ||||
| 		.data		= &sysctl_discovery, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= do_discovery, | ||||
| 		.strategy       = sysctl_intvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_DEVNAME, | ||||
| 		.procname	= "devname", | ||||
| 		.data		= sysctl_devname, | ||||
| 		.maxlen		= 65, | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= do_devname, | ||||
| 		.strategy	= sysctl_string | ||||
| 	}, | ||||
| #ifdef CONFIG_IRDA_DEBUG | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_DEBUG, | ||||
| 		.procname	= "debug", | ||||
| 		.data		= &irda_debug, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -142,7 +137,6 @@ static ctl_table irda_table[] = { | |||
| #endif | ||||
| #ifdef CONFIG_IRDA_FAST_RR | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_FAST_POLL, | ||||
| 		.procname	= "fast_poll_increase", | ||||
| 		.data		= &sysctl_fast_poll_increase, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -151,18 +145,15 @@ static ctl_table irda_table[] = { | |||
| 	}, | ||||
| #endif | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_DISCOVERY_SLOTS, | ||||
| 		.procname	= "discovery_slots", | ||||
| 		.data		= &sysctl_discovery_slots, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_discovery_slots, | ||||
| 		.extra2		= &max_discovery_slots | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_DISCOVERY_TIMEOUT, | ||||
| 		.procname	= "discovery_timeout", | ||||
| 		.data		= &sysctl_discovery_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -170,99 +161,83 @@ static ctl_table irda_table[] = { | |||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_SLOT_TIMEOUT, | ||||
| 		.procname	= "slot_timeout", | ||||
| 		.data		= &sysctl_slot_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_slot_timeout, | ||||
| 		.extra2		= &max_slot_timeout | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_MAX_BAUD_RATE, | ||||
| 		.procname	= "max_baud_rate", | ||||
| 		.data		= &sysctl_max_baud_rate, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_max_baud_rate, | ||||
| 		.extra2		= &max_max_baud_rate | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_MIN_TX_TURN_TIME, | ||||
| 		.procname	= "min_tx_turn_time", | ||||
| 		.data		= &sysctl_min_tx_turn_time, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_min_tx_turn_time, | ||||
| 		.extra2		= &max_min_tx_turn_time | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_MAX_TX_DATA_SIZE, | ||||
| 		.procname	= "max_tx_data_size", | ||||
| 		.data		= &sysctl_max_tx_data_size, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_max_tx_data_size, | ||||
| 		.extra2		= &max_max_tx_data_size | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_MAX_TX_WINDOW, | ||||
| 		.procname	= "max_tx_window", | ||||
| 		.data		= &sysctl_max_tx_window, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_max_tx_window, | ||||
| 		.extra2		= &max_max_tx_window | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_MAX_NOREPLY_TIME, | ||||
| 		.procname	= "max_noreply_time", | ||||
| 		.data		= &sysctl_max_noreply_time, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_max_noreply_time, | ||||
| 		.extra2		= &max_max_noreply_time | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_WARN_NOREPLY_TIME, | ||||
| 		.procname	= "warn_noreply_time", | ||||
| 		.data		= &sysctl_warn_noreply_time, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_warn_noreply_time, | ||||
| 		.extra2		= &max_warn_noreply_time | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IRDA_LAP_KEEPALIVE_TIME, | ||||
| 		.procname	= "lap_keepalive_time", | ||||
| 		.data		= &sysctl_lap_keepalive_time, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_lap_keepalive_time, | ||||
| 		.extra2		= &max_lap_keepalive_time | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path irda_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "irda", .ctl_name = NET_IRDA, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "irda", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -15,86 +15,73 @@ | |||
| 
 | ||||
| static struct ctl_table llc2_timeout_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_LLC2_ACK_TIMEOUT, | ||||
| 		.procname	= "ack", | ||||
| 		.data		= &sysctl_llc2_ack_timeout, | ||||
| 		.maxlen		= sizeof(long), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler   = proc_dointvec_jiffies, | ||||
| 		.strategy       = sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_LLC2_BUSY_TIMEOUT, | ||||
| 		.procname	= "busy", | ||||
| 		.data		= &sysctl_llc2_busy_timeout, | ||||
| 		.maxlen		= sizeof(long), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler   = proc_dointvec_jiffies, | ||||
| 		.strategy       = sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_LLC2_P_TIMEOUT, | ||||
| 		.procname	= "p", | ||||
| 		.data		= &sysctl_llc2_p_timeout, | ||||
| 		.maxlen		= sizeof(long), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler   = proc_dointvec_jiffies, | ||||
| 		.strategy       = sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_LLC2_REJ_TIMEOUT, | ||||
| 		.procname	= "rej", | ||||
| 		.data		= &sysctl_llc2_rej_timeout, | ||||
| 		.maxlen		= sizeof(long), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler   = proc_dointvec_jiffies, | ||||
| 		.strategy       = sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ 0 }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_table llc_station_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_LLC_STATION_ACK_TIMEOUT, | ||||
| 		.procname	= "ack_timeout", | ||||
| 		.data		= &sysctl_llc_station_ack_timeout, | ||||
| 		.maxlen		= sizeof(long), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler   = proc_dointvec_jiffies, | ||||
| 		.strategy       = sysctl_jiffies, | ||||
| 	}, | ||||
| 	{ 0 }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_table llc2_dir_timeout_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_LLC2, | ||||
| 		.procname	= "timeout", | ||||
| 		.mode		= 0555, | ||||
| 		.child		= llc2_timeout_table, | ||||
| 	}, | ||||
| 	{ 0 }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_table llc_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_LLC2, | ||||
| 		.procname	= "llc2", | ||||
| 		.mode		= 0555, | ||||
| 		.child		= llc2_dir_timeout_table, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = NET_LLC_STATION, | ||||
| 		.procname       = "station", | ||||
| 		.mode           = 0555, | ||||
| 		.child          = llc_station_table, | ||||
| 	}, | ||||
| 	{ 0 }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path llc_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "llc", .ctl_name = NET_LLC, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "llc", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -273,8 +273,8 @@ void __init netfilter_init(void) | |||
| 
 | ||||
| #ifdef CONFIG_SYSCTL | ||||
| struct ctl_path nf_net_netfilter_sysctl_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "netfilter", .ctl_name = NET_NETFILTER, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "netfilter", }, | ||||
| 	{ } | ||||
| }; | ||||
| EXPORT_SYMBOL_GPL(nf_net_netfilter_sysctl_path); | ||||
|  |  | |||
|  | @ -1706,12 +1706,12 @@ static struct ctl_table vs_vars[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| const struct ctl_path net_vs_ctl_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "ipv4", .ctl_name = NET_IPV4, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "ipv4", }, | ||||
| 	{ .procname = "vs", }, | ||||
| 	{ } | ||||
| }; | ||||
|  |  | |||
|  | @ -121,7 +121,7 @@ static ctl_table vs_vars_table[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_table_header * sysctl_header; | ||||
|  |  | |||
|  | @ -302,7 +302,7 @@ static ctl_table vs_vars_table[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_table_header * sysctl_header; | ||||
|  |  | |||
|  | @ -30,7 +30,6 @@ MODULE_PARM_DESC(acct, "Enable connection tracking flow accounting."); | |||
| #ifdef CONFIG_SYSCTL | ||||
| static struct ctl_table acct_sysctl_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_acct", | ||||
| 		.data		= &init_net.ct.sysctl_acct, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
|  |  | |||
|  | @ -151,7 +151,6 @@ static int nf_ct_events_retry_timeout __read_mostly = 15*HZ; | |||
| #ifdef CONFIG_SYSCTL | ||||
| static struct ctl_table event_sysctl_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_events", | ||||
| 		.data		= &init_net.ct.sysctl_events, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
|  | @ -159,7 +158,6 @@ static struct ctl_table event_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_events_retry_timeout", | ||||
| 		.data		= &init_net.ct.sysctl_events_retry_timeout, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
|  |  | |||
|  | @ -703,64 +703,54 @@ static int dccp_nlattr_size(void) | |||
| /* template, data assigned later */ | ||||
| static struct ctl_table dccp_sysctl_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_dccp_timeout_request", | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_dccp_timeout_respond", | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_dccp_timeout_partopen", | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_dccp_timeout_open", | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_dccp_timeout_closereq", | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_dccp_timeout_closing", | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_dccp_timeout_timewait", | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_dccp_loose", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= 0, | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| #endif /* CONFIG_SYSCTL */ | ||||
| 
 | ||||
|  |  | |||
|  | @ -69,9 +69,7 @@ static struct ctl_table generic_sysctl_table[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= 0 | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| #ifdef CONFIG_NF_CONNTRACK_PROC_COMPAT | ||||
| static struct ctl_table generic_compat_sysctl_table[] = { | ||||
|  | @ -82,9 +80,7 @@ static struct ctl_table generic_compat_sysctl_table[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= 0 | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| #endif /* CONFIG_NF_CONNTRACK_PROC_COMPAT */ | ||||
| #endif /* CONFIG_SYSCTL */ | ||||
|  |  | |||
|  | @ -595,9 +595,7 @@ static struct ctl_table sctp_sysctl_table[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = 0 | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| #ifdef CONFIG_NF_CONNTRACK_PROC_COMPAT | ||||
|  | @ -651,9 +649,7 @@ static struct ctl_table sctp_compat_sysctl_table[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = 0 | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| #endif /* CONFIG_NF_CONNTRACK_PROC_COMPAT */ | ||||
| #endif | ||||
|  |  | |||
|  | @ -1303,7 +1303,6 @@ static struct ctl_table tcp_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NF_CONNTRACK_TCP_LOOSE, | ||||
| 		.procname	= "nf_conntrack_tcp_loose", | ||||
| 		.data		= &nf_ct_tcp_loose, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
|  | @ -1311,7 +1310,6 @@ static struct ctl_table tcp_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NF_CONNTRACK_TCP_BE_LIBERAL, | ||||
| 		.procname       = "nf_conntrack_tcp_be_liberal", | ||||
| 		.data           = &nf_ct_tcp_be_liberal, | ||||
| 		.maxlen         = sizeof(unsigned int), | ||||
|  | @ -1319,16 +1317,13 @@ static struct ctl_table tcp_sysctl_table[] = { | |||
| 		.proc_handler   = proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NF_CONNTRACK_TCP_MAX_RETRANS, | ||||
| 		.procname	= "nf_conntrack_tcp_max_retrans", | ||||
| 		.data		= &nf_ct_tcp_max_retrans, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= 0 | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| #ifdef CONFIG_NF_CONNTRACK_PROC_COMPAT | ||||
|  | @ -1404,7 +1399,6 @@ static struct ctl_table tcp_compat_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_NF_CONNTRACK_TCP_LOOSE, | ||||
| 		.procname	= "ip_conntrack_tcp_loose", | ||||
| 		.data		= &nf_ct_tcp_loose, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
|  | @ -1412,7 +1406,6 @@ static struct ctl_table tcp_compat_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_NF_CONNTRACK_TCP_BE_LIBERAL, | ||||
| 		.procname	= "ip_conntrack_tcp_be_liberal", | ||||
| 		.data		= &nf_ct_tcp_be_liberal, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
|  | @ -1420,16 +1413,13 @@ static struct ctl_table tcp_compat_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_IPV4_NF_CONNTRACK_TCP_MAX_RETRANS, | ||||
| 		.procname	= "ip_conntrack_tcp_max_retrans", | ||||
| 		.data		= &nf_ct_tcp_max_retrans, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= 0 | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| #endif /* CONFIG_NF_CONNTRACK_PROC_COMPAT */ | ||||
| #endif /* CONFIG_SYSCTL */ | ||||
|  |  | |||
|  | @ -154,9 +154,7 @@ static struct ctl_table udp_sysctl_table[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= 0 | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| #ifdef CONFIG_NF_CONNTRACK_PROC_COMPAT | ||||
| static struct ctl_table udp_compat_sysctl_table[] = { | ||||
|  | @ -174,9 +172,7 @@ static struct ctl_table udp_compat_sysctl_table[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= 0 | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| #endif /* CONFIG_NF_CONNTRACK_PROC_COMPAT */ | ||||
| #endif /* CONFIG_SYSCTL */ | ||||
|  |  | |||
|  | @ -146,7 +146,6 @@ static unsigned int udplite_sysctl_table_users; | |||
| static struct ctl_table_header *udplite_sysctl_header; | ||||
| static struct ctl_table udplite_sysctl_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_udplite_timeout", | ||||
| 		.data		= &nf_ct_udplite_timeout, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
|  | @ -154,16 +153,13 @@ static struct ctl_table udplite_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_udplite_timeout_stream", | ||||
| 		.data		= &nf_ct_udplite_timeout_stream, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= 0 | ||||
| 	} | ||||
| 	{ } | ||||
| }; | ||||
| #endif /* CONFIG_SYSCTL */ | ||||
| 
 | ||||
|  |  | |||
|  | @ -340,7 +340,6 @@ static struct ctl_table_header *nf_ct_netfilter_header; | |||
| 
 | ||||
| static ctl_table nf_ct_sysctl_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NF_CONNTRACK_MAX, | ||||
| 		.procname	= "nf_conntrack_max", | ||||
| 		.data		= &nf_conntrack_max, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -348,7 +347,6 @@ static ctl_table nf_ct_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NF_CONNTRACK_COUNT, | ||||
| 		.procname	= "nf_conntrack_count", | ||||
| 		.data		= &init_net.ct.count, | ||||
| 		.maxlen		= sizeof(int), | ||||
|  | @ -356,7 +354,6 @@ static ctl_table nf_ct_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = NET_NF_CONNTRACK_BUCKETS, | ||||
| 		.procname       = "nf_conntrack_buckets", | ||||
| 		.data           = &nf_conntrack_htable_size, | ||||
| 		.maxlen         = sizeof(unsigned int), | ||||
|  | @ -364,7 +361,6 @@ static ctl_table nf_ct_sysctl_table[] = { | |||
| 		.proc_handler   = proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NF_CONNTRACK_CHECKSUM, | ||||
| 		.procname	= "nf_conntrack_checksum", | ||||
| 		.data		= &init_net.ct.sysctl_checksum, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
|  | @ -372,43 +368,39 @@ static ctl_table nf_ct_sysctl_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NF_CONNTRACK_LOG_INVALID, | ||||
| 		.procname	= "nf_conntrack_log_invalid", | ||||
| 		.data		= &init_net.ct.sysctl_log_invalid, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &log_invalid_proto_min, | ||||
| 		.extra2		= &log_invalid_proto_max, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "nf_conntrack_expect_max", | ||||
| 		.data		= &nf_ct_expect_max, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| #define NET_NF_CONNTRACK_MAX 2089 | ||||
| 
 | ||||
| static ctl_table nf_ct_netfilter_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NF_CONNTRACK_MAX, | ||||
| 		.procname	= "nf_conntrack_max", | ||||
| 		.data		= &nf_conntrack_max, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path nf_ct_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -216,9 +216,9 @@ static const struct file_operations nflog_file_ops = { | |||
| 
 | ||||
| #ifdef CONFIG_SYSCTL | ||||
| static struct ctl_path nf_log_sysctl_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "netfilter", .ctl_name = NET_NETFILTER, }, | ||||
| 	{ .procname = "nf_log", .ctl_name = CTL_UNNUMBERED, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "netfilter", }, | ||||
| 	{ .procname = "nf_log", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  | @ -273,7 +273,6 @@ static __init int netfilter_log_sysctl_init(void) | |||
| 
 | ||||
| 	for (i = NFPROTO_UNSPEC; i < NFPROTO_NUMPROTO; i++) { | ||||
| 		snprintf(nf_log_sysctl_fnames[i-NFPROTO_UNSPEC], 3, "%d", i); | ||||
| 		nf_log_sysctl_table[i].ctl_name	= CTL_UNNUMBERED; | ||||
| 		nf_log_sysctl_table[i].procname	= | ||||
| 			nf_log_sysctl_fnames[i-NFPROTO_UNSPEC]; | ||||
| 		nf_log_sysctl_table[i].data = NULL; | ||||
|  |  | |||
|  | @ -36,143 +36,119 @@ static struct ctl_table_header *nr_table_header; | |||
| 
 | ||||
| static ctl_table nr_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NETROM_DEFAULT_PATH_QUALITY, | ||||
| 		.procname	= "default_path_quality", | ||||
| 		.data		= &sysctl_netrom_default_path_quality, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_quality, | ||||
| 		.extra2		= &max_quality | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NETROM_OBSOLESCENCE_COUNT_INITIALISER, | ||||
| 		.procname	= "obsolescence_count_initialiser", | ||||
| 		.data		= &sysctl_netrom_obsolescence_count_initialiser, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_obs, | ||||
| 		.extra2		= &max_obs | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NETROM_NETWORK_TTL_INITIALISER, | ||||
| 		.procname	= "network_ttl_initialiser", | ||||
| 		.data		= &sysctl_netrom_network_ttl_initialiser, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_ttl, | ||||
| 		.extra2		= &max_ttl | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NETROM_TRANSPORT_TIMEOUT, | ||||
| 		.procname	= "transport_timeout", | ||||
| 		.data		= &sysctl_netrom_transport_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_t1, | ||||
| 		.extra2		= &max_t1 | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NETROM_TRANSPORT_MAXIMUM_TRIES, | ||||
| 		.procname	= "transport_maximum_tries", | ||||
| 		.data		= &sysctl_netrom_transport_maximum_tries, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_n2, | ||||
| 		.extra2		= &max_n2 | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NETROM_TRANSPORT_ACKNOWLEDGE_DELAY, | ||||
| 		.procname	= "transport_acknowledge_delay", | ||||
| 		.data		= &sysctl_netrom_transport_acknowledge_delay, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_t2, | ||||
| 		.extra2		= &max_t2 | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NETROM_TRANSPORT_BUSY_DELAY, | ||||
| 		.procname	= "transport_busy_delay", | ||||
| 		.data		= &sysctl_netrom_transport_busy_delay, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_t4, | ||||
| 		.extra2		= &max_t4 | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NETROM_TRANSPORT_REQUESTED_WINDOW_SIZE, | ||||
| 		.procname	= "transport_requested_window_size", | ||||
| 		.data		= &sysctl_netrom_transport_requested_window_size, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_window, | ||||
| 		.extra2		= &max_window | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NETROM_TRANSPORT_NO_ACTIVITY_TIMEOUT, | ||||
| 		.procname	= "transport_no_activity_timeout", | ||||
| 		.data		= &sysctl_netrom_transport_no_activity_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_idle, | ||||
| 		.extra2		= &max_idle | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NETROM_ROUTING_CONTROL, | ||||
| 		.procname	= "routing_control", | ||||
| 		.data		= &sysctl_netrom_routing_control, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_route, | ||||
| 		.extra2		= &max_route | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NETROM_LINK_FAILS_COUNT, | ||||
| 		.procname	= "link_fails_count", | ||||
| 		.data		= &sysctl_netrom_link_fails_count, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_fails, | ||||
| 		.extra2		= &max_fails | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_NETROM_RESET, | ||||
| 		.procname	= "reset", | ||||
| 		.data		= &sysctl_netrom_reset_circuit, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_reset, | ||||
| 		.extra2		= &max_reset | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path nr_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "netrom", .ctl_name = NET_NETROM, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "netrom", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -84,20 +84,18 @@ static int proc_local_port_range(ctl_table *table, int write, | |||
| 
 | ||||
| static struct ctl_table phonet_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "local_port_range", | ||||
| 		.data		= &local_port_range, | ||||
| 		.maxlen		= sizeof(local_port_range), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_local_port_range, | ||||
| 		.strategy	= NULL, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path phonet_ctl_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "phonet", .ctl_name = CTL_UNNUMBERED, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "phonet", }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -67,7 +67,6 @@ unsigned int rds_ib_sysctl_flow_control = 0; | |||
| 
 | ||||
| ctl_table rds_ib_sysctl_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "max_send_wr", | ||||
| 		.data		= &rds_ib_sysctl_max_send_wr, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -77,7 +76,6 @@ ctl_table rds_ib_sysctl_table[] = { | |||
| 		.extra2		= &rds_ib_sysctl_max_wr_max, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "max_recv_wr", | ||||
| 		.data		= &rds_ib_sysctl_max_recv_wr, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -87,7 +85,6 @@ ctl_table rds_ib_sysctl_table[] = { | |||
| 		.extra2		= &rds_ib_sysctl_max_wr_max, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "max_unsignaled_wr", | ||||
| 		.data		= &rds_ib_sysctl_max_unsig_wrs, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -97,7 +94,6 @@ ctl_table rds_ib_sysctl_table[] = { | |||
| 		.extra2		= &rds_ib_sysctl_max_unsig_wr_max, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "max_unsignaled_bytes", | ||||
| 		.data		= &rds_ib_sysctl_max_unsig_bytes, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -107,7 +103,6 @@ ctl_table rds_ib_sysctl_table[] = { | |||
| 		.extra2		= &rds_ib_sysctl_max_unsig_bytes_max, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "max_recv_allocation", | ||||
| 		.data		= &rds_ib_sysctl_max_recv_allocation, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -115,20 +110,19 @@ ctl_table rds_ib_sysctl_table[] = { | |||
| 		.proc_handler   = &proc_doulongvec_minmax, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "flow_control", | ||||
| 		.data		= &rds_ib_sysctl_flow_control, | ||||
| 		.maxlen		= sizeof(rds_ib_sysctl_flow_control), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0} | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path rds_ib_sysctl_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "rds", .ctl_name = CTL_UNNUMBERED, }, | ||||
| 	{ .procname = "ib", .ctl_name = CTL_UNNUMBERED, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "rds", }, | ||||
| 	{ .procname = "ib", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -57,7 +57,6 @@ unsigned int rds_iw_sysctl_flow_control = 1; | |||
| 
 | ||||
| ctl_table rds_iw_sysctl_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "max_send_wr", | ||||
| 		.data		= &rds_iw_sysctl_max_send_wr, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -67,7 +66,6 @@ ctl_table rds_iw_sysctl_table[] = { | |||
| 		.extra2		= &rds_iw_sysctl_max_wr_max, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "max_recv_wr", | ||||
| 		.data		= &rds_iw_sysctl_max_recv_wr, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -77,7 +75,6 @@ ctl_table rds_iw_sysctl_table[] = { | |||
| 		.extra2		= &rds_iw_sysctl_max_wr_max, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "max_unsignaled_wr", | ||||
| 		.data		= &rds_iw_sysctl_max_unsig_wrs, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -87,7 +84,6 @@ ctl_table rds_iw_sysctl_table[] = { | |||
| 		.extra2		= &rds_iw_sysctl_max_unsig_wr_max, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "max_unsignaled_bytes", | ||||
| 		.data		= &rds_iw_sysctl_max_unsig_bytes, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -97,7 +93,6 @@ ctl_table rds_iw_sysctl_table[] = { | |||
| 		.extra2		= &rds_iw_sysctl_max_unsig_bytes_max, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "max_recv_allocation", | ||||
| 		.data		= &rds_iw_sysctl_max_recv_allocation, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -105,20 +100,19 @@ ctl_table rds_iw_sysctl_table[] = { | |||
| 		.proc_handler   = &proc_doulongvec_minmax, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "flow_control", | ||||
| 		.data		= &rds_iw_sysctl_flow_control, | ||||
| 		.maxlen		= sizeof(rds_iw_sysctl_flow_control), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0} | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path rds_iw_sysctl_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "rds", .ctl_name = CTL_UNNUMBERED, }, | ||||
| 	{ .procname = "iw", .ctl_name = CTL_UNNUMBERED, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "rds", }, | ||||
| 	{ .procname = "iw", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -51,7 +51,6 @@ unsigned int rds_sysctl_ping_enable = 1; | |||
| 
 | ||||
| static ctl_table rds_sysctl_rds_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "reconnect_min_delay_ms", | ||||
| 		.data		= &rds_sysctl_reconnect_min_jiffies, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -61,7 +60,6 @@ static ctl_table rds_sysctl_rds_table[] = { | |||
| 		.extra2		= &rds_sysctl_reconnect_max_jiffies, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname       = "reconnect_max_delay_ms", | ||||
| 		.data		= &rds_sysctl_reconnect_max_jiffies, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -71,7 +69,6 @@ static ctl_table rds_sysctl_rds_table[] = { | |||
| 		.extra2		= &rds_sysctl_reconnect_max, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "max_unacked_packets", | ||||
| 		.data		= &rds_sysctl_max_unacked_packets, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -79,7 +76,6 @@ static ctl_table rds_sysctl_rds_table[] = { | |||
| 		.proc_handler   = &proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "max_unacked_bytes", | ||||
| 		.data		= &rds_sysctl_max_unacked_bytes, | ||||
| 		.maxlen         = sizeof(unsigned long), | ||||
|  | @ -87,19 +83,18 @@ static ctl_table rds_sysctl_rds_table[] = { | |||
| 		.proc_handler   = &proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "ping_enable", | ||||
| 		.data		= &rds_sysctl_ping_enable, | ||||
| 		.maxlen         = sizeof(int), | ||||
| 		.mode           = 0644, | ||||
| 		.proc_handler   = &proc_dointvec, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0} | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path rds_sysctl_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "rds", .ctl_name = CTL_UNNUMBERED, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "rds", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -26,121 +26,101 @@ static struct ctl_table_header *rose_table_header; | |||
| 
 | ||||
| static ctl_table rose_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ROSE_RESTART_REQUEST_TIMEOUT, | ||||
| 		.procname	= "restart_request_timeout", | ||||
| 		.data		= &sysctl_rose_restart_request_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_timer, | ||||
| 		.extra2		= &max_timer | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ROSE_CALL_REQUEST_TIMEOUT, | ||||
| 		.procname	= "call_request_timeout", | ||||
| 		.data		= &sysctl_rose_call_request_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_timer, | ||||
| 		.extra2		= &max_timer | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ROSE_RESET_REQUEST_TIMEOUT, | ||||
| 		.procname	= "reset_request_timeout", | ||||
| 		.data		= &sysctl_rose_reset_request_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_timer, | ||||
| 		.extra2		= &max_timer | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ROSE_CLEAR_REQUEST_TIMEOUT, | ||||
| 		.procname	= "clear_request_timeout", | ||||
| 		.data		= &sysctl_rose_clear_request_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_timer, | ||||
| 		.extra2		= &max_timer | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ROSE_NO_ACTIVITY_TIMEOUT, | ||||
| 		.procname	= "no_activity_timeout", | ||||
| 		.data		= &sysctl_rose_no_activity_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_idle, | ||||
| 		.extra2		= &max_idle | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ROSE_ACK_HOLD_BACK_TIMEOUT, | ||||
| 		.procname	= "acknowledge_hold_back_timeout", | ||||
| 		.data		= &sysctl_rose_ack_hold_back_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_timer, | ||||
| 		.extra2		= &max_timer | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ROSE_ROUTING_CONTROL, | ||||
| 		.procname	= "routing_control", | ||||
| 		.data		= &sysctl_rose_routing_control, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_route, | ||||
| 		.extra2		= &max_route | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ROSE_LINK_FAIL_TIMEOUT, | ||||
| 		.procname	= "link_fail_timeout", | ||||
| 		.data		= &sysctl_rose_link_fail_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_ftimer, | ||||
| 		.extra2		= &max_ftimer | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ROSE_MAX_VCS, | ||||
| 		.procname	= "maximum_virtual_circuits", | ||||
| 		.data		= &sysctl_rose_maximum_vcs, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_maxvcs, | ||||
| 		.extra2		= &max_maxvcs | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_ROSE_WINDOW_SIZE, | ||||
| 		.procname	= "window_size", | ||||
| 		.data		= &sysctl_rose_window_size, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &min_window, | ||||
| 		.extra2		= &max_window | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path rose_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "rose", .ctl_name = NET_ROSE, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "rose", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -59,180 +59,145 @@ extern int sysctl_sctp_wmem[3]; | |||
| 
 | ||||
| static ctl_table sctp_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_RTO_INITIAL, | ||||
| 		.procname	= "rto_initial", | ||||
| 		.data		= &sctp_rto_initial, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1         = &one, | ||||
| 		.extra2         = &timer_max | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_RTO_MIN, | ||||
| 		.procname	= "rto_min", | ||||
| 		.data		= &sctp_rto_min, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1         = &one, | ||||
| 		.extra2         = &timer_max | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_RTO_MAX, | ||||
| 		.procname	= "rto_max", | ||||
| 		.data		= &sctp_rto_max, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1         = &one, | ||||
| 		.extra2         = &timer_max | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_VALID_COOKIE_LIFE, | ||||
| 		.procname	= "valid_cookie_life", | ||||
| 		.data		= &sctp_valid_cookie_life, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1         = &one, | ||||
| 		.extra2         = &timer_max | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_MAX_BURST, | ||||
| 		.procname	= "max_burst", | ||||
| 		.data		= &sctp_max_burst, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &zero, | ||||
| 		.extra2		= &int_max | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_ASSOCIATION_MAX_RETRANS, | ||||
| 		.procname	= "association_max_retrans", | ||||
| 		.data		= &sctp_max_retrans_association, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &one, | ||||
| 		.extra2		= &int_max | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_SNDBUF_POLICY, | ||||
| 		.procname	= "sndbuf_policy", | ||||
| 		.data		= &sctp_sndbuf_policy, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 		.strategy	= sysctl_intvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_RCVBUF_POLICY, | ||||
| 		.procname	= "rcvbuf_policy", | ||||
| 		.data		= &sctp_rcvbuf_policy, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 		.strategy	= sysctl_intvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_PATH_MAX_RETRANS, | ||||
| 		.procname	= "path_max_retrans", | ||||
| 		.data		= &sctp_max_retrans_path, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &one, | ||||
| 		.extra2		= &int_max | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_MAX_INIT_RETRANSMITS, | ||||
| 		.procname	= "max_init_retransmits", | ||||
| 		.data		= &sctp_max_retrans_init, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1		= &one, | ||||
| 		.extra2		= &int_max | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_HB_INTERVAL, | ||||
| 		.procname	= "hb_interval", | ||||
| 		.data		= &sctp_hb_interval, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1         = &one, | ||||
| 		.extra2         = &timer_max | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_PRESERVE_ENABLE, | ||||
| 		.procname	= "cookie_preserve_enable", | ||||
| 		.data		= &sctp_cookie_preserve_enable, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 		.strategy	= sysctl_intvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_RTO_ALPHA, | ||||
| 		.procname	= "rto_alpha_exp_divisor", | ||||
| 		.data		= &sctp_rto_alpha, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0444, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 		.strategy	= sysctl_intvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_RTO_BETA, | ||||
| 		.procname	= "rto_beta_exp_divisor", | ||||
| 		.data		= &sctp_rto_beta, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0444, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 		.strategy	= sysctl_intvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_ADDIP_ENABLE, | ||||
| 		.procname	= "addip_enable", | ||||
| 		.data		= &sctp_addip_enable, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 		.strategy	= sysctl_intvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_PRSCTP_ENABLE, | ||||
| 		.procname	= "prsctp_enable", | ||||
| 		.data		= &sctp_prsctp_enable, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 		.strategy	= sysctl_intvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_SCTP_SACK_TIMEOUT, | ||||
| 		.procname	= "sack_timeout", | ||||
| 		.data		= &sctp_sack_timeout, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec_minmax, | ||||
| 		.strategy	= sysctl_intvec, | ||||
| 		.extra1         = &sack_timer_min, | ||||
| 		.extra2         = &sack_timer_max, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "sctp_mem", | ||||
| 		.data		= &sysctl_sctp_mem, | ||||
| 		.maxlen		= sizeof(sysctl_sctp_mem), | ||||
|  | @ -240,7 +205,6 @@ static ctl_table sctp_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "sctp_rmem", | ||||
| 		.data		= &sysctl_sctp_rmem, | ||||
| 		.maxlen		= sizeof(sysctl_sctp_rmem), | ||||
|  | @ -248,7 +212,6 @@ static ctl_table sctp_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "sctp_wmem", | ||||
| 		.data		= &sysctl_sctp_wmem, | ||||
| 		.maxlen		= sizeof(sysctl_sctp_wmem), | ||||
|  | @ -256,40 +219,34 @@ static ctl_table sctp_table[] = { | |||
| 		.proc_handler	= proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "auth_enable", | ||||
| 		.data		= &sctp_auth_enable, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 		.strategy	= sysctl_intvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "addip_noauth_enable", | ||||
| 		.data		= &sctp_addip_noauth, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec, | ||||
| 		.strategy	= sysctl_intvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "addr_scope_policy", | ||||
| 		.data		= &sctp_scope_policy, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec_minmax, | ||||
| 		.strategy	= &sysctl_intvec, | ||||
| 		.extra1		= &zero, | ||||
| 		.extra2		= &addr_scope_max, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path sctp_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "sctp", .ctl_name = NET_SCTP, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "sctp", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -168,17 +168,16 @@ static ctl_table debug_table[] = { | |||
| 		.mode		= 0444, | ||||
| 		.proc_handler	= &proc_do_xprt, | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static ctl_table sunrpc_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_SUNRPC, | ||||
| 		.procname	= "sunrpc", | ||||
| 		.mode		= 0555, | ||||
| 		.child		= debug_table | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -121,7 +121,6 @@ static ctl_table svcrdma_parm_table[] = { | |||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec_minmax, | ||||
| 		.strategy	= &sysctl_intvec, | ||||
| 		.extra1		= &min_max_requests, | ||||
| 		.extra2		= &max_max_requests | ||||
| 	}, | ||||
|  | @ -131,7 +130,6 @@ static ctl_table svcrdma_parm_table[] = { | |||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec_minmax, | ||||
| 		.strategy	= &sysctl_intvec, | ||||
| 		.extra1		= &min_max_inline, | ||||
| 		.extra2		= &max_max_inline | ||||
| 	}, | ||||
|  | @ -141,7 +139,6 @@ static ctl_table svcrdma_parm_table[] = { | |||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec_minmax, | ||||
| 		.strategy	= &sysctl_intvec, | ||||
| 		.extra1		= &min_ord, | ||||
| 		.extra2		= &max_ord, | ||||
| 	}, | ||||
|  | @ -209,9 +206,7 @@ static ctl_table svcrdma_parm_table[] = { | |||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &read_reset_stat, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = 0, | ||||
| 	}, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| static ctl_table svcrdma_table[] = { | ||||
|  | @ -220,21 +215,16 @@ static ctl_table svcrdma_table[] = { | |||
| 		.mode		= 0555, | ||||
| 		.child		= svcrdma_parm_table | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = 0, | ||||
| 	}, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| static ctl_table svcrdma_root_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_SUNRPC, | ||||
| 		.procname	= "sunrpc", | ||||
| 		.mode		= 0555, | ||||
| 		.child		= svcrdma_table | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = 0, | ||||
| 	}, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| void svc_rdma_cleanup(void) | ||||
|  |  | |||
|  | @ -86,79 +86,63 @@ static struct ctl_table_header *sunrpc_table_header; | |||
| 
 | ||||
| static ctl_table xr_tunables_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname	= "rdma_slot_table_entries", | ||||
| 		.data		= &xprt_rdma_slot_table_entries, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec_minmax, | ||||
| 		.strategy	= &sysctl_intvec, | ||||
| 		.extra1		= &min_slot_table_size, | ||||
| 		.extra2		= &max_slot_table_size | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname	= "rdma_max_inline_read", | ||||
| 		.data		= &xprt_rdma_max_inline_read, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec, | ||||
| 		.strategy	= &sysctl_intvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname	= "rdma_max_inline_write", | ||||
| 		.data		= &xprt_rdma_max_inline_write, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec, | ||||
| 		.strategy	= &sysctl_intvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname	= "rdma_inline_write_padding", | ||||
| 		.data		= &xprt_rdma_inline_write_padding, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec_minmax, | ||||
| 		.strategy	= &sysctl_intvec, | ||||
| 		.extra1		= &zero, | ||||
| 		.extra2		= &max_padding, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname	= "rdma_memreg_strategy", | ||||
| 		.data		= &xprt_rdma_memreg_strategy, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec_minmax, | ||||
| 		.strategy	= &sysctl_intvec, | ||||
| 		.extra1		= &min_memreg, | ||||
| 		.extra2		= &max_memreg, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name       = CTL_UNNUMBERED, | ||||
| 		.procname	= "rdma_pad_optimize", | ||||
| 		.data		= &xprt_rdma_pad_optimize, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = 0, | ||||
| 	}, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| static ctl_table sunrpc_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_SUNRPC, | ||||
| 		.procname	= "sunrpc", | ||||
| 		.mode		= 0555, | ||||
| 		.child		= xr_tunables_table | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = 0, | ||||
| 	}, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -81,46 +81,38 @@ static struct ctl_table_header *sunrpc_table_header; | |||
|  */ | ||||
| static ctl_table xs_tunables_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_SLOTTABLE_UDP, | ||||
| 		.procname	= "udp_slot_table_entries", | ||||
| 		.data		= &xprt_udp_slot_table_entries, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec_minmax, | ||||
| 		.strategy	= &sysctl_intvec, | ||||
| 		.extra1		= &min_slot_table_size, | ||||
| 		.extra2		= &max_slot_table_size | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_SLOTTABLE_TCP, | ||||
| 		.procname	= "tcp_slot_table_entries", | ||||
| 		.data		= &xprt_tcp_slot_table_entries, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec_minmax, | ||||
| 		.strategy	= &sysctl_intvec, | ||||
| 		.extra1		= &min_slot_table_size, | ||||
| 		.extra2		= &max_slot_table_size | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_MIN_RESVPORT, | ||||
| 		.procname	= "min_resvport", | ||||
| 		.data		= &xprt_min_resvport, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec_minmax, | ||||
| 		.strategy	= &sysctl_intvec, | ||||
| 		.extra1		= &xprt_min_resvport_limit, | ||||
| 		.extra2		= &xprt_max_resvport_limit | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_MAX_RESVPORT, | ||||
| 		.procname	= "max_resvport", | ||||
| 		.data		= &xprt_max_resvport, | ||||
| 		.maxlen		= sizeof(unsigned int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec_minmax, | ||||
| 		.strategy	= &sysctl_intvec, | ||||
| 		.extra1		= &xprt_min_resvport_limit, | ||||
| 		.extra2		= &xprt_max_resvport_limit | ||||
| 	}, | ||||
|  | @ -130,23 +122,17 @@ static ctl_table xs_tunables_table[] = { | |||
| 		.maxlen		= sizeof(xs_tcp_fin_timeout), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= &proc_dointvec_jiffies, | ||||
| 		.strategy	= sysctl_jiffies | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = 0, | ||||
| 	}, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| static ctl_table sunrpc_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_SUNRPC, | ||||
| 		.procname	= "sunrpc", | ||||
| 		.mode		= 0555, | ||||
| 		.child		= xs_tunables_table | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name = 0, | ||||
| 	}, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -16,19 +16,18 @@ | |||
| 
 | ||||
| static ctl_table unix_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_UNIX_MAX_DGRAM_QLEN, | ||||
| 		.procname	= "max_dgram_qlen", | ||||
| 		.data		= &init_net.unx.sysctl_max_dgram_qlen, | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ .ctl_name = 0 } | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
| static struct ctl_path unix_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "unix", .ctl_name = NET_UNIX, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "unix", }, | ||||
| 	{ }, | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -19,62 +19,51 @@ static struct ctl_table_header *x25_table_header; | |||
| 
 | ||||
| static struct ctl_table x25_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name =	NET_X25_RESTART_REQUEST_TIMEOUT, | ||||
| 		.procname =	"restart_request_timeout", | ||||
| 		.data =		&sysctl_x25_restart_request_timeout, | ||||
| 		.maxlen =	sizeof(int), | ||||
| 		.mode =		0644, | ||||
| 		.proc_handler =	proc_dointvec_minmax, | ||||
| 		.strategy =	sysctl_intvec, | ||||
| 		.extra1 =	&min_timer, | ||||
| 		.extra2 =	&max_timer, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name =	NET_X25_CALL_REQUEST_TIMEOUT, | ||||
| 		.procname =	"call_request_timeout", | ||||
| 		.data =		&sysctl_x25_call_request_timeout, | ||||
| 		.maxlen =	sizeof(int), | ||||
| 		.mode =		0644, | ||||
| 		.proc_handler =	proc_dointvec_minmax, | ||||
| 		.strategy =	sysctl_intvec, | ||||
| 		.extra1 =	&min_timer, | ||||
| 		.extra2 =	&max_timer, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name =	NET_X25_RESET_REQUEST_TIMEOUT, | ||||
| 		.procname =	"reset_request_timeout", | ||||
| 		.data =		&sysctl_x25_reset_request_timeout, | ||||
| 		.maxlen =	sizeof(int), | ||||
| 		.mode =		0644, | ||||
| 		.proc_handler =	proc_dointvec_minmax, | ||||
| 		.strategy =	sysctl_intvec, | ||||
| 		.extra1 =	&min_timer, | ||||
| 		.extra2 =	&max_timer, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name =	NET_X25_CLEAR_REQUEST_TIMEOUT, | ||||
| 		.procname =	"clear_request_timeout", | ||||
| 		.data =		&sysctl_x25_clear_request_timeout, | ||||
| 		.maxlen =	sizeof(int), | ||||
| 		.mode =		0644, | ||||
| 		.proc_handler =	proc_dointvec_minmax, | ||||
| 		.strategy =	sysctl_intvec, | ||||
| 		.extra1 =	&min_timer, | ||||
| 		.extra2 =	&max_timer, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name =	NET_X25_ACK_HOLD_BACK_TIMEOUT, | ||||
| 		.procname =	"acknowledgement_hold_back_timeout", | ||||
| 		.data =		&sysctl_x25_ack_holdback_timeout, | ||||
| 		.maxlen =	sizeof(int), | ||||
| 		.mode =		0644, | ||||
| 		.proc_handler =	proc_dointvec_minmax, | ||||
| 		.strategy =	sysctl_intvec, | ||||
| 		.extra1 =	&min_timer, | ||||
| 		.extra2 =	&max_timer, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name =	NET_X25_FORWARD, | ||||
| 		.procname =	"x25_forward", | ||||
| 		.data = 	&sysctl_x25_forward, | ||||
| 		.maxlen = 	sizeof(int), | ||||
|  | @ -85,8 +74,8 @@ static struct ctl_table x25_table[] = { | |||
| }; | ||||
| 
 | ||||
| static struct ctl_path x25_path[] = { | ||||
| 	{ .procname = "net", .ctl_name = CTL_NET, }, | ||||
| 	{ .procname = "x25", .ctl_name = NET_X25, }, | ||||
| 	{ .procname = "net", }, | ||||
| 	{ .procname = "x25", }, | ||||
| 	{ } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -13,28 +13,24 @@ static void __xfrm_sysctl_init(struct net *net) | |||
| #ifdef CONFIG_SYSCTL | ||||
| static struct ctl_table xfrm_table[] = { | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_AEVENT_ETIME, | ||||
| 		.procname	= "xfrm_aevent_etime", | ||||
| 		.maxlen		= sizeof(u32), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= NET_CORE_AEVENT_RSEQTH, | ||||
| 		.procname	= "xfrm_aevent_rseqth", | ||||
| 		.maxlen		= sizeof(u32), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "xfrm_larval_drop", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
| 		.proc_handler	= proc_dointvec | ||||
| 	}, | ||||
| 	{ | ||||
| 		.ctl_name	= CTL_UNNUMBERED, | ||||
| 		.procname	= "xfrm_acq_expires", | ||||
| 		.maxlen		= sizeof(int), | ||||
| 		.mode		= 0644, | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Eric W. Biederman
						Eric W. Biederman