mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-09 11:00:52 +00:00
5dd3df105b
This makes it clearer which sysctls are relative to your current network namespace. This makes it a little less error prone by not exposing sysctls for the initial network namespace in other namespaces. This is the same way we handle all of our other network interfaces to userspace and I can't honestly remember why we didn't do this for sysctls right from the start. Signed-off-by: Eric W. Biederman <ebiederm@xmission.com> Acked-by: Pavel Emelyanov <xemul@parallels.com> Signed-off-by: David S. Miller <davem@davemloft.net>
91 lines
2.0 KiB
C
91 lines
2.0 KiB
C
/* -*- linux-c -*-
|
|
* sysctl_net_x25.c: sysctl interface to net X.25 subsystem.
|
|
*
|
|
* Begun April 1, 1996, Mike Shaver.
|
|
* Added /proc/sys/net/x25 directory entry (empty =) ). [MS]
|
|
*/
|
|
|
|
#include <linux/sysctl.h>
|
|
#include <linux/skbuff.h>
|
|
#include <linux/socket.h>
|
|
#include <linux/netdevice.h>
|
|
#include <linux/init.h>
|
|
#include <net/x25.h>
|
|
|
|
static int min_timer[] = { 1 * HZ };
|
|
static int max_timer[] = { 300 * HZ };
|
|
|
|
static struct ctl_table_header *x25_table_header;
|
|
|
|
static struct ctl_table x25_table[] = {
|
|
{
|
|
.procname = "restart_request_timeout",
|
|
.data = &sysctl_x25_restart_request_timeout,
|
|
.maxlen = sizeof(int),
|
|
.mode = 0644,
|
|
.proc_handler = proc_dointvec_minmax,
|
|
.extra1 = &min_timer,
|
|
.extra2 = &max_timer,
|
|
},
|
|
{
|
|
.procname = "call_request_timeout",
|
|
.data = &sysctl_x25_call_request_timeout,
|
|
.maxlen = sizeof(int),
|
|
.mode = 0644,
|
|
.proc_handler = proc_dointvec_minmax,
|
|
.extra1 = &min_timer,
|
|
.extra2 = &max_timer,
|
|
},
|
|
{
|
|
.procname = "reset_request_timeout",
|
|
.data = &sysctl_x25_reset_request_timeout,
|
|
.maxlen = sizeof(int),
|
|
.mode = 0644,
|
|
.proc_handler = proc_dointvec_minmax,
|
|
.extra1 = &min_timer,
|
|
.extra2 = &max_timer,
|
|
},
|
|
{
|
|
.procname = "clear_request_timeout",
|
|
.data = &sysctl_x25_clear_request_timeout,
|
|
.maxlen = sizeof(int),
|
|
.mode = 0644,
|
|
.proc_handler = proc_dointvec_minmax,
|
|
.extra1 = &min_timer,
|
|
.extra2 = &max_timer,
|
|
},
|
|
{
|
|
.procname = "acknowledgement_hold_back_timeout",
|
|
.data = &sysctl_x25_ack_holdback_timeout,
|
|
.maxlen = sizeof(int),
|
|
.mode = 0644,
|
|
.proc_handler = proc_dointvec_minmax,
|
|
.extra1 = &min_timer,
|
|
.extra2 = &max_timer,
|
|
},
|
|
{
|
|
.procname = "x25_forward",
|
|
.data = &sysctl_x25_forward,
|
|
.maxlen = sizeof(int),
|
|
.mode = 0644,
|
|
.proc_handler = proc_dointvec,
|
|
},
|
|
{ 0, },
|
|
};
|
|
|
|
static struct ctl_path x25_path[] = {
|
|
{ .procname = "net", },
|
|
{ .procname = "x25", },
|
|
{ }
|
|
};
|
|
|
|
void __init x25_register_sysctl(void)
|
|
{
|
|
x25_table_header = register_net_sysctl_table(&init_net, x25_path, x25_table);
|
|
}
|
|
|
|
void x25_unregister_sysctl(void)
|
|
{
|
|
unregister_net_sysctl_table(x25_table_header);
|
|
}
|