2005-04-17 02:20:36 +04:00
/*
* INET An implementation of the TCP / IP protocol suite for the LINUX
* operating system . INET is implemented using the BSD Socket
* interface as the means of communication with the user level .
*
* Definitions for the protocol dispatcher .
*
* Version : @ ( # ) protocol . h 1.0 .2 05 / 07 / 93
*
* Author : Fred N . van Kempen , < waltje @ uWalt . NL . Mugnet . ORG >
*
* 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 .
*
* Changes :
* Alan Cox : Added a name field and a frag handler
* field for later .
* Alan Cox : Cleaned up , and sorted types .
* Pedro Roque : inet6 protocols
*/
# ifndef _PROTOCOL_H
# define _PROTOCOL_H
# include <linux/in6.h>
2012-11-15 12:49:22 +04:00
# include <linux/skbuff.h>
2011-12-10 13:48:31 +04:00
# if IS_ENABLED(CONFIG_IPV6)
2005-04-17 02:20:36 +04:00
# include <linux/ipv6.h>
# endif
2012-11-15 12:49:23 +04:00
# include <linux/netdevice.h>
2005-04-17 02:20:36 +04:00
2012-06-20 05:56:21 +04:00
/* This is one larger than the largest protocol value that can be
* found in an ipv4 or ipv6 header . Since in both cases the protocol
* value is presented in a __u8 , this is defined to be 256.
*/
# define MAX_INET_PROTOS 256
2005-04-17 02:20:36 +04:00
/* This is used to register protocols. */
struct net_protocol {
2017-09-28 16:51:36 +03:00
int ( * early_demux ) ( struct sk_buff * skb ) ;
int ( * early_demux_handler ) ( struct sk_buff * skb ) ;
2005-04-17 02:20:36 +04:00
int ( * handler ) ( struct sk_buff * skb ) ;
2018-11-08 14:19:21 +03:00
/* This returns an error if we weren't able to handle the error. */
int ( * err_handler ) ( struct sk_buff * skb , u32 info ) ;
2008-03-25 01:33:00 +03:00
unsigned int no_policy : 1 ,
2014-01-09 13:01:17 +04:00
netns_ok : 1 ,
/* does the protocol do more stringent
* icmp tag validation than simple
* socket lookup ?
*/
icmp_strict_tag_validation : 1 ;
2005-04-17 02:20:36 +04:00
} ;
2011-12-10 13:48:31 +04:00
# if IS_ENABLED(CONFIG_IPV6)
2009-11-03 06:26:03 +03:00
struct inet6_protocol {
2012-07-26 16:18:11 +04:00
void ( * early_demux ) ( struct sk_buff * skb ) ;
2017-03-23 22:34:16 +03:00
void ( * early_demux_handler ) ( struct sk_buff * skb ) ;
2007-10-15 23:50:28 +04:00
int ( * handler ) ( struct sk_buff * skb ) ;
2005-04-17 02:20:36 +04:00
2018-11-08 14:19:21 +03:00
/* This returns an error if we weren't able to handle the error. */
int ( * err_handler ) ( struct sk_buff * skb ,
2005-04-17 02:20:36 +04:00
struct inet6_skb_parm * opt ,
2009-06-23 15:31:07 +04:00
u8 type , u8 code , int offset ,
2006-11-08 11:21:01 +03:00
__be32 info ) ;
2018-11-08 14:19:21 +03:00
2005-04-17 02:20:36 +04:00
unsigned int flags ; /* INET6_PROTO_xxx */
} ;
# define INET6_PROTO_NOPOLICY 0x1
# define INET6_PROTO_FINAL 0x2
# endif
2012-11-15 12:49:12 +04:00
struct net_offload {
2012-11-15 12:49:23 +04:00
struct offload_callbacks callbacks ;
unsigned int flags ; /* Flags used by IPv6 for now */
2012-11-15 12:49:12 +04:00
} ;
2012-11-15 12:49:22 +04:00
/* This should be set for any extension header which is compatible with GSO. */
# define INET6_PROTO_GSO_EXTHDR 0x1
2012-11-15 12:49:12 +04:00
2005-04-17 02:20:36 +04:00
/* This is used to register socket interfaces for IP protocols. */
struct inet_protosw {
struct list_head list ;
/* These two fields form the lookup key. */
unsigned short type ; /* This is the 2nd argument to socket(2). */
2006-11-28 08:11:33 +03:00
unsigned short protocol ; /* This is the L4 protocol number. */
2005-04-17 02:20:36 +04:00
struct proto * prot ;
2005-12-22 23:49:22 +03:00
const struct proto_ops * ops ;
2005-04-17 02:20:36 +04:00
unsigned char flags ; /* See INET_PROTOSW_* below. */
} ;
# define INET_PROTOSW_REUSE 0x01 /* Are ports automatically reusable? */
# define INET_PROTOSW_PERMANENT 0x02 /* Permanent protocols are unremovable. */
2005-12-14 10:26:10 +03:00
# define INET_PROTOSW_ICSK 0x04 /* Is this an inet_connection_sock? */
2005-04-17 02:20:36 +04:00
2017-03-23 22:34:16 +03:00
extern struct net_protocol __rcu * inet_protos [ MAX_INET_PROTOS ] ;
2012-11-15 12:49:12 +04:00
extern const struct net_offload __rcu * inet_offloads [ MAX_INET_PROTOS ] ;
2012-11-15 12:49:22 +04:00
extern const struct net_offload __rcu * inet6_offloads [ MAX_INET_PROTOS ] ;
2005-04-17 02:20:36 +04:00
2011-12-10 13:48:31 +04:00
# if IS_ENABLED(CONFIG_IPV6)
2017-03-23 22:34:16 +03:00
extern struct inet6_protocol __rcu * inet6_protos [ MAX_INET_PROTOS ] ;
2005-04-17 02:20:36 +04:00
# endif
2013-09-22 21:32:17 +04:00
int inet_add_protocol ( const struct net_protocol * prot , unsigned char num ) ;
int inet_del_protocol ( const struct net_protocol * prot , unsigned char num ) ;
int inet_add_offload ( const struct net_offload * prot , unsigned char num ) ;
int inet_del_offload ( const struct net_offload * prot , unsigned char num ) ;
void inet_register_protosw ( struct inet_protosw * p ) ;
void inet_unregister_protosw ( struct inet_protosw * p ) ;
2005-04-17 02:20:36 +04:00
2011-12-10 13:48:31 +04:00
# if IS_ENABLED(CONFIG_IPV6)
2013-09-22 21:32:17 +04:00
int inet6_add_protocol ( const struct inet6_protocol * prot , unsigned char num ) ;
int inet6_del_protocol ( const struct inet6_protocol * prot , unsigned char num ) ;
int inet6_register_protosw ( struct inet_protosw * p ) ;
void inet6_unregister_protosw ( struct inet_protosw * p ) ;
2005-04-17 02:20:36 +04:00
# endif
2013-09-22 21:32:17 +04:00
int inet6_add_offload ( const struct net_offload * prot , unsigned char num ) ;
int inet6_del_offload ( const struct net_offload * prot , unsigned char num ) ;
2005-04-17 02:20:36 +04:00
# endif /* _PROTOCOL_H */