blob: f713fbf34c230d93d25061ff7db3c04a5577d771 [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
Pavel Emelyanov3d7cc2b2008-01-09 00:33:11 -080085struct ctl_path net_ipv6_ctl_path[] = {
Pavel Emelyanov4d43b782007-12-05 01:44:02 -080086 { .procname = "net", .ctl_name = CTL_NET, },
87 { .procname = "ipv6", .ctl_name = NET_IPV6, },
88 { },
89};
Pavel Emelyanov3d7cc2b2008-01-09 00:33:11 -080090EXPORT_SYMBOL_GPL(net_ipv6_ctl_path);
Pavel Emelyanov4d43b782007-12-05 01:44:02 -080091
Linus Torvalds1da177e2005-04-16 15:20:36 -070092static struct ctl_table_header *ipv6_sysctl_header;
93
Daniel Lezcano291480c2008-01-10 02:47:55 -080094int ipv6_sysctl_register(void)
Linus Torvalds1da177e2005-04-16 15:20:36 -070095{
Pavel Emelyanov3d7cc2b2008-01-09 00:33:11 -080096 ipv6_sysctl_header = register_sysctl_paths(net_ipv6_ctl_path,
Daniel Lezcano291480c2008-01-10 02:47:55 -080097 ipv6_table);
98 if (!ipv6_sysctl_header)
99 return -ENOMEM;
100
101 return 0;
102
Linus Torvalds1da177e2005-04-16 15:20:36 -0700103}
104
105void ipv6_sysctl_unregister(void)
106{
107 unregister_sysctl_table(ipv6_sysctl_header);
108}