blob: 708f5df6b7f08e7217ce7a1f2a89f83b856b1ddd [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * NET4: Sysctl interface to net af_unix subsystem.
3 *
4 * Authors: Mike Shaver.
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version
9 * 2 of the License, or (at your option) any later version.
10 */
11
12#include <linux/mm.h>
13#include <linux/sysctl.h>
14
Arnaldo Carvalho de Melo20380732005-08-16 02:18:02 -030015#include <net/af_unix.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070016
17static ctl_table unix_table[] = {
18 {
Linus Torvalds1da177e2005-04-16 15:20:36 -070019 .procname = "max_dgram_qlen",
Denis V. Luneva0a53c82007-12-11 04:19:17 -080020 .data = &init_net.unx.sysctl_max_dgram_qlen,
Linus Torvalds1da177e2005-04-16 15:20:36 -070021 .maxlen = sizeof(int),
22 .mode = 0644,
Alexey Dobriyan6d9f2392008-11-03 18:21:05 -080023 .proc_handler = proc_dointvec
Linus Torvalds1da177e2005-04-16 15:20:36 -070024 },
Eric W. Biedermanf8572d82009-11-05 13:32:03 -080025 { }
Linus Torvalds1da177e2005-04-16 15:20:36 -070026};
27
Pavel Emelyanov1d430b92007-12-01 23:45:41 +110028static struct ctl_path unix_path[] = {
Eric W. Biedermanf8572d82009-11-05 13:32:03 -080029 { .procname = "net", },
30 { .procname = "unix", },
Pavel Emelyanov1d430b92007-12-01 23:45:41 +110031 { },
Linus Torvalds1da177e2005-04-16 15:20:36 -070032};
33
Pavel Emelyanov97577e32007-12-01 23:40:40 +110034int unix_sysctl_register(struct net *net)
Linus Torvalds1da177e2005-04-16 15:20:36 -070035{
Pavel Emelyanov1597fbc2007-12-01 23:51:01 +110036 struct ctl_table *table;
37
38 table = kmemdup(unix_table, sizeof(unix_table), GFP_KERNEL);
39 if (table == NULL)
40 goto err_alloc;
41
Denis V. Luneva0a53c82007-12-11 04:19:17 -080042 table[0].data = &net->unx.sysctl_max_dgram_qlen;
43 net->unx.ctl = register_net_sysctl_table(net, unix_path, table);
44 if (net->unx.ctl == NULL)
Pavel Emelyanov1597fbc2007-12-01 23:51:01 +110045 goto err_reg;
46
47 return 0;
48
49err_reg:
50 kfree(table);
51err_alloc:
52 return -ENOMEM;
Linus Torvalds1da177e2005-04-16 15:20:36 -070053}
54
Pavel Emelyanov97577e32007-12-01 23:40:40 +110055void unix_sysctl_unregister(struct net *net)
Linus Torvalds1da177e2005-04-16 15:20:36 -070056{
Pavel Emelyanov1597fbc2007-12-01 23:51:01 +110057 struct ctl_table *table;
58
Denis V. Luneva0a53c82007-12-11 04:19:17 -080059 table = net->unx.ctl->ctl_table_arg;
60 unregister_sysctl_table(net->unx.ctl);
Pavel Emelyanov1597fbc2007-12-01 23:51:01 +110061 kfree(table);
Linus Torvalds1da177e2005-04-16 15:20:36 -070062}