2006-11-27 11:10:57 -08:00
/*
* UDPLITEv6 An implementation of the UDP - Lite protocol over IPv6 .
* See also net / ipv4 / udplite . c
*
* 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 .
*/
2011-07-15 11:47:34 -04:00
# include <linux/export.h>
2006-11-27 11:10:57 -08:00
# include "udp_impl.h"
2007-10-15 12:50:28 -07:00
static int udplitev6_rcv ( struct sk_buff * skb )
2006-11-27 11:10:57 -08:00
{
2008-10-29 01:41:45 -07:00
return __udp6_lib_rcv ( skb , & udplite_table , IPPROTO_UDPLITE ) ;
2006-11-27 11:10:57 -08:00
}
2006-11-30 17:22:29 -08:00
static void udplitev6_err ( struct sk_buff * skb ,
struct inet6_skb_parm * opt ,
2009-06-23 04:31:07 -07:00
u8 type , u8 code , int offset , __be32 info )
2006-11-27 11:10:57 -08:00
{
2008-10-29 01:41:45 -07:00
__udp6_lib_err ( skb , opt , type , code , offset , info , & udplite_table ) ;
2006-11-27 11:10:57 -08:00
}
2009-09-14 12:22:28 +00:00
static const struct inet6_protocol udplitev6_protocol = {
2006-11-27 11:10:57 -08:00
. handler = udplitev6_rcv ,
. err_handler = udplitev6_err ,
. flags = INET6_PROTO_NOPOLICY | INET6_PROTO_FINAL ,
} ;
struct proto udplitev6_prot = {
. name = " UDPLITEv6 " ,
. owner = THIS_MODULE ,
. close = udp_lib_close ,
. connect = ip6_datagram_connect ,
. disconnect = udp_disconnect ,
. ioctl = udp_ioctl ,
. init = udplite_sk_init ,
. destroy = udpv6_destroy_sock ,
. setsockopt = udpv6_setsockopt ,
. getsockopt = udpv6_getsockopt ,
. sendmsg = udpv6_sendmsg ,
. recvmsg = udpv6_recvmsg ,
. hash = udp_lib_hash ,
. unhash = udp_lib_unhash ,
2008-03-22 16:51:21 -07:00
. get_port = udp_v6_get_port ,
2016-11-15 16:37:53 +01:00
. memory_allocated = & udp_memory_allocated ,
. sysctl_mem = sysctl_udp_mem ,
2006-11-27 11:10:57 -08:00
. obj_size = sizeof ( struct udp6_sock ) ,
2008-10-29 01:41:45 -07:00
. h . udp_table = & udplite_table ,
2006-11-27 11:10:57 -08:00
# ifdef CONFIG_COMPAT
. compat_setsockopt = compat_udpv6_setsockopt ,
. compat_getsockopt = compat_udpv6_getsockopt ,
# endif
} ;
static struct inet_protosw udplite6_protosw = {
. type = SOCK_DGRAM ,
. protocol = IPPROTO_UDPLITE ,
. prot = & udplitev6_prot ,
. ops = & inet6_dgram_ops ,
. flags = INET_PROTOSW_PERMANENT ,
} ;
2007-12-11 02:25:35 -08:00
int __init udplitev6_init ( void )
2006-11-27 11:10:57 -08:00
{
2007-12-11 02:25:35 -08:00
int ret ;
2006-11-27 11:10:57 -08:00
2007-12-11 02:25:35 -08:00
ret = inet6_add_protocol ( & udplitev6_protocol , IPPROTO_UDPLITE ) ;
if ( ret )
goto out ;
ret = inet6_register_protosw ( & udplite6_protosw ) ;
if ( ret )
goto out_udplitev6_protocol ;
out :
return ret ;
out_udplitev6_protocol :
inet6_del_protocol ( & udplitev6_protocol , IPPROTO_UDPLITE ) ;
goto out ;
}
2007-12-13 05:34:58 -08:00
void udplitev6_exit ( void )
2007-12-11 02:25:35 -08:00
{
inet6_unregister_protosw ( & udplite6_protosw ) ;
inet6_del_protocol ( & udplitev6_protocol , IPPROTO_UDPLITE ) ;
2006-11-27 11:10:57 -08:00
}
# ifdef CONFIG_PROC_FS
2011-10-30 06:46:30 +00:00
static const struct file_operations udplite6_afinfo_seq_fops = {
. open = udp_seq_open ,
. read = seq_read ,
. llseek = seq_lseek ,
. release = seq_release_net
} ;
2006-11-27 11:10:57 -08:00
static struct udp_seq_afinfo udplite6_seq_afinfo = {
. name = " udplite6 " ,
. family = AF_INET6 ,
2008-10-29 01:41:45 -07:00
. udp_table = & udplite_table ,
2011-10-30 06:46:30 +00:00
. seq_fops = & udplite6_afinfo_seq_fops ,
2008-03-28 18:24:26 -07:00
. seq_ops = {
. show = udp6_seq_show ,
} ,
2006-11-27 11:10:57 -08:00
} ;
2010-01-17 03:35:32 +00:00
static int __net_init udplite6_proc_init_net ( struct net * net )
2008-03-24 14:56:57 -07:00
{
return udp_proc_register ( net , & udplite6_seq_afinfo ) ;
}
2010-01-17 03:35:32 +00:00
static void __net_exit udplite6_proc_exit_net ( struct net * net )
2008-03-24 14:56:57 -07:00
{
udp_proc_unregister ( net , & udplite6_seq_afinfo ) ;
}
static struct pernet_operations udplite6_net_ops = {
. init = udplite6_proc_init_net ,
. exit = udplite6_proc_exit_net ,
} ;
2006-11-27 11:10:57 -08:00
int __init udplite6_proc_init ( void )
{
2008-03-24 14:56:57 -07:00
return register_pernet_subsys ( & udplite6_net_ops ) ;
2006-11-27 11:10:57 -08:00
}
void udplite6_proc_exit ( void )
{
2008-03-24 14:56:57 -07:00
unregister_pernet_subsys ( & udplite6_net_ops ) ;
2006-11-27 11:10:57 -08:00
}
# endif