xref: /linux/fs/nfs/sysctl.c (revision 26fbb4c8c7c3ee9a4c3b4de555a8587b5a19154e)
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * linux/fs/nfs/sysctl.c
4  *
5  * Sysctl interface to NFS parameters
6  */
7 #include <linux/types.h>
8 #include <linux/linkage.h>
9 #include <linux/ctype.h>
10 #include <linux/fs.h>
11 #include <linux/sysctl.h>
12 #include <linux/module.h>
13 #include <linux/nfs_fs.h>
14 
15 static struct ctl_table_header *nfs_callback_sysctl_table;
16 
17 static struct ctl_table nfs_cb_sysctls[] = {
18 	{
19 		.procname	= "nfs_mountpoint_timeout",
20 		.data		= &nfs_mountpoint_expiry_timeout,
21 		.maxlen		= sizeof(nfs_mountpoint_expiry_timeout),
22 		.mode		= 0644,
23 		.proc_handler	= proc_dointvec_jiffies,
24 	},
25 	{
26 		.procname	= "nfs_congestion_kb",
27 		.data		= &nfs_congestion_kb,
28 		.maxlen		= sizeof(nfs_congestion_kb),
29 		.mode		= 0644,
30 		.proc_handler	= proc_dointvec,
31 	},
32 	{ }
33 };
34 
35 static struct ctl_table nfs_cb_sysctl_dir[] = {
36 	{
37 		.procname = "nfs",
38 		.mode = 0555,
39 		.child = nfs_cb_sysctls,
40 	},
41 	{ }
42 };
43 
44 static struct ctl_table nfs_cb_sysctl_root[] = {
45 	{
46 		.procname = "fs",
47 		.mode = 0555,
48 		.child = nfs_cb_sysctl_dir,
49 	},
50 	{ }
51 };
52 
53 int nfs_register_sysctl(void)
54 {
55 	nfs_callback_sysctl_table = register_sysctl_table(nfs_cb_sysctl_root);
56 	if (nfs_callback_sysctl_table == NULL)
57 		return -ENOMEM;
58 	return 0;
59 }
60 
61 void nfs_unregister_sysctl(void)
62 {
63 	unregister_sysctl_table(nfs_callback_sysctl_table);
64 	nfs_callback_sysctl_table = NULL;
65 }
66