Linux Audio

Check our new training course

Loading...
v4.6
 1/*
 2 * linux/fs/nfs/sysctl.c
 3 *
 4 * Sysctl interface to NFS parameters
 5 */
 6#include <linux/types.h>
 7#include <linux/linkage.h>
 8#include <linux/ctype.h>
 9#include <linux/fs.h>
10#include <linux/sysctl.h>
11#include <linux/module.h>
 
 
12#include <linux/nfs_fs.h>
13
 
 
 
 
 
 
14static struct ctl_table_header *nfs_callback_sysctl_table;
15
16static struct ctl_table nfs_cb_sysctls[] = {
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
17	{
18		.procname	= "nfs_mountpoint_timeout",
19		.data		= &nfs_mountpoint_expiry_timeout,
20		.maxlen		= sizeof(nfs_mountpoint_expiry_timeout),
21		.mode		= 0644,
22		.proc_handler	= proc_dointvec_jiffies,
23	},
24	{
25		.procname	= "nfs_congestion_kb",
26		.data		= &nfs_congestion_kb,
27		.maxlen		= sizeof(nfs_congestion_kb),
28		.mode		= 0644,
29		.proc_handler	= proc_dointvec,
30	},
31	{ }
32};
33
34static struct ctl_table nfs_cb_sysctl_dir[] = {
35	{
36		.procname = "nfs",
37		.mode = 0555,
38		.child = nfs_cb_sysctls,
39	},
40	{ }
41};
42
43static struct ctl_table nfs_cb_sysctl_root[] = {
44	{
45		.procname = "fs",
46		.mode = 0555,
47		.child = nfs_cb_sysctl_dir,
48	},
49	{ }
50};
51
52int nfs_register_sysctl(void)
53{
54	nfs_callback_sysctl_table = register_sysctl_table(nfs_cb_sysctl_root);
55	if (nfs_callback_sysctl_table == NULL)
56		return -ENOMEM;
57	return 0;
58}
59
60void nfs_unregister_sysctl(void)
61{
62	unregister_sysctl_table(nfs_callback_sysctl_table);
63	nfs_callback_sysctl_table = NULL;
64}
v3.1
 1/*
 2 * linux/fs/nfs/sysctl.c
 3 *
 4 * Sysctl interface to NFS parameters
 5 */
 6#include <linux/types.h>
 7#include <linux/linkage.h>
 8#include <linux/ctype.h>
 9#include <linux/fs.h>
10#include <linux/sysctl.h>
11#include <linux/module.h>
12#include <linux/nfs4.h>
13#include <linux/nfs_idmap.h>
14#include <linux/nfs_fs.h>
15
16#include "callback.h"
17
18#ifdef CONFIG_NFS_V4
19static const int nfs_set_port_min = 0;
20static const int nfs_set_port_max = 65535;
21#endif
22static struct ctl_table_header *nfs_callback_sysctl_table;
23
24static ctl_table nfs_cb_sysctls[] = {
25#ifdef CONFIG_NFS_V4
26	{
27		.procname = "nfs_callback_tcpport",
28		.data = &nfs_callback_set_tcpport,
29		.maxlen = sizeof(int),
30		.mode = 0644,
31		.proc_handler = proc_dointvec_minmax,
32		.extra1 = (int *)&nfs_set_port_min,
33		.extra2 = (int *)&nfs_set_port_max,
34	},
35#ifndef CONFIG_NFS_USE_NEW_IDMAPPER
36	{
37		.procname = "idmap_cache_timeout",
38		.data = &nfs_idmap_cache_timeout,
39		.maxlen = sizeof(int),
40		.mode = 0644,
41		.proc_handler = proc_dointvec_jiffies,
42	},
43#endif /* CONFIG_NFS_USE_NEW_IDMAPPER */
44#endif
45	{
46		.procname	= "nfs_mountpoint_timeout",
47		.data		= &nfs_mountpoint_expiry_timeout,
48		.maxlen		= sizeof(nfs_mountpoint_expiry_timeout),
49		.mode		= 0644,
50		.proc_handler	= proc_dointvec_jiffies,
51	},
52	{
53		.procname	= "nfs_congestion_kb",
54		.data		= &nfs_congestion_kb,
55		.maxlen		= sizeof(nfs_congestion_kb),
56		.mode		= 0644,
57		.proc_handler	= proc_dointvec,
58	},
59	{ }
60};
61
62static ctl_table nfs_cb_sysctl_dir[] = {
63	{
64		.procname = "nfs",
65		.mode = 0555,
66		.child = nfs_cb_sysctls,
67	},
68	{ }
69};
70
71static ctl_table nfs_cb_sysctl_root[] = {
72	{
73		.procname = "fs",
74		.mode = 0555,
75		.child = nfs_cb_sysctl_dir,
76	},
77	{ }
78};
79
80int nfs_register_sysctl(void)
81{
82	nfs_callback_sysctl_table = register_sysctl_table(nfs_cb_sysctl_root);
83	if (nfs_callback_sysctl_table == NULL)
84		return -ENOMEM;
85	return 0;
86}
87
88void nfs_unregister_sysctl(void)
89{
90	unregister_sysctl_table(nfs_callback_sysctl_table);
91	nfs_callback_sysctl_table = NULL;
92}