xref: /openbmc/linux/net/x25/sysctl_net_x25.c (revision 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2)
1 /* -*- linux-c -*-
2  * sysctl_net_x25.c: sysctl interface to net X.25 subsystem.
3  *
4  * Begun April 1, 1996, Mike Shaver.
5  * Added /proc/sys/net/x25 directory entry (empty =) ). [MS]
6  */
7 
8 #include <linux/sysctl.h>
9 #include <linux/skbuff.h>
10 #include <linux/socket.h>
11 #include <linux/netdevice.h>
12 #include <linux/init.h>
13 #include <net/x25.h>
14 
15 static int min_timer[] = {   1 * HZ };
16 static int max_timer[] = { 300 * HZ };
17 
18 static struct ctl_table_header *x25_table_header;
19 
20 static struct ctl_table x25_table[] = {
21         {
22 		.ctl_name =	NET_X25_RESTART_REQUEST_TIMEOUT,
23 		.procname =	"restart_request_timeout",
24 		.data =		&sysctl_x25_restart_request_timeout,
25 		.maxlen =	sizeof(int),
26 		.mode =		0644,
27 		.proc_handler =	&proc_dointvec_minmax,
28 		.strategy =	&sysctl_intvec,
29 		.extra1 =	&min_timer,
30 		.extra2 =	&max_timer,
31 	},
32         {
33 		.ctl_name =	NET_X25_CALL_REQUEST_TIMEOUT,
34 		.procname =	"call_request_timeout",
35 		.data =		&sysctl_x25_call_request_timeout,
36 		.maxlen =	sizeof(int),
37 		.mode =		0644,
38 		.proc_handler =	&proc_dointvec_minmax,
39 		.strategy =	&sysctl_intvec,
40 		.extra1 =	&min_timer,
41 		.extra2 =	&max_timer,
42 	},
43         {
44 		.ctl_name =	NET_X25_RESET_REQUEST_TIMEOUT,
45 		.procname =	"reset_request_timeout",
46 		.data =		&sysctl_x25_reset_request_timeout,
47 		.maxlen =	sizeof(int),
48 		.mode =		0644,
49 		.proc_handler =	&proc_dointvec_minmax,
50 		.strategy =	&sysctl_intvec,
51 		.extra1 =	&min_timer,
52 		.extra2 =	&max_timer,
53 	},
54         {
55 		.ctl_name =	NET_X25_CLEAR_REQUEST_TIMEOUT,
56 		.procname =	"clear_request_timeout",
57 		.data =		&sysctl_x25_clear_request_timeout,
58 		.maxlen =	sizeof(int),
59 		.mode =		0644,
60 		.proc_handler =	&proc_dointvec_minmax,
61 		.strategy =	&sysctl_intvec,
62 		.extra1 =	&min_timer,
63 		.extra2 =	&max_timer,
64 	},
65         {
66 		.ctl_name =	NET_X25_ACK_HOLD_BACK_TIMEOUT,
67 		.procname =	"acknowledgement_hold_back_timeout",
68 		.data =		&sysctl_x25_ack_holdback_timeout,
69 		.maxlen =	sizeof(int),
70 		.mode =		0644,
71 		.proc_handler =	&proc_dointvec_minmax,
72 		.strategy =	&sysctl_intvec,
73 		.extra1 =	&min_timer,
74 		.extra2 =	&max_timer,
75 	},
76 	{ 0, },
77 };
78 
79 static struct ctl_table x25_dir_table[] = {
80 	{
81 		.ctl_name =	NET_X25,
82 		.procname =	"x25",
83 		.mode =		0555,
84 		.child =	x25_table,
85 	},
86 	{ 0, },
87 };
88 
89 static struct ctl_table x25_root_table[] = {
90 	{
91 		.ctl_name =	CTL_NET,
92 		.procname =	"net",
93 		.mode =		0555,
94 		.child =	x25_dir_table,
95 	},
96 	{ 0, },
97 };
98 
99 void __init x25_register_sysctl(void)
100 {
101 	x25_table_header = register_sysctl_table(x25_root_table, 1);
102 }
103 
104 void x25_unregister_sysctl(void)
105 {
106 	unregister_sysctl_table(x25_table_header);
107 }
108