2008-01-11 09:57:09 -05:00
/* SCTP kernel implementation
2005-04-16 15:20:36 -07:00
* ( C ) Copyright IBM Corp . 2002 , 2004
* Copyright ( c ) 2002 Intel Corp .
*
2008-01-11 09:57:09 -05:00
* This file is part of the SCTP kernel implementation
2005-04-16 15:20:36 -07:00
*
* Sysctl related interfaces for SCTP .
*
2008-01-11 09:57:09 -05:00
* This SCTP implementation is free software ;
2005-04-16 15:20:36 -07:00
* you can redistribute it and / or modify it under the terms of
* the GNU General Public License as published by
* the Free Software Foundation ; either version 2 , or ( at your option )
* any later version .
*
2008-01-11 09:57:09 -05:00
* This SCTP implementation is distributed in the hope that it
2005-04-16 15:20:36 -07:00
* will be useful , but WITHOUT ANY WARRANTY ; without even the implied
* * * * * * * * * * * * * * * * * * * * * * * * *
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE .
* See the GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with GNU CC ; see the file COPYING . If not , write to
* the Free Software Foundation , 59 Temple Place - Suite 330 ,
* Boston , MA 02111 - 1307 , USA .
*
* Please send any bug reports or fixes you make to the
* email address ( es ) :
2013-07-23 14:51:47 +02:00
* lksctp developers < linux - sctp @ vger . kernel . org >
2005-04-16 15:20:36 -07:00
*
* Written or modified by :
* Mingqin Liu < liuming @ us . ibm . com >
* Jon Grimm < jgrimm @ us . ibm . com >
* Ardelle Fan < ardelle . fan @ intel . com >
* Ryan Layer < rmlayer @ us . ibm . com >
* Sridhar Samudrala < sri @ us . ibm . com >
*/
# include <net/sctp/structs.h>
2005-09-05 18:07:42 -07:00
# include <net/sctp/sctp.h>
2005-04-16 15:20:36 -07:00
# include <linux/sysctl.h>
2006-08-22 13:29:17 -07:00
static int zero = 0 ;
static int one = 1 ;
static int timer_max = 86400000 ; /* ms in one day */
static int int_max = INT_MAX ;
2009-05-13 00:03:20 +02:00
static int sack_timer_min = 1 ;
static int sack_timer_max = 500 ;
2009-09-03 17:25:47 +05:30
static int addr_scope_max = 3 ; /* check sctp_scope_policy_t in include/net/sctp/constants.h for max entries */
2009-11-23 15:53:57 -05:00
static int rwnd_scale_max = 16 ;
2011-12-16 12:44:15 +00:00
static unsigned long max_autoclose_min = 0 ;
static unsigned long max_autoclose_max =
( MAX_SCHEDULE_TIMEOUT / HZ > UINT_MAX )
? UINT_MAX : MAX_SCHEDULE_TIMEOUT / HZ ;
2005-04-16 15:20:36 -07:00
2010-11-09 23:24:26 +00:00
extern long sysctl_sctp_mem [ 3 ] ;
2007-09-16 16:04:37 -07:00
extern int sysctl_sctp_rmem [ 3 ] ;
extern int sysctl_sctp_wmem [ 3 ] ;
2007-08-15 16:07:44 -07:00
2013-06-11 23:04:25 -07:00
static int proc_sctp_do_hmac_alg ( struct ctl_table * ctl ,
2012-10-24 09:20:03 +00:00
int write ,
void __user * buffer , size_t * lenp ,
loff_t * ppos ) ;
2013-06-11 23:04:25 -07:00
static struct ctl_table sctp_table [ ] = {
2012-08-07 07:29:57 +00:00
{
. procname = " sctp_mem " ,
. data = & sysctl_sctp_mem ,
. maxlen = sizeof ( sysctl_sctp_mem ) ,
. mode = 0644 ,
. proc_handler = proc_doulongvec_minmax
} ,
{
. procname = " sctp_rmem " ,
. data = & sysctl_sctp_rmem ,
. maxlen = sizeof ( sysctl_sctp_rmem ) ,
. mode = 0644 ,
. proc_handler = proc_dointvec ,
} ,
{
. procname = " sctp_wmem " ,
. data = & sysctl_sctp_wmem ,
. maxlen = sizeof ( sysctl_sctp_wmem ) ,
. mode = 0644 ,
. proc_handler = proc_dointvec ,
} ,
{ /* sentinel */ }
} ;
2013-06-11 23:04:25 -07:00
static struct ctl_table sctp_net_table [ ] = {
2005-04-16 15:20:36 -07:00
{
. procname = " rto_initial " ,
2012-08-07 07:29:57 +00:00
. data = & init_net . sctp . rto_initial ,
2006-08-22 13:29:17 -07:00
. maxlen = sizeof ( unsigned int ) ,
2005-04-16 15:20:36 -07:00
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec_minmax ,
2006-08-22 13:29:17 -07:00
. extra1 = & one ,
. extra2 = & timer_max
2005-04-16 15:20:36 -07:00
} ,
{
. procname = " rto_min " ,
2012-08-07 07:29:57 +00:00
. data = & init_net . sctp . rto_min ,
2006-08-22 13:29:17 -07:00
. maxlen = sizeof ( unsigned int ) ,
2005-04-16 15:20:36 -07:00
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec_minmax ,
2006-08-22 13:29:17 -07:00
. extra1 = & one ,
. extra2 = & timer_max
2005-04-16 15:20:36 -07:00
} ,
{
. procname = " rto_max " ,
2012-08-07 07:29:57 +00:00
. data = & init_net . sctp . rto_max ,
2006-08-22 13:29:17 -07:00
. maxlen = sizeof ( unsigned int ) ,
2005-04-16 15:20:36 -07:00
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec_minmax ,
2006-08-22 13:29:17 -07:00
. extra1 = & one ,
. extra2 = & timer_max
2005-04-16 15:20:36 -07:00
} ,
{
2012-08-07 07:29:57 +00:00
. procname = " rto_alpha_exp_divisor " ,
. data = & init_net . sctp . rto_alpha ,
. maxlen = sizeof ( int ) ,
. mode = 0444 ,
. proc_handler = proc_dointvec ,
} ,
{
. procname = " rto_beta_exp_divisor " ,
. data = & init_net . sctp . rto_beta ,
. maxlen = sizeof ( int ) ,
. mode = 0444 ,
. proc_handler = proc_dointvec ,
2005-04-16 15:20:36 -07:00
} ,
{
. procname = " max_burst " ,
2012-08-07 07:29:57 +00:00
. data = & init_net . sctp . max_burst ,
2005-04-16 15:20:36 -07:00
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec_minmax ,
2006-08-22 13:29:17 -07:00
. extra1 = & zero ,
. extra2 = & int_max
2005-04-16 15:20:36 -07:00
} ,
{
2012-08-07 07:29:57 +00:00
. procname = " cookie_preserve_enable " ,
. data = & init_net . sctp . cookie_preserve_enable ,
2005-04-16 15:20:36 -07:00
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
2012-08-07 07:29:57 +00:00
. proc_handler = proc_dointvec ,
} ,
2012-10-24 09:20:03 +00:00
{
. procname = " cookie_hmac_alg " ,
. maxlen = 8 ,
. mode = 0644 ,
. proc_handler = proc_sctp_do_hmac_alg ,
} ,
2012-08-07 07:29:57 +00:00
{
. procname = " valid_cookie_life " ,
. data = & init_net . sctp . valid_cookie_life ,
. maxlen = sizeof ( unsigned int ) ,
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec_minmax ,
2012-08-07 07:29:57 +00:00
. extra1 = & one ,
. extra2 = & timer_max
2005-04-16 15:20:36 -07:00
} ,
2005-04-28 12:02:04 -07:00
{
2012-08-07 07:29:57 +00:00
. procname = " sack_timeout " ,
. data = & init_net . sctp . sack_timeout ,
2005-04-28 12:02:04 -07:00
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
2012-08-07 07:29:57 +00:00
. proc_handler = proc_dointvec_minmax ,
. extra1 = & sack_timer_min ,
. extra2 = & sack_timer_max ,
2005-04-28 12:02:04 -07:00
} ,
2005-11-11 16:08:24 -08:00
{
2012-08-07 07:29:57 +00:00
. procname = " hb_interval " ,
. data = & init_net . sctp . hb_interval ,
. maxlen = sizeof ( unsigned int ) ,
2005-11-11 16:08:24 -08:00
. mode = 0644 ,
2012-08-07 07:29:57 +00:00
. proc_handler = proc_dointvec_minmax ,
. extra1 = & one ,
. extra2 = & timer_max
2005-11-11 16:08:24 -08:00
} ,
2005-04-16 15:20:36 -07:00
{
2012-08-07 07:29:57 +00:00
. procname = " association_max_retrans " ,
. data = & init_net . sctp . max_retrans_association ,
2005-04-16 15:20:36 -07:00
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec_minmax ,
2006-08-22 13:29:17 -07:00
. extra1 = & one ,
. extra2 = & int_max
2005-04-16 15:20:36 -07:00
} ,
2012-07-21 07:56:07 +00:00
{
2012-08-07 07:29:57 +00:00
. procname = " path_max_retrans " ,
. data = & init_net . sctp . max_retrans_path ,
2012-07-21 07:56:07 +00:00
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
. proc_handler = proc_dointvec_minmax ,
2012-08-07 07:29:57 +00:00
. extra1 = & one ,
2012-07-21 07:56:07 +00:00
. extra2 = & int_max
} ,
2005-04-16 15:20:36 -07:00
{
. procname = " max_init_retransmits " ,
2012-08-07 07:29:57 +00:00
. data = & init_net . sctp . max_retrans_init ,
2005-04-16 15:20:36 -07:00
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec_minmax ,
2006-08-22 13:29:17 -07:00
. extra1 = & one ,
. extra2 = & int_max
2005-04-16 15:20:36 -07:00
} ,
{
2012-08-07 07:29:57 +00:00
. procname = " pf_retrans " ,
. data = & init_net . sctp . pf_retrans ,
. maxlen = sizeof ( int ) ,
2005-04-16 15:20:36 -07:00
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec_minmax ,
2012-08-07 07:29:57 +00:00
. extra1 = & zero ,
. extra2 = & int_max
2005-04-16 15:20:36 -07:00
} ,
{
2012-08-07 07:29:57 +00:00
. procname = " sndbuf_policy " ,
. data = & init_net . sctp . sndbuf_policy ,
2006-01-17 11:55:17 -08:00
. maxlen = sizeof ( int ) ,
2005-04-16 15:20:36 -07:00
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec ,
2005-04-16 15:20:36 -07:00
} ,
{
2012-08-07 07:29:57 +00:00
. procname = " rcvbuf_policy " ,
. data = & init_net . sctp . rcvbuf_policy ,
2011-04-26 17:36:05 +09:00
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
. proc_handler = proc_dointvec ,
} ,
{
. procname = " default_auto_asconf " ,
2012-08-07 07:29:57 +00:00
. data = & init_net . sctp . default_auto_asconf ,
2005-04-16 15:20:36 -07:00
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec ,
2005-04-16 15:20:36 -07:00
} ,
{
2012-08-07 07:29:57 +00:00
. procname = " addip_enable " ,
. data = & init_net . sctp . addip_enable ,
2005-04-16 15:20:36 -07:00
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec ,
2005-04-16 15:20:36 -07:00
} ,
2005-06-28 13:24:23 -07:00
{
2012-08-07 07:29:57 +00:00
. procname = " addip_noauth_enable " ,
. data = & init_net . sctp . addip_noauth ,
2009-05-13 00:03:20 +02:00
. maxlen = sizeof ( int ) ,
2005-06-28 13:24:23 -07:00
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec ,
2007-08-15 16:07:44 -07:00
} ,
{
2012-08-07 07:29:57 +00:00
. procname = " prsctp_enable " ,
. data = & init_net . sctp . prsctp_enable ,
2007-09-16 19:31:35 -07:00
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec ,
2007-09-16 19:31:35 -07:00
} ,
2007-10-24 17:24:26 -04:00
{
2012-08-07 07:29:57 +00:00
. procname = " auth_enable " ,
. data = & init_net . sctp . auth_enable ,
2007-10-24 17:24:26 -04:00
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
2008-11-03 18:21:05 -08:00
. proc_handler = proc_dointvec ,
2007-10-24 17:24:26 -04:00
} ,
2009-09-03 17:25:47 +05:30
{
. procname = " addr_scope_policy " ,
2012-08-07 07:29:57 +00:00
. data = & init_net . sctp . scope_policy ,
2009-09-03 17:25:47 +05:30
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
2009-11-16 03:11:48 -08:00
. proc_handler = proc_dointvec_minmax ,
2009-09-03 17:25:47 +05:30
. extra1 = & zero ,
. extra2 = & addr_scope_max ,
} ,
2009-11-23 15:53:57 -05:00
{
. procname = " rwnd_update_shift " ,
2012-08-07 07:29:57 +00:00
. data = & init_net . sctp . rwnd_upd_shift ,
2009-11-23 15:53:57 -05:00
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
. proc_handler = & proc_dointvec_minmax ,
. extra1 = & one ,
. extra2 = & rwnd_scale_max ,
} ,
2011-12-16 12:44:15 +00:00
{
. procname = " max_autoclose " ,
2012-08-07 07:29:57 +00:00
. data = & init_net . sctp . max_autoclose ,
2011-12-16 12:44:15 +00:00
. maxlen = sizeof ( unsigned long ) ,
. mode = 0644 ,
. proc_handler = & proc_doulongvec_minmax ,
. extra1 = & max_autoclose_min ,
. extra2 = & max_autoclose_max ,
} ,
2013-08-09 13:09:41 -07:00
2009-12-08 07:55:01 -08:00
{ /* sentinel */ }
2005-04-16 15:20:36 -07:00
} ;
2013-06-11 23:04:25 -07:00
static int proc_sctp_do_hmac_alg ( struct ctl_table * ctl ,
2012-10-24 09:20:03 +00:00
int write ,
void __user * buffer , size_t * lenp ,
loff_t * ppos )
{
struct net * net = current - > nsproxy - > net_ns ;
char tmp [ 8 ] ;
2013-06-11 23:04:25 -07:00
struct ctl_table tbl ;
2012-10-24 09:20:03 +00:00
int ret ;
int changed = 0 ;
char * none = " none " ;
memset ( & tbl , 0 , sizeof ( struct ctl_table ) ) ;
if ( write ) {
tbl . data = tmp ;
tbl . maxlen = 8 ;
} else {
tbl . data = net - > sctp . sctp_hmac_alg ? : none ;
tbl . maxlen = strlen ( tbl . data ) ;
}
ret = proc_dostring ( & tbl , write , buffer , lenp , ppos ) ;
if ( write ) {
# ifdef CONFIG_CRYPTO_MD5
if ( ! strncmp ( tmp , " md5 " , 3 ) ) {
net - > sctp . sctp_hmac_alg = " md5 " ;
changed = 1 ;
}
# endif
# ifdef CONFIG_CRYPTO_SHA1
if ( ! strncmp ( tmp , " sha1 " , 4 ) ) {
net - > sctp . sctp_hmac_alg = " sha1 " ;
changed = 1 ;
}
# endif
if ( ! strncmp ( tmp , " none " , 4 ) ) {
net - > sctp . sctp_hmac_alg = NULL ;
changed = 1 ;
}
if ( ! changed )
ret = - EINVAL ;
}
return ret ;
}
2012-08-07 07:23:59 +00:00
int sctp_sysctl_net_register ( struct net * net )
{
struct ctl_table * table ;
2012-08-07 07:29:57 +00:00
int i ;
2012-08-07 07:23:59 +00:00
table = kmemdup ( sctp_net_table , sizeof ( sctp_net_table ) , GFP_KERNEL ) ;
if ( ! table )
return - ENOMEM ;
2012-08-07 07:29:57 +00:00
for ( i = 0 ; table [ i ] . data ; i + + )
table [ i ] . data + = ( char * ) ( & net - > sctp ) - ( char * ) & init_net . sctp ;
2012-08-07 07:23:59 +00:00
net - > sctp . sysctl_header = register_net_sysctl ( net , " net/sctp " , table ) ;
return 0 ;
}
void sctp_sysctl_net_unregister ( struct net * net )
{
2013-01-24 11:02:47 -05:00
struct ctl_table * table ;
table = net - > sctp . sysctl_header - > ctl_table_arg ;
2012-08-07 07:23:59 +00:00
unregister_net_sysctl_table ( net - > sctp . sysctl_header ) ;
2013-01-24 11:02:47 -05:00
kfree ( table ) ;
2012-08-07 07:23:59 +00:00
}
2005-04-16 15:20:36 -07:00
static struct ctl_table_header * sctp_sysctl_header ;
/* Sysctl registration. */
void sctp_sysctl_register ( void )
{
2012-04-19 13:44:49 +00:00
sctp_sysctl_header = register_net_sysctl ( & init_net , " net/sctp " , sctp_table ) ;
2005-04-16 15:20:36 -07:00
}
/* Sysctl deregistration. */
void sctp_sysctl_unregister ( void )
{
2012-04-19 13:24:33 +00:00
unregister_net_sysctl_table ( sctp_sysctl_header ) ;
2005-04-16 15:20:36 -07:00
}