2006-03-21 06:25:02 +03:00
/*
* net / dccp / sysctl . c
*
* An implementation of the DCCP protocol
* Arnaldo Carvalho de Melo < acme @ mandriva . com >
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License v2
* as published by the Free Software Foundation .
*/
# include <linux/mm.h>
# include <linux/sysctl.h>
2006-11-13 18:23:52 +03:00
# include "dccp.h"
2006-08-27 06:15:35 +04:00
# include "feat.h"
2006-03-21 06:25:02 +03:00
# ifndef CONFIG_SYSCTL
# error This file should not be compiled without CONFIG_SYSCTL defined
# endif
2009-01-17 02:36:32 +03:00
/* Boundary values */
static int zero = 0 ,
u8_max = 0xFF ;
2011-01-02 20:15:58 +03:00
static unsigned long seqw_min = DCCPF_SEQ_WMIN ,
seqw_max = 0xFFFFFFFF ; /* maximum on 32 bit */
2009-01-17 02:36:32 +03:00
2006-03-21 06:25:02 +03:00
static struct ctl_table dccp_default_table [ ] = {
{
. procname = " seq_window " ,
2009-01-17 02:36:32 +03:00
. data = & sysctl_dccp_sequence_window ,
. maxlen = sizeof ( sysctl_dccp_sequence_window ) ,
2006-03-21 06:25:02 +03:00
. mode = 0644 ,
2009-01-17 02:36:32 +03:00
. proc_handler = proc_doulongvec_minmax ,
. extra1 = & seqw_min , /* RFC 4340, 7.5.2 */
2011-01-02 20:15:58 +03:00
. extra2 = & seqw_max ,
2006-03-21 06:25:02 +03:00
} ,
{
. procname = " rx_ccid " ,
2009-01-17 02:36:32 +03:00
. data = & sysctl_dccp_rx_ccid ,
. maxlen = sizeof ( sysctl_dccp_rx_ccid ) ,
2006-03-21 06:25:02 +03:00
. mode = 0644 ,
2009-01-17 02:36:32 +03:00
. proc_handler = proc_dointvec_minmax ,
. extra1 = & zero ,
. extra2 = & u8_max , /* RFC 4340, 10. */
2006-03-21 06:25:02 +03:00
} ,
{
. procname = " tx_ccid " ,
2009-01-17 02:36:32 +03:00
. data = & sysctl_dccp_tx_ccid ,
. maxlen = sizeof ( sysctl_dccp_tx_ccid ) ,
2006-03-21 06:25:02 +03:00
. mode = 0644 ,
2009-01-17 02:36:32 +03:00
. proc_handler = proc_dointvec_minmax ,
. extra1 = & zero ,
. extra2 = & u8_max , /* RFC 4340, 10. */
2006-03-21 06:25:02 +03:00
} ,
2006-11-13 18:23:52 +03:00
{
. procname = " request_retries " ,
. data = & sysctl_dccp_request_retries ,
. maxlen = sizeof ( sysctl_dccp_request_retries ) ,
. mode = 0644 ,
2009-01-17 02:36:32 +03:00
. proc_handler = proc_dointvec_minmax ,
. extra1 = & zero ,
. extra2 = & u8_max ,
2006-11-13 18:23:52 +03:00
} ,
{
. procname = " retries1 " ,
. data = & sysctl_dccp_retries1 ,
. maxlen = sizeof ( sysctl_dccp_retries1 ) ,
. mode = 0644 ,
2009-01-17 02:36:32 +03:00
. proc_handler = proc_dointvec_minmax ,
. extra1 = & zero ,
. extra2 = & u8_max ,
2006-11-13 18:23:52 +03:00
} ,
{
. procname = " retries2 " ,
. data = & sysctl_dccp_retries2 ,
. maxlen = sizeof ( sysctl_dccp_retries2 ) ,
. mode = 0644 ,
2009-01-17 02:36:32 +03:00
. proc_handler = proc_dointvec_minmax ,
. extra1 = & zero ,
. extra2 = & u8_max ,
2006-11-13 18:23:52 +03:00
} ,
2006-11-21 00:19:32 +03:00
{
. procname = " tx_qlen " ,
. data = & sysctl_dccp_tx_qlen ,
. maxlen = sizeof ( sysctl_dccp_tx_qlen ) ,
. mode = 0644 ,
2009-01-17 02:36:32 +03:00
. proc_handler = proc_dointvec_minmax ,
. extra1 = & zero ,
2006-11-21 00:19:32 +03:00
} ,
2007-09-26 18:31:49 +04:00
{
. procname = " sync_ratelimit " ,
. data = & sysctl_dccp_sync_ratelimit ,
. maxlen = sizeof ( sysctl_dccp_sync_ratelimit ) ,
. mode = 0644 ,
. proc_handler = proc_dointvec_ms_jiffies ,
} ,
2006-11-21 00:19:32 +03:00
2009-11-06 00:32:03 +03:00
{ }
2006-03-21 06:25:02 +03:00
} ;
2008-01-09 11:30:05 +03:00
static struct ctl_path dccp_path [ ] = {
2009-11-06 00:32:03 +03:00
{ . procname = " net " , } ,
{ . procname = " dccp " , } ,
{ . procname = " default " , } ,
2008-01-09 11:30:05 +03:00
{ }
2006-03-21 06:25:02 +03:00
} ;
static struct ctl_table_header * dccp_table_header ;
int __init dccp_sysctl_init ( void )
{
2008-01-09 11:30:05 +03:00
dccp_table_header = register_sysctl_paths ( dccp_path ,
dccp_default_table ) ;
2006-03-21 06:25:02 +03:00
return dccp_table_header ! = NULL ? 0 : - ENOMEM ;
}
void dccp_sysctl_exit ( void )
{
if ( dccp_table_header ! = NULL ) {
unregister_sysctl_table ( dccp_table_header ) ;
dccp_table_header = NULL ;
}
}