blob: 92b3eaad60888963d3dce6a637f06582829ca883 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * INET An implementation of the TCP/IP protocol suite for the LINUX
3 * operating system. INET is implemented using the BSD Socket
4 * interface as the means of communication with the user level.
5 *
6 * Definitions for the protocol dispatcher.
7 *
8 * Version: @(#)protocol.h 1.0.2 05/07/93
9 *
10 * Author: Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
11 *
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation; either version
15 * 2 of the License, or (at your option) any later version.
16 *
17 * Changes:
18 * Alan Cox : Added a name field and a frag handler
19 * field for later.
20 * Alan Cox : Cleaned up, and sorted types.
21 * Pedro Roque : inet6 protocols
22 */
23
24#ifndef _PROTOCOL_H
25#define _PROTOCOL_H
26
Linus Torvalds1da177e2005-04-16 15:20:36 -070027#include <linux/in6.h>
Vlad Yasevichc6b641a2012-11-15 08:49:22 +000028#include <linux/skbuff.h>
Eric Dumazetdfd56b82011-12-10 09:48:31 +000029#if IS_ENABLED(CONFIG_IPV6)
Linus Torvalds1da177e2005-04-16 15:20:36 -070030#include <linux/ipv6.h>
31#endif
Vlad Yasevichf191a1d2012-11-15 08:49:23 +000032#include <linux/netdevice.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070033
David S. Millerf9242b62012-06-19 18:56:21 -070034/* This is one larger than the largest protocol value that can be
35 * found in an ipv4 or ipv6 header. Since in both cases the protocol
36 * value is presented in a __u8, this is defined to be 256.
37 */
38#define MAX_INET_PROTOS 256
Linus Torvalds1da177e2005-04-16 15:20:36 -070039
40/* This is used to register protocols. */
41struct net_protocol {
Paolo Abeni74874492017-09-28 15:51:36 +020042 int (*early_demux)(struct sk_buff *skb);
43 int (*early_demux_handler)(struct sk_buff *skb);
Linus Torvalds1da177e2005-04-16 15:20:36 -070044 int (*handler)(struct sk_buff *skb);
Stefano Brivio32bbd872018-11-08 12:19:21 +010045
46 /* This returns an error if we weren't able to handle the error. */
47 int (*err_handler)(struct sk_buff *skb, u32 info);
48
Denis V. Lunevf1450492008-03-24 15:33:00 -070049 unsigned int no_policy:1,
Hannes Frederic Sowa8ed1dc42014-01-09 10:01:17 +010050 netns_ok:1,
51 /* does the protocol do more stringent
52 * icmp tag validation than simple
53 * socket lookup?
54 */
55 icmp_strict_tag_validation:1;
Linus Torvalds1da177e2005-04-16 15:20:36 -070056};
57
Eric Dumazetdfd56b82011-12-10 09:48:31 +000058#if IS_ENABLED(CONFIG_IPV6)
Eric Dumazetfd2c3ef2009-11-03 03:26:03 +000059struct inet6_protocol {
Eric Dumazetc7109982012-07-26 12:18:11 +000060 void (*early_demux)(struct sk_buff *skb);
subashab@codeaurora.orgdddb64b2017-03-23 13:34:16 -060061 void (*early_demux_handler)(struct sk_buff *skb);
Herbert Xue5bbef22007-10-15 12:50:28 -070062 int (*handler)(struct sk_buff *skb);
Linus Torvalds1da177e2005-04-16 15:20:36 -070063
Stefano Brivio32bbd872018-11-08 12:19:21 +010064 /* This returns an error if we weren't able to handle the error. */
65 int (*err_handler)(struct sk_buff *skb,
Linus Torvalds1da177e2005-04-16 15:20:36 -070066 struct inet6_skb_parm *opt,
Brian Haleyd5fdd6b2009-06-23 04:31:07 -070067 u8 type, u8 code, int offset,
Al Viro04ce6902006-11-08 00:21:01 -080068 __be32 info);
Stefano Brivio32bbd872018-11-08 12:19:21 +010069
Linus Torvalds1da177e2005-04-16 15:20:36 -070070 unsigned int flags; /* INET6_PROTO_xxx */
71};
72
73#define INET6_PROTO_NOPOLICY 0x1
74#define INET6_PROTO_FINAL 0x2
75#endif
76
Vlad Yasevichde27d002012-11-15 08:49:12 +000077struct net_offload {
Vlad Yasevichf191a1d2012-11-15 08:49:23 +000078 struct offload_callbacks callbacks;
79 unsigned int flags; /* Flags used by IPv6 for now */
Vlad Yasevichde27d002012-11-15 08:49:12 +000080};
Vlad Yasevichc6b641a2012-11-15 08:49:22 +000081/* This should be set for any extension header which is compatible with GSO. */
82#define INET6_PROTO_GSO_EXTHDR 0x1
Vlad Yasevichde27d002012-11-15 08:49:12 +000083
Linus Torvalds1da177e2005-04-16 15:20:36 -070084/* This is used to register socket interfaces for IP protocols. */
85struct inet_protosw {
86 struct list_head list;
87
88 /* These two fields form the lookup key. */
89 unsigned short type; /* This is the 2nd argument to socket(2). */
Arnaldo Carvalho de Meloee41e2d2006-11-28 03:11:33 -020090 unsigned short protocol; /* This is the L4 protocol number. */
Linus Torvalds1da177e2005-04-16 15:20:36 -070091
92 struct proto *prot;
Eric Dumazet90ddc4f2005-12-22 12:49:22 -080093 const struct proto_ops *ops;
Linus Torvalds1da177e2005-04-16 15:20:36 -070094
Linus Torvalds1da177e2005-04-16 15:20:36 -070095 unsigned char flags; /* See INET_PROTOSW_* below. */
96};
97#define INET_PROTOSW_REUSE 0x01 /* Are ports automatically reusable? */
98#define INET_PROTOSW_PERMANENT 0x02 /* Permanent protocols are unremovable. */
Arnaldo Carvalho de Melod83d8462005-12-13 23:26:10 -080099#define INET_PROTOSW_ICSK 0x04 /* Is this an inet_connection_sock? */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700100
subashab@codeaurora.orgdddb64b2017-03-23 13:34:16 -0600101extern struct net_protocol __rcu *inet_protos[MAX_INET_PROTOS];
Vlad Yasevichde27d002012-11-15 08:49:12 +0000102extern const struct net_offload __rcu *inet_offloads[MAX_INET_PROTOS];
Vlad Yasevichc6b641a2012-11-15 08:49:22 +0000103extern const struct net_offload __rcu *inet6_offloads[MAX_INET_PROTOS];
Linus Torvalds1da177e2005-04-16 15:20:36 -0700104
Eric Dumazetdfd56b82011-12-10 09:48:31 +0000105#if IS_ENABLED(CONFIG_IPV6)
subashab@codeaurora.orgdddb64b2017-03-23 13:34:16 -0600106extern struct inet6_protocol __rcu *inet6_protos[MAX_INET_PROTOS];
Linus Torvalds1da177e2005-04-16 15:20:36 -0700107#endif
108
Joe Perchesf307c632013-09-22 10:32:17 -0700109int inet_add_protocol(const struct net_protocol *prot, unsigned char num);
110int inet_del_protocol(const struct net_protocol *prot, unsigned char num);
111int inet_add_offload(const struct net_offload *prot, unsigned char num);
112int inet_del_offload(const struct net_offload *prot, unsigned char num);
113void inet_register_protosw(struct inet_protosw *p);
114void inet_unregister_protosw(struct inet_protosw *p);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700115
Eric Dumazetdfd56b82011-12-10 09:48:31 +0000116#if IS_ENABLED(CONFIG_IPV6)
Joe Perchesf307c632013-09-22 10:32:17 -0700117int inet6_add_protocol(const struct inet6_protocol *prot, unsigned char num);
118int inet6_del_protocol(const struct inet6_protocol *prot, unsigned char num);
119int inet6_register_protosw(struct inet_protosw *p);
120void inet6_unregister_protosw(struct inet_protosw *p);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700121#endif
Joe Perchesf307c632013-09-22 10:32:17 -0700122int inet6_add_offload(const struct net_offload *prot, unsigned char num);
123int inet6_del_offload(const struct net_offload *prot, unsigned char num);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700124
125#endif /* _PROTOCOL_H */