mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	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>
		
			
				
	
	
		
			62 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * NET4:	Sysctl interface to net af_unix subsystem.
 | 
						|
 *
 | 
						|
 * Authors:	Mike Shaver.
 | 
						|
 *
 | 
						|
 *		This program is free software; you can redistribute it and/or
 | 
						|
 *		modify it under the terms of the GNU General Public License
 | 
						|
 *		as published by the Free Software Foundation; either version
 | 
						|
 *		2 of the License, or (at your option) any later version.
 | 
						|
 */
 | 
						|
 | 
						|
#include <linux/mm.h>
 | 
						|
#include <linux/sysctl.h>
 | 
						|
 | 
						|
#include <net/af_unix.h>
 | 
						|
 | 
						|
static ctl_table unix_table[] = {
 | 
						|
	{
 | 
						|
		.procname	= "max_dgram_qlen",
 | 
						|
		.data		= &init_net.unx.sysctl_max_dgram_qlen,
 | 
						|
		.maxlen		= sizeof(int),
 | 
						|
		.mode		= 0644,
 | 
						|
		.proc_handler	= proc_dointvec
 | 
						|
	},
 | 
						|
	{ }
 | 
						|
};
 | 
						|
 | 
						|
static struct ctl_path unix_path[] = {
 | 
						|
	{ .procname = "net", },
 | 
						|
	{ .procname = "unix", },
 | 
						|
	{ },
 | 
						|
};
 | 
						|
 | 
						|
int unix_sysctl_register(struct net *net)
 | 
						|
{
 | 
						|
	struct ctl_table *table;
 | 
						|
 | 
						|
	table = kmemdup(unix_table, sizeof(unix_table), GFP_KERNEL);
 | 
						|
	if (table == NULL)
 | 
						|
		goto err_alloc;
 | 
						|
 | 
						|
	table[0].data = &net->unx.sysctl_max_dgram_qlen;
 | 
						|
	net->unx.ctl = register_net_sysctl_table(net, unix_path, table);
 | 
						|
	if (net->unx.ctl == NULL)
 | 
						|
		goto err_reg;
 | 
						|
 | 
						|
	return 0;
 | 
						|
 | 
						|
err_reg:
 | 
						|
	kfree(table);
 | 
						|
err_alloc:
 | 
						|
	return -ENOMEM;
 | 
						|
}
 | 
						|
 | 
						|
void unix_sysctl_unregister(struct net *net)
 | 
						|
{
 | 
						|
	struct ctl_table *table;
 | 
						|
 | 
						|
	table = net->unx.ctl->ctl_table_arg;
 | 
						|
	unregister_sysctl_table(net->unx.ctl);
 | 
						|
	kfree(table);
 | 
						|
}
 |