2 * This program is free software; you can redistribute it and/or modify
3 * it under the terms of the GNU General Public License as published by
4 * the Free Software Foundation; either version 2 of the License, or
5 * (at your option) any later version.
7 * Copyright (C) 1996 Mike Shaver (shaver@zeroknowledge.com)
10 #include <linux/sysctl.h>
11 #include <linux/init.h>
13 #include <net/netrom.h>
16 * Values taken from NET/ROM documentation.
18 static int min_quality[] = {0}, max_quality[] = {255};
19 static int min_obs[] = {0}, max_obs[] = {255};
20 static int min_ttl[] = {0}, max_ttl[] = {255};
21 static int min_t1[] = {5 * HZ};
22 static int max_t1[] = {600 * HZ};
23 static int min_n2[] = {2}, max_n2[] = {127};
24 static int min_t2[] = {1 * HZ};
25 static int max_t2[] = {60 * HZ};
26 static int min_t4[] = {1 * HZ};
27 static int max_t4[] = {1000 * HZ};
28 static int min_window[] = {1}, max_window[] = {127};
29 static int min_idle[] = {0 * HZ};
30 static int max_idle[] = {65535 * HZ};
31 static int min_route[] = {0}, max_route[] = {1};
32 static int min_fails[] = {1}, max_fails[] = {10};
33 static int min_reset[] = {0}, max_reset[] = {1};
35 static struct ctl_table_header *nr_table_header;
37 static ctl_table nr_table[] = {
39 .ctl_name = NET_NETROM_DEFAULT_PATH_QUALITY,
40 .procname = "default_path_quality",
41 .data = &sysctl_netrom_default_path_quality,
42 .maxlen = sizeof(int),
44 .proc_handler = &proc_dointvec_minmax,
45 .strategy = &sysctl_intvec,
46 .extra1 = &min_quality,
47 .extra2 = &max_quality
50 .ctl_name = NET_NETROM_OBSOLESCENCE_COUNT_INITIALISER,
51 .procname = "obsolescence_count_initialiser",
52 .data = &sysctl_netrom_obsolescence_count_initialiser,
53 .maxlen = sizeof(int),
55 .proc_handler = &proc_dointvec_minmax,
56 .strategy = &sysctl_intvec,
61 .ctl_name = NET_NETROM_NETWORK_TTL_INITIALISER,
62 .procname = "network_ttl_initialiser",
63 .data = &sysctl_netrom_network_ttl_initialiser,
64 .maxlen = sizeof(int),
66 .proc_handler = &proc_dointvec_minmax,
67 .strategy = &sysctl_intvec,
72 .ctl_name = NET_NETROM_TRANSPORT_TIMEOUT,
73 .procname = "transport_timeout",
74 .data = &sysctl_netrom_transport_timeout,
75 .maxlen = sizeof(int),
77 .proc_handler = &proc_dointvec_minmax,
78 .strategy = &sysctl_intvec,
83 .ctl_name = NET_NETROM_TRANSPORT_MAXIMUM_TRIES,
84 .procname = "transport_maximum_tries",
85 .data = &sysctl_netrom_transport_maximum_tries,
86 .maxlen = sizeof(int),
88 .proc_handler = &proc_dointvec_minmax,
89 .strategy = &sysctl_intvec,
94 .ctl_name = NET_NETROM_TRANSPORT_ACKNOWLEDGE_DELAY,
95 .procname = "transport_acknowledge_delay",
96 .data = &sysctl_netrom_transport_acknowledge_delay,
97 .maxlen = sizeof(int),
99 .proc_handler = &proc_dointvec_minmax,
100 .strategy = &sysctl_intvec,
105 .ctl_name = NET_NETROM_TRANSPORT_BUSY_DELAY,
106 .procname = "transport_busy_delay",
107 .data = &sysctl_netrom_transport_busy_delay,
108 .maxlen = sizeof(int),
110 .proc_handler = &proc_dointvec_minmax,
111 .strategy = &sysctl_intvec,
116 .ctl_name = NET_NETROM_TRANSPORT_REQUESTED_WINDOW_SIZE,
117 .procname = "transport_requested_window_size",
118 .data = &sysctl_netrom_transport_requested_window_size,
119 .maxlen = sizeof(int),
121 .proc_handler = &proc_dointvec_minmax,
122 .strategy = &sysctl_intvec,
123 .extra1 = &min_window,
124 .extra2 = &max_window
127 .ctl_name = NET_NETROM_TRANSPORT_NO_ACTIVITY_TIMEOUT,
128 .procname = "transport_no_activity_timeout",
129 .data = &sysctl_netrom_transport_no_activity_timeout,
130 .maxlen = sizeof(int),
132 .proc_handler = &proc_dointvec_minmax,
133 .strategy = &sysctl_intvec,
138 .ctl_name = NET_NETROM_ROUTING_CONTROL,
139 .procname = "routing_control",
140 .data = &sysctl_netrom_routing_control,
141 .maxlen = sizeof(int),
143 .proc_handler = &proc_dointvec_minmax,
144 .strategy = &sysctl_intvec,
145 .extra1 = &min_route,
149 .ctl_name = NET_NETROM_LINK_FAILS_COUNT,
150 .procname = "link_fails_count",
151 .data = &sysctl_netrom_link_fails_count,
152 .maxlen = sizeof(int),
154 .proc_handler = &proc_dointvec_minmax,
155 .strategy = &sysctl_intvec,
156 .extra1 = &min_fails,
160 .ctl_name = NET_NETROM_RESET,
162 .data = &sysctl_netrom_reset_circuit,
163 .maxlen = sizeof(int),
165 .proc_handler = &proc_dointvec_minmax,
166 .strategy = &sysctl_intvec,
167 .extra1 = &min_reset,
173 static ctl_table nr_dir_table[] = {
175 .ctl_name = NET_NETROM,
176 .procname = "netrom",
183 static ctl_table nr_root_table[] = {
188 .child = nr_dir_table
193 void __init nr_register_sysctl(void)
195 nr_table_header = register_sysctl_table(nr_root_table, 1);
198 void nr_unregister_sysctl(void)
200 unregister_sysctl_table(nr_table_header);