blob: 227efa726acd21452ca70effd00213b436956ba4 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * sysctl_net_ipv6.c: sysctl interface to net IPV6 subsystem.
3 *
4 * Changes:
5 * YOSHIFUJI Hideaki @USAGI: added icmp sysctl table.
6 */
7
8#include <linux/mm.h>
9#include <linux/sysctl.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070010#include <linux/in6.h>
11#include <linux/ipv6.h>
12#include <net/ndisc.h>
13#include <net/ipv6.h>
14#include <net/addrconf.h>
Pavel Emelyanov04128f22007-10-15 02:33:45 -070015#include <net/inet_frag.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070016
Linus Torvalds1da177e2005-04-16 15:20:36 -070017static ctl_table ipv6_table[] = {
18 {
19 .ctl_name = NET_IPV6_ROUTE,
20 .procname = "route",
21 .maxlen = 0,
22 .mode = 0555,
23 .child = ipv6_route_table
24 },
25 {
26 .ctl_name = NET_IPV6_ICMP,
27 .procname = "icmp",
28 .maxlen = 0,
29 .mode = 0555,
30 .child = ipv6_icmp_table
31 },
32 {
33 .ctl_name = NET_IPV6_BINDV6ONLY,
34 .procname = "bindv6only",
35 .data = &sysctl_ipv6_bindv6only,
36 .maxlen = sizeof(int),
37 .mode = 0644,
38 .proc_handler = &proc_dointvec
39 },
40 {
41 .ctl_name = NET_IPV6_IP6FRAG_HIGH_THRESH,
42 .procname = "ip6frag_high_thresh",
Pavel Emelyanov04128f22007-10-15 02:33:45 -070043 .data = &ip6_frags_ctl.high_thresh,
Linus Torvalds1da177e2005-04-16 15:20:36 -070044 .maxlen = sizeof(int),
45 .mode = 0644,
46 .proc_handler = &proc_dointvec
47 },
48 {
49 .ctl_name = NET_IPV6_IP6FRAG_LOW_THRESH,
50 .procname = "ip6frag_low_thresh",
Pavel Emelyanov04128f22007-10-15 02:33:45 -070051 .data = &ip6_frags_ctl.low_thresh,
Linus Torvalds1da177e2005-04-16 15:20:36 -070052 .maxlen = sizeof(int),
53 .mode = 0644,
54 .proc_handler = &proc_dointvec
55 },
56 {
57 .ctl_name = NET_IPV6_IP6FRAG_TIME,
58 .procname = "ip6frag_time",
Pavel Emelyanov04128f22007-10-15 02:33:45 -070059 .data = &ip6_frags_ctl.timeout,
Linus Torvalds1da177e2005-04-16 15:20:36 -070060 .maxlen = sizeof(int),
61 .mode = 0644,
62 .proc_handler = &proc_dointvec_jiffies,
63 .strategy = &sysctl_jiffies,
64 },
65 {
66 .ctl_name = NET_IPV6_IP6FRAG_SECRET_INTERVAL,
67 .procname = "ip6frag_secret_interval",
Pavel Emelyanov04128f22007-10-15 02:33:45 -070068 .data = &ip6_frags_ctl.secret_interval,
Linus Torvalds1da177e2005-04-16 15:20:36 -070069 .maxlen = sizeof(int),
70 .mode = 0644,
71 .proc_handler = &proc_dointvec_jiffies,
72 .strategy = &sysctl_jiffies
73 },
74 {
75 .ctl_name = NET_IPV6_MLD_MAX_MSF,
76 .procname = "mld_max_msf",
77 .data = &sysctl_mld_max_msf,
78 .maxlen = sizeof(int),
79 .mode = 0644,
80 .proc_handler = &proc_dointvec
81 },
82 { .ctl_name = 0 }
83};
84
85static struct ctl_table_header *ipv6_sysctl_header;
86
87static ctl_table ipv6_net_table[] = {
88 {
89 .ctl_name = NET_IPV6,
90 .procname = "ipv6",
91 .mode = 0555,
92 .child = ipv6_table
93 },
YOSHIFUJI Hideaki1ab14572007-02-09 23:24:49 +090094 { .ctl_name = 0 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070095};
96
97static ctl_table ipv6_root_table[] = {
98 {
99 .ctl_name = CTL_NET,
100 .procname = "net",
101 .mode = 0555,
102 .child = ipv6_net_table
103 },
YOSHIFUJI Hideaki1ab14572007-02-09 23:24:49 +0900104 { .ctl_name = 0 }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700105};
106
107void ipv6_sysctl_register(void)
108{
Eric W. Biederman0b4d4142007-02-14 00:34:09 -0800109 ipv6_sysctl_header = register_sysctl_table(ipv6_root_table);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700110}
111
112void ipv6_sysctl_unregister(void)
113{
114 unregister_sysctl_table(ipv6_sysctl_header);
115}