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