2006-11-27 22:10:57 +03:00
/*
* UDPLITE An implementation of the UDP - Lite protocol ( RFC 3828 ) .
*
* Authors : Gerrit Renker < gerrit @ erg . abdn . ac . uk >
*
* Changes :
* Fixes :
* This program is free software ; 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 of the License , or ( at your option ) any later version .
*/
2012-03-12 11:03:32 +04:00
# define pr_fmt(fmt) "UDPLite: " fmt
2011-07-15 19:47:34 +04:00
# include <linux/export.h>
2006-11-27 22:10:57 +03:00
# include "udp_impl.h"
2009-10-07 04:37:59 +04:00
struct udp_table udplite_table __read_mostly ;
2008-10-29 11:41:45 +03:00
EXPORT_SYMBOL ( udplite_table ) ;
2006-11-27 22:10:57 +03:00
2006-12-01 04:22:29 +03:00
static int udplite_rcv ( struct sk_buff * skb )
2006-11-27 22:10:57 +03:00
{
2008-10-29 11:41:45 +03:00
return __udp4_lib_rcv ( skb , & udplite_table , IPPROTO_UDPLITE ) ;
2006-11-27 22:10:57 +03:00
}
2006-12-01 04:22:29 +03:00
static void udplite_err ( struct sk_buff * skb , u32 info )
2006-11-27 22:10:57 +03:00
{
2008-10-29 11:41:45 +03:00
__udp4_lib_err ( skb , info , & udplite_table ) ;
2006-11-27 22:10:57 +03:00
}
2009-09-14 16:21:47 +04:00
static const struct net_protocol udplite_protocol = {
2006-11-27 22:10:57 +03:00
. handler = udplite_rcv ,
. err_handler = udplite_err ,
. no_policy = 1 ,
2008-03-25 01:34:06 +03:00
. netns_ok = 1 ,
2006-11-27 22:10:57 +03:00
} ;
struct proto udplite_prot = {
. name = " UDP-Lite " ,
. owner = THIS_MODULE ,
. close = udp_lib_close ,
. connect = ip4_datagram_connect ,
. disconnect = udp_disconnect ,
. ioctl = udp_ioctl ,
. init = udplite_sk_init ,
. destroy = udp_destroy_sock ,
. setsockopt = udp_setsockopt ,
. getsockopt = udp_getsockopt ,
. sendmsg = udp_sendmsg ,
. recvmsg = udp_recvmsg ,
. sendpage = udp_sendpage ,
2016-11-22 20:06:45 +03:00
. backlog_rcv = __udp_queue_rcv_skb ,
2006-11-27 22:10:57 +03:00
. hash = udp_lib_hash ,
. unhash = udp_lib_unhash ,
2008-03-23 02:51:21 +03:00
. get_port = udp_v4_get_port ,
2006-11-27 22:10:57 +03:00
. obj_size = sizeof ( struct udp_sock ) ,
2008-10-29 11:41:45 +03:00
. h . udp_table = & udplite_table ,
2006-11-27 22:10:57 +03:00
# ifdef CONFIG_COMPAT
. compat_setsockopt = compat_udp_setsockopt ,
. compat_getsockopt = compat_udp_getsockopt ,
# endif
} ;
2010-07-10 01:22:10 +04:00
EXPORT_SYMBOL ( udplite_prot ) ;
2006-11-27 22:10:57 +03:00
static struct inet_protosw udplite4_protosw = {
. type = SOCK_DGRAM ,
. protocol = IPPROTO_UDPLITE ,
. prot = & udplite_prot ,
. ops = & inet_dgram_ops ,
. flags = INET_PROTOSW_PERMANENT ,
} ;
# ifdef CONFIG_PROC_FS
2011-10-30 10:46:30 +04:00
static const struct file_operations udplite_afinfo_seq_fops = {
. owner = THIS_MODULE ,
. open = udp_seq_open ,
. read = seq_read ,
. llseek = seq_lseek ,
. release = seq_release_net
} ;
2006-11-27 22:10:57 +03:00
static struct udp_seq_afinfo udplite4_seq_afinfo = {
. name = " udplite " ,
. family = AF_INET ,
2008-10-29 11:41:45 +03:00
. udp_table = & udplite_table ,
2011-10-30 10:46:30 +04:00
. seq_fops = & udplite_afinfo_seq_fops ,
2008-03-29 04:24:26 +03:00
. seq_ops = {
. show = udp4_seq_show ,
} ,
2006-11-27 22:10:57 +03:00
} ;
2008-03-25 00:56:34 +03:00
2010-01-17 06:35:32 +03:00
static int __net_init udplite4_proc_init_net ( struct net * net )
2008-03-25 00:56:57 +03:00
{
return udp_proc_register ( net , & udplite4_seq_afinfo ) ;
}
2010-01-17 06:35:32 +03:00
static void __net_exit udplite4_proc_exit_net ( struct net * net )
2008-03-25 00:56:57 +03:00
{
udp_proc_unregister ( net , & udplite4_seq_afinfo ) ;
}
static struct pernet_operations udplite4_net_ops = {
. init = udplite4_proc_init_net ,
. exit = udplite4_proc_exit_net ,
} ;
2008-03-25 00:56:34 +03:00
static __init int udplite4_proc_init ( void )
{
2008-03-25 00:56:57 +03:00
return register_pernet_subsys ( & udplite4_net_ops ) ;
2008-03-25 00:56:34 +03:00
}
# else
static inline int udplite4_proc_init ( void )
{
return 0 ;
}
2006-11-27 22:10:57 +03:00
# endif
void __init udplite4_register ( void )
{
2009-10-07 04:37:59 +04:00
udp_table_init ( & udplite_table , " UDP-Lite " ) ;
2006-11-27 22:10:57 +03:00
if ( proto_register ( & udplite_prot , 1 ) )
goto out_register_err ;
if ( inet_add_protocol ( & udplite_protocol , IPPROTO_UDPLITE ) < 0 )
goto out_unregister_proto ;
inet_register_protosw ( & udplite4_protosw ) ;
2008-03-25 00:56:34 +03:00
if ( udplite4_proc_init ( ) )
2012-03-11 22:36:11 +04:00
pr_err ( " %s: Cannot register /proc! \n " , __func__ ) ;
2006-11-27 22:10:57 +03:00
return ;
out_unregister_proto :
proto_unregister ( & udplite_prot ) ;
out_register_err :
2012-03-11 22:36:11 +04:00
pr_crit ( " %s: Cannot add UDP-Lite protocol \n " , __func__ ) ;
2006-11-27 22:10:57 +03:00
}