blob: 2b778e1d2d8f1365c969952b9aed939e28cb80d7 [file] [log] [blame]
Thomas Gleixner2874c5f2019-05-27 08:55:01 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
3 * INET An implementation of the TCP/IP protocol suite for the LINUX
4 * operating system. INET is implemented using the BSD Socket
5 * interface as the means of communication with the user level.
6 *
7 * Definitions for the protocol dispatcher.
8 *
9 * Version: @(#)protocol.h 1.0.2 05/07/93
10 *
11 * Author: Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
12 *
Linus Torvalds1da177e2005-04-16 15:20:36 -070013 * Changes:
14 * Alan Cox : Added a name field and a frag handler
15 * field for later.
16 * Alan Cox : Cleaned up, and sorted types.
17 * Pedro Roque : inet6 protocols
18 */
19
20#ifndef _PROTOCOL_H
21#define _PROTOCOL_H
22
Linus Torvalds1da177e2005-04-16 15:20:36 -070023#include <linux/in6.h>
Vlad Yasevichc6b641a2012-11-15 08:49:22 +000024#include <linux/skbuff.h>
Eric Dumazetdfd56b82011-12-10 09:48:31 +000025#if IS_ENABLED(CONFIG_IPV6)
Linus Torvalds1da177e2005-04-16 15:20:36 -070026#include <linux/ipv6.h>
27#endif
Vlad Yasevichf191a1d2012-11-15 08:49:23 +000028#include <linux/netdevice.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070029
David S. Millerf9242b62012-06-19 18:56:21 -070030/* This is one larger than the largest protocol value that can be
31 * found in an ipv4 or ipv6 header. Since in both cases the protocol
32 * value is presented in a __u8, this is defined to be 256.
33 */
34#define MAX_INET_PROTOS 256
Linus Torvalds1da177e2005-04-16 15:20:36 -070035
36/* This is used to register protocols. */
37struct net_protocol {
Paolo Abeni74874492017-09-28 15:51:36 +020038 int (*early_demux)(struct sk_buff *skb);
39 int (*early_demux_handler)(struct sk_buff *skb);
Linus Torvalds1da177e2005-04-16 15:20:36 -070040 int (*handler)(struct sk_buff *skb);
Stefano Brivio32bbd872018-11-08 12:19:21 +010041
42 /* This returns an error if we weren't able to handle the error. */
43 int (*err_handler)(struct sk_buff *skb, u32 info);
44
Denis V. Lunevf1450492008-03-24 15:33:00 -070045 unsigned int no_policy:1,
Hannes Frederic Sowa8ed1dc42014-01-09 10:01:17 +010046 netns_ok:1,
47 /* does the protocol do more stringent
48 * icmp tag validation than simple
49 * socket lookup?
50 */
51 icmp_strict_tag_validation:1;
Linus Torvalds1da177e2005-04-16 15:20:36 -070052};
53
Eric Dumazetdfd56b82011-12-10 09:48:31 +000054#if IS_ENABLED(CONFIG_IPV6)
Eric Dumazetfd2c3ef2009-11-03 03:26:03 +000055struct inet6_protocol {
Eric Dumazetc7109982012-07-26 12:18:11 +000056 void (*early_demux)(struct sk_buff *skb);
subashab@codeaurora.orgdddb64b2017-03-23 13:34:16 -060057 void (*early_demux_handler)(struct sk_buff *skb);
Herbert Xue5bbef22007-10-15 12:50:28 -070058 int (*handler)(struct sk_buff *skb);
Linus Torvalds1da177e2005-04-16 15:20:36 -070059
Stefano Brivio32bbd872018-11-08 12:19:21 +010060 /* This returns an error if we weren't able to handle the error. */
61 int (*err_handler)(struct sk_buff *skb,
Linus Torvalds1da177e2005-04-16 15:20:36 -070062 struct inet6_skb_parm *opt,
Brian Haleyd5fdd6b2009-06-23 04:31:07 -070063 u8 type, u8 code, int offset,
Al Viro04ce6902006-11-08 00:21:01 -080064 __be32 info);
Stefano Brivio32bbd872018-11-08 12:19:21 +010065
Linus Torvalds1da177e2005-04-16 15:20:36 -070066 unsigned int flags; /* INET6_PROTO_xxx */
67};
68
69#define INET6_PROTO_NOPOLICY 0x1
70#define INET6_PROTO_FINAL 0x2
71#endif
72
Vlad Yasevichde27d002012-11-15 08:49:12 +000073struct net_offload {
Vlad Yasevichf191a1d2012-11-15 08:49:23 +000074 struct offload_callbacks callbacks;
75 unsigned int flags; /* Flags used by IPv6 for now */
Vlad Yasevichde27d002012-11-15 08:49:12 +000076};
Vlad Yasevichc6b641a2012-11-15 08:49:22 +000077/* This should be set for any extension header which is compatible with GSO. */
78#define INET6_PROTO_GSO_EXTHDR 0x1
Vlad Yasevichde27d002012-11-15 08:49:12 +000079
Linus Torvalds1da177e2005-04-16 15:20:36 -070080/* This is used to register socket interfaces for IP protocols. */
81struct inet_protosw {
82 struct list_head list;
83
84 /* These two fields form the lookup key. */
85 unsigned short type; /* This is the 2nd argument to socket(2). */
Arnaldo Carvalho de Meloee41e2d2006-11-28 03:11:33 -020086 unsigned short protocol; /* This is the L4 protocol number. */
Linus Torvalds1da177e2005-04-16 15:20:36 -070087
88 struct proto *prot;
Eric Dumazet90ddc4f2005-12-22 12:49:22 -080089 const struct proto_ops *ops;
Linus Torvalds1da177e2005-04-16 15:20:36 -070090
Linus Torvalds1da177e2005-04-16 15:20:36 -070091 unsigned char flags; /* See INET_PROTOSW_* below. */
92};
93#define INET_PROTOSW_REUSE 0x01 /* Are ports automatically reusable? */
94#define INET_PROTOSW_PERMANENT 0x02 /* Permanent protocols are unremovable. */
Arnaldo Carvalho de Melod83d8462005-12-13 23:26:10 -080095#define INET_PROTOSW_ICSK 0x04 /* Is this an inet_connection_sock? */
Linus Torvalds1da177e2005-04-16 15:20:36 -070096
subashab@codeaurora.orgdddb64b2017-03-23 13:34:16 -060097extern struct net_protocol __rcu *inet_protos[MAX_INET_PROTOS];
Vlad Yasevichde27d002012-11-15 08:49:12 +000098extern const struct net_offload __rcu *inet_offloads[MAX_INET_PROTOS];
Vlad Yasevichc6b641a2012-11-15 08:49:22 +000099extern const struct net_offload __rcu *inet6_offloads[MAX_INET_PROTOS];
Linus Torvalds1da177e2005-04-16 15:20:36 -0700100
Eric Dumazetdfd56b82011-12-10 09:48:31 +0000101#if IS_ENABLED(CONFIG_IPV6)
subashab@codeaurora.orgdddb64b2017-03-23 13:34:16 -0600102extern struct inet6_protocol __rcu *inet6_protos[MAX_INET_PROTOS];
Linus Torvalds1da177e2005-04-16 15:20:36 -0700103#endif
104
Joe Perchesf307c632013-09-22 10:32:17 -0700105int inet_add_protocol(const struct net_protocol *prot, unsigned char num);
106int inet_del_protocol(const struct net_protocol *prot, unsigned char num);
107int inet_add_offload(const struct net_offload *prot, unsigned char num);
108int inet_del_offload(const struct net_offload *prot, unsigned char num);
109void inet_register_protosw(struct inet_protosw *p);
110void inet_unregister_protosw(struct inet_protosw *p);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700111
Eric Dumazetdfd56b82011-12-10 09:48:31 +0000112#if IS_ENABLED(CONFIG_IPV6)
Joe Perchesf307c632013-09-22 10:32:17 -0700113int inet6_add_protocol(const struct inet6_protocol *prot, unsigned char num);
114int inet6_del_protocol(const struct inet6_protocol *prot, unsigned char num);
115int inet6_register_protosw(struct inet_protosw *p);
116void inet6_unregister_protosw(struct inet_protosw *p);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700117#endif
Joe Perchesf307c632013-09-22 10:32:17 -0700118int inet6_add_offload(const struct net_offload *prot, unsigned char num);
119int inet6_del_offload(const struct net_offload *prot, unsigned char num);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700120
121#endif /* _PROTOCOL_H */