13e504849SAndy Grover /*
23e504849SAndy Grover * Copyright (c) 2006 Oracle. All rights reserved.
33e504849SAndy Grover *
43e504849SAndy Grover * This software is available to you under a choice of one of two
53e504849SAndy Grover * licenses. You may choose to be licensed under the terms of the GNU
63e504849SAndy Grover * General Public License (GPL) Version 2, available from the file
73e504849SAndy Grover * COPYING in the main directory of this source tree, or the
83e504849SAndy Grover * OpenIB.org BSD license below:
93e504849SAndy Grover *
103e504849SAndy Grover * Redistribution and use in source and binary forms, with or
113e504849SAndy Grover * without modification, are permitted provided that the following
123e504849SAndy Grover * conditions are met:
133e504849SAndy Grover *
143e504849SAndy Grover * - Redistributions of source code must retain the above
153e504849SAndy Grover * copyright notice, this list of conditions and the following
163e504849SAndy Grover * disclaimer.
173e504849SAndy Grover *
183e504849SAndy Grover * - Redistributions in binary form must reproduce the above
193e504849SAndy Grover * copyright notice, this list of conditions and the following
203e504849SAndy Grover * disclaimer in the documentation and/or other materials
213e504849SAndy Grover * provided with the distribution.
223e504849SAndy Grover *
233e504849SAndy Grover * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
243e504849SAndy Grover * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
253e504849SAndy Grover * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
263e504849SAndy Grover * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
273e504849SAndy Grover * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
283e504849SAndy Grover * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
293e504849SAndy Grover * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
303e504849SAndy Grover * SOFTWARE.
313e504849SAndy Grover *
323e504849SAndy Grover */
333e504849SAndy Grover #include <linux/kernel.h>
343e504849SAndy Grover #include <linux/sysctl.h>
353e504849SAndy Grover #include <linux/proc_fs.h>
363e504849SAndy Grover
373e504849SAndy Grover #include "rds.h"
383e504849SAndy Grover
393e504849SAndy Grover static struct ctl_table_header *rds_sysctl_reg_table;
403e504849SAndy Grover
413e504849SAndy Grover static unsigned long rds_sysctl_reconnect_min = 1;
423e504849SAndy Grover static unsigned long rds_sysctl_reconnect_max = ~0UL;
433e504849SAndy Grover
443e504849SAndy Grover unsigned long rds_sysctl_reconnect_min_jiffies;
453e504849SAndy Grover unsigned long rds_sysctl_reconnect_max_jiffies = HZ;
463e504849SAndy Grover
473e504849SAndy Grover unsigned int rds_sysctl_max_unacked_packets = 8;
483e504849SAndy Grover unsigned int rds_sysctl_max_unacked_bytes = (16 << 20);
493e504849SAndy Grover
503e504849SAndy Grover unsigned int rds_sysctl_ping_enable = 1;
513e504849SAndy Grover
52fe2c6338SJoe Perches static struct ctl_table rds_sysctl_rds_table[] = {
533e504849SAndy Grover {
543e504849SAndy Grover .procname = "reconnect_min_delay_ms",
553e504849SAndy Grover .data = &rds_sysctl_reconnect_min_jiffies,
563e504849SAndy Grover .maxlen = sizeof(unsigned long),
573e504849SAndy Grover .mode = 0644,
586d456111SEric W. Biederman .proc_handler = proc_doulongvec_ms_jiffies_minmax,
593e504849SAndy Grover .extra1 = &rds_sysctl_reconnect_min,
603e504849SAndy Grover .extra2 = &rds_sysctl_reconnect_max_jiffies,
613e504849SAndy Grover },
623e504849SAndy Grover {
633e504849SAndy Grover .procname = "reconnect_max_delay_ms",
643e504849SAndy Grover .data = &rds_sysctl_reconnect_max_jiffies,
653e504849SAndy Grover .maxlen = sizeof(unsigned long),
663e504849SAndy Grover .mode = 0644,
676d456111SEric W. Biederman .proc_handler = proc_doulongvec_ms_jiffies_minmax,
683e504849SAndy Grover .extra1 = &rds_sysctl_reconnect_min_jiffies,
693e504849SAndy Grover .extra2 = &rds_sysctl_reconnect_max,
703e504849SAndy Grover },
713e504849SAndy Grover {
723e504849SAndy Grover .procname = "max_unacked_packets",
733e504849SAndy Grover .data = &rds_sysctl_max_unacked_packets,
74db27ebb1SSasha Levin .maxlen = sizeof(int),
753e504849SAndy Grover .mode = 0644,
766d456111SEric W. Biederman .proc_handler = proc_dointvec,
773e504849SAndy Grover },
783e504849SAndy Grover {
793e504849SAndy Grover .procname = "max_unacked_bytes",
803e504849SAndy Grover .data = &rds_sysctl_max_unacked_bytes,
81db27ebb1SSasha Levin .maxlen = sizeof(int),
823e504849SAndy Grover .mode = 0644,
836d456111SEric W. Biederman .proc_handler = proc_dointvec,
843e504849SAndy Grover },
853e504849SAndy Grover {
863e504849SAndy Grover .procname = "ping_enable",
873e504849SAndy Grover .data = &rds_sysctl_ping_enable,
883e504849SAndy Grover .maxlen = sizeof(int),
893e504849SAndy Grover .mode = 0644,
906d456111SEric W. Biederman .proc_handler = proc_dointvec,
913e504849SAndy Grover },
92f8572d8fSEric W. Biederman { }
933e504849SAndy Grover };
943e504849SAndy Grover
rds_sysctl_exit(void)953e504849SAndy Grover void rds_sysctl_exit(void)
963e504849SAndy Grover {
975dd3df10SEric W. Biederman unregister_net_sysctl_table(rds_sysctl_reg_table);
983e504849SAndy Grover }
993e504849SAndy Grover
rds_sysctl_init(void)100ef87b7eaSZach Brown int rds_sysctl_init(void)
1013e504849SAndy Grover {
1023e504849SAndy Grover rds_sysctl_reconnect_min = msecs_to_jiffies(1);
1033e504849SAndy Grover rds_sysctl_reconnect_min_jiffies = rds_sysctl_reconnect_min;
1043e504849SAndy Grover
105*5c3da57dSJoshua Houghton rds_sysctl_reg_table =
106*5c3da57dSJoshua Houghton register_net_sysctl(&init_net, "net/rds", rds_sysctl_rds_table);
1078690bfa1SAndy Grover if (!rds_sysctl_reg_table)
1083e504849SAndy Grover return -ENOMEM;
1093e504849SAndy Grover return 0;
1103e504849SAndy Grover }
111