2005-04-16 15:20:36 -07: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 08:49:22 +00:00
# include <linux/skbuff.h>
2011-12-10 09:48:31 +00:00
# if IS_ENABLED(CONFIG_IPV6)
2005-04-16 15:20:36 -07:00
# include <linux/ipv6.h>
# endif
2012-11-15 08:49:23 +00:00
# include <linux/netdevice.h>
2005-04-16 15:20:36 -07:00
2012-06-19 18:56:21 -07: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-16 15:20:36 -07:00
/* This is used to register protocols. */
struct net_protocol {
2017-09-28 15:51:36 +02:00
int ( * early_demux ) ( struct sk_buff * skb ) ;
int ( * early_demux_handler ) ( struct sk_buff * skb ) ;
2005-04-16 15:20:36 -07:00
int ( * handler ) ( struct sk_buff * skb ) ;
2018-11-08 12:19:21 +01: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-24 15:33:00 -07:00
unsigned int no_policy : 1 ,
2014-01-09 10:01:17 +01:00
netns_ok : 1 ,
/* does the protocol do more stringent
* icmp tag validation than simple
* socket lookup ?
*/
icmp_strict_tag_validation : 1 ;
2005-04-16 15:20:36 -07:00
} ;
2011-12-10 09:48:31 +00:00
# if IS_ENABLED(CONFIG_IPV6)
2009-11-03 03:26:03 +00:00
struct inet6_protocol {
2012-07-26 12:18:11 +00:00
void ( * early_demux ) ( struct sk_buff * skb ) ;
2017-03-23 13:34:16 -06:00
void ( * early_demux_handler ) ( struct sk_buff * skb ) ;
2007-10-15 12:50:28 -07:00
int ( * handler ) ( struct sk_buff * skb ) ;
2005-04-16 15:20:36 -07:00
2018-11-08 12:19:21 +01:00
/* This returns an error if we weren't able to handle the error. */
int ( * err_handler ) ( struct sk_buff * skb ,
2005-04-16 15:20:36 -07:00
struct inet6_skb_parm * opt ,
2009-06-23 04:31:07 -07:00
u8 type , u8 code , int offset ,
2006-11-08 00:21:01 -08:00
__be32 info ) ;
2018-11-08 12:19:21 +01:00
2005-04-16 15:20:36 -07:00
unsigned int flags ; /* INET6_PROTO_xxx */
} ;
# define INET6_PROTO_NOPOLICY 0x1
# define INET6_PROTO_FINAL 0x2
# endif
2012-11-15 08:49:12 +00:00
struct net_offload {
2012-11-15 08:49:23 +00:00
struct offload_callbacks callbacks ;
unsigned int flags ; /* Flags used by IPv6 for now */
2012-11-15 08:49:12 +00:00
} ;
2012-11-15 08:49:22 +00:00
/* This should be set for any extension header which is compatible with GSO. */
# define INET6_PROTO_GSO_EXTHDR 0x1
2012-11-15 08:49:12 +00:00
2005-04-16 15:20:36 -07: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 03:11:33 -02:00
unsigned short protocol ; /* This is the L4 protocol number. */
2005-04-16 15:20:36 -07:00
struct proto * prot ;
2005-12-22 12:49:22 -08:00
const struct proto_ops * ops ;
2005-04-16 15:20:36 -07: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-13 23:26:10 -08:00
# define INET_PROTOSW_ICSK 0x04 /* Is this an inet_connection_sock? */
2005-04-16 15:20:36 -07:00
2017-03-23 13:34:16 -06:00
extern struct net_protocol __rcu * inet_protos [ MAX_INET_PROTOS ] ;
2012-11-15 08:49:12 +00:00
extern const struct net_offload __rcu * inet_offloads [ MAX_INET_PROTOS ] ;
2012-11-15 08:49:22 +00:00
extern const struct net_offload __rcu * inet6_offloads [ MAX_INET_PROTOS ] ;
2005-04-16 15:20:36 -07:00
2011-12-10 09:48:31 +00:00
# if IS_ENABLED(CONFIG_IPV6)
2017-03-23 13:34:16 -06:00
extern struct inet6_protocol __rcu * inet6_protos [ MAX_INET_PROTOS ] ;
2005-04-16 15:20:36 -07:00
# endif
2013-09-22 10:32:17 -07: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-16 15:20:36 -07:00
2011-12-10 09:48:31 +00:00
# if IS_ENABLED(CONFIG_IPV6)
2013-09-22 10:32:17 -07: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-16 15:20:36 -07:00
# endif
2013-09-22 10:32:17 -07: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-16 15:20:36 -07:00
# endif /* _PROTOCOL_H */