Merge tag 'rtc-6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/abelloni/linux
[linux-block.git] / include / net / flow_dissector.h
CommitLineData
b2441318 1/* SPDX-License-Identifier: GPL-2.0 */
1bd758eb
JP
2#ifndef _NET_FLOW_DISSECTOR_H
3#define _NET_FLOW_DISSECTOR_H
0744dd00 4
c3f8eaeb 5#include <linux/types.h>
b924933c 6#include <linux/in6.h>
55667441 7#include <linux/siphash.h>
8a9093c7 8#include <linux/string.h>
67a900cc 9#include <uapi/linux/if_ether.h>
c3f8eaeb 10
b27f7bb5
JS
11struct bpf_prog;
12struct net;
5dec597e
MC
13struct sk_buff;
14
42aecaa9
TH
15/**
16 * struct flow_dissector_key_control:
8c966a10
SH
17 * @thoff: Transport header offset
18 * @addr_type: Type of key. One of FLOW_DISSECTOR_KEY_*
19 * @flags: Key flags. Any of FLOW_DIS_(IS_FRAGMENT|FIRST_FRAGENCAPSULATION)
42aecaa9
TH
20 */
21struct flow_dissector_key_control {
22 u16 thoff;
c3f83241 23 u16 addr_type;
4b36993d 24 u32 flags;
42aecaa9
TH
25};
26
4b36993d
DM
27#define FLOW_DIS_IS_FRAGMENT BIT(0)
28#define FLOW_DIS_FIRST_FRAG BIT(1)
29#define FLOW_DIS_ENCAPSULATION BIT(2)
30
3a1214e8
TH
31enum flow_dissect_ret {
32 FLOW_DISSECT_RET_OUT_GOOD,
33 FLOW_DISSECT_RET_OUT_BAD,
34 FLOW_DISSECT_RET_PROTO_AGAIN,
35 FLOW_DISSECT_RET_IPPROTO_AGAIN,
36 FLOW_DISSECT_RET_CONTINUE,
37};
38
fbff949e
JP
39/**
40 * struct flow_dissector_key_basic:
8c966a10 41 * @n_proto: Network header protocol (eg. IPv4/IPv6)
fbff949e 42 * @ip_proto: Transport header protocol (eg. TCP/UDP)
8c966a10 43 * @padding: Unused
fbff949e
JP
44 */
45struct flow_dissector_key_basic {
fbff949e
JP
46 __be16 n_proto;
47 u8 ip_proto;
42aecaa9 48 u8 padding;
fbff949e
JP
49};
50
d34af823 51struct flow_dissector_key_tags {
f6a66927
HHZ
52 u32 flow_label;
53};
54
55struct flow_dissector_key_vlan {
a82055af 56 union {
d1746d1e
PM
57 struct {
58 u16 vlan_id:12,
59 vlan_dei:1,
60 vlan_priority:3;
61 };
a82055af
PNA
62 __be16 vlan_tci;
63 };
2064c3d4 64 __be16 vlan_tpid;
2105f700
VB
65 __be16 vlan_eth_type;
66 u16 padding;
d34af823
TH
67};
68
58cff782 69struct flow_dissector_mpls_lse {
029c1ecb
BL
70 u32 mpls_ttl:8,
71 mpls_bos:1,
72 mpls_tc:3,
73 mpls_label:20;
74};
75
58cff782
GN
76#define FLOW_DIS_MPLS_MAX 7
77struct flow_dissector_key_mpls {
78 struct flow_dissector_mpls_lse ls[FLOW_DIS_MPLS_MAX]; /* Label Stack */
79 u8 used_lses; /* One bit set for each Label Stack Entry in use */
80};
81
82static inline void dissector_set_mpls_lse(struct flow_dissector_key_mpls *mpls,
83 int lse_index)
84{
85 mpls->used_lses |= 1 << lse_index;
86}
87
92e2c405
SH
88#define FLOW_DIS_TUN_OPTS_MAX 255
89/**
90 * struct flow_dissector_key_enc_opts:
91 * @data: tunnel option data
92 * @len: length of tunnel option data
93 * @dst_opt_type: tunnel option type
94 */
95struct flow_dissector_key_enc_opts {
96 u8 data[FLOW_DIS_TUN_OPTS_MAX]; /* Using IP_TUNNEL_OPTS_MAX is desired
97 * here but seems difficult to #include
98 */
99 u8 len;
100 __be16 dst_opt_type;
101};
102
1fdd512c
TH
103struct flow_dissector_key_keyid {
104 __be32 keyid;
105};
106
fbff949e 107/**
c3f83241
TH
108 * struct flow_dissector_key_ipv4_addrs:
109 * @src: source ip address
110 * @dst: destination ip address
fbff949e 111 */
c3f83241 112struct flow_dissector_key_ipv4_addrs {
fbff949e
JP
113 /* (src,dst) must be grouped, in the same way than in IP header */
114 __be32 src;
115 __be32 dst;
116};
117
c3f83241
TH
118/**
119 * struct flow_dissector_key_ipv6_addrs:
120 * @src: source ip address
121 * @dst: destination ip address
122 */
123struct flow_dissector_key_ipv6_addrs {
124 /* (src,dst) must be grouped, in the same way than in IP header */
125 struct in6_addr src;
126 struct in6_addr dst;
127};
128
9f249089 129/**
8d6e79d3
JM
130 * struct flow_dissector_key_tipc:
131 * @key: source node address combined with selector
9f249089 132 */
8d6e79d3
JM
133struct flow_dissector_key_tipc {
134 __be32 key;
9f249089
TH
135};
136
c3f83241
TH
137/**
138 * struct flow_dissector_key_addrs:
139 * @v4addrs: IPv4 addresses
140 * @v6addrs: IPv6 addresses
8c966a10 141 * @tipckey: TIPC key
c3f83241
TH
142 */
143struct flow_dissector_key_addrs {
144 union {
145 struct flow_dissector_key_ipv4_addrs v4addrs;
146 struct flow_dissector_key_ipv6_addrs v6addrs;
8d6e79d3 147 struct flow_dissector_key_tipc tipckey;
c3f83241
TH
148 };
149};
150
55733350 151/**
8c966a10
SH
152 * struct flow_dissector_key_arp:
153 * @sip: Sender IP address
154 * @tip: Target IP address
155 * @op: Operation
156 * @sha: Sender hardware address
157 * @tha: Target hardware address
55733350
SH
158 */
159struct flow_dissector_key_arp {
160 __u32 sip;
161 __u32 tip;
162 __u8 op;
163 unsigned char sha[ETH_ALEN];
164 unsigned char tha[ETH_ALEN];
165};
166
fbff949e 167/**
8c966a10
SH
168 * struct flow_dissector_key_ports:
169 * @ports: port numbers of Transport header
170 * @src: source port number
171 * @dst: destination port number
fbff949e
JP
172 */
173struct flow_dissector_key_ports {
174 union {
175 __be32 ports;
59346afe
JP
176 struct {
177 __be16 src;
178 __be16 dst;
179 };
fbff949e
JP
180 };
181};
182
83d85bb0
MG
183/**
184 * struct flow_dissector_key_ports_range
185 * @tp: port number from packet
186 * @tp_min: min port number in range
187 * @tp_max: max port number in range
188 */
189struct flow_dissector_key_ports_range {
190 union {
191 struct flow_dissector_key_ports tp;
192 struct {
193 struct flow_dissector_key_ports tp_min;
194 struct flow_dissector_key_ports tp_max;
195 };
196 };
197};
198
972d3876 199/**
8c966a10
SH
200 * struct flow_dissector_key_icmp:
201 * @type: ICMP type
202 * @code: ICMP code
203 * @id: Session identifier
972d3876
SH
204 */
205struct flow_dissector_key_icmp {
5dec597e
MC
206 struct {
207 u8 type;
208 u8 code;
972d3876 209 };
5dec597e 210 u16 id;
972d3876 211};
b924933c 212
67a900cc
JP
213/**
214 * struct flow_dissector_key_eth_addrs:
215 * @src: source Ethernet address
216 * @dst: destination Ethernet address
217 */
218struct flow_dissector_key_eth_addrs {
219 /* (dst,src) must be grouped, in the same way than in ETH header */
220 unsigned char dst[ETH_ALEN];
221 unsigned char src[ETH_ALEN];
222};
223
ac4bb5de
JP
224/**
225 * struct flow_dissector_key_tcp:
226 * @flags: flags
227 */
228struct flow_dissector_key_tcp {
229 __be16 flags;
230};
231
518d8a2e
OG
232/**
233 * struct flow_dissector_key_ip:
234 * @tos: tos
235 * @ttl: ttl
236 */
237struct flow_dissector_key_ip {
238 __u8 tos;
239 __u8 ttl;
240};
241
82828b88
JP
242/**
243 * struct flow_dissector_key_meta:
244 * @ingress_ifindex: ingress ifindex
8819efc9 245 * @ingress_iftype: ingress interface type
82828b88
JP
246 */
247struct flow_dissector_key_meta {
248 int ingress_ifindex;
8819efc9 249 u16 ingress_iftype;
82828b88
JP
250};
251
75a56758
PB
252/**
253 * struct flow_dissector_key_ct:
254 * @ct_state: conntrack state after converting with map
255 * @ct_mark: conttrack mark
256 * @ct_zone: conntrack zone
257 * @ct_labels: conntrack labels
258 */
259struct flow_dissector_key_ct {
260 u16 ct_state;
261 u16 ct_zone;
262 u32 ct_mark;
263 u32 ct_labels[4];
264};
265
0cb09aff
AL
266/**
267 * struct flow_dissector_key_hash:
268 * @hash: hash value
269 */
270struct flow_dissector_key_hash {
271 u32 hash;
272};
273
34951fcf
BS
274/**
275 * struct flow_dissector_key_num_of_vlans:
276 * @num_of_vlans: num_of_vlans value
277 */
278struct flow_dissector_key_num_of_vlans {
279 u8 num_of_vlans;
280};
281
46126db9
WD
282/**
283 * struct flow_dissector_key_pppoe:
284 * @session_id: pppoe session id
285 * @ppp_proto: ppp protocol
286 * @type: pppoe eth type
287 */
288struct flow_dissector_key_pppoe {
289 __be16 session_id;
290 __be16 ppp_proto;
291 __be16 type;
292};
293
dda2fa08
WD
294/**
295 * struct flow_dissector_key_l2tpv3:
296 * @session_id: identifier for a l2tp session
297 */
298struct flow_dissector_key_l2tpv3 {
299 __be32 session_id;
300};
301
fbff949e 302enum flow_dissector_key_id {
42aecaa9 303 FLOW_DISSECTOR_KEY_CONTROL, /* struct flow_dissector_key_control */
fbff949e 304 FLOW_DISSECTOR_KEY_BASIC, /* struct flow_dissector_key_basic */
c3f83241
TH
305 FLOW_DISSECTOR_KEY_IPV4_ADDRS, /* struct flow_dissector_key_ipv4_addrs */
306 FLOW_DISSECTOR_KEY_IPV6_ADDRS, /* struct flow_dissector_key_ipv6_addrs */
fbff949e 307 FLOW_DISSECTOR_KEY_PORTS, /* struct flow_dissector_key_ports */
8ffb055b 308 FLOW_DISSECTOR_KEY_PORTS_RANGE, /* struct flow_dissector_key_ports */
972d3876 309 FLOW_DISSECTOR_KEY_ICMP, /* struct flow_dissector_key_icmp */
67a900cc 310 FLOW_DISSECTOR_KEY_ETH_ADDRS, /* struct flow_dissector_key_eth_addrs */
8d6e79d3 311 FLOW_DISSECTOR_KEY_TIPC, /* struct flow_dissector_key_tipc */
55733350 312 FLOW_DISSECTOR_KEY_ARP, /* struct flow_dissector_key_arp */
91c45956
EC
313 FLOW_DISSECTOR_KEY_VLAN, /* struct flow_dissector_key_vlan */
314 FLOW_DISSECTOR_KEY_FLOW_LABEL, /* struct flow_dissector_key_tags */
1fdd512c 315 FLOW_DISSECTOR_KEY_GRE_KEYID, /* struct flow_dissector_key_keyid */
b3baa0fb 316 FLOW_DISSECTOR_KEY_MPLS_ENTROPY, /* struct flow_dissector_key_keyid */
9ba6a9a9
HHZ
317 FLOW_DISSECTOR_KEY_ENC_KEYID, /* struct flow_dissector_key_keyid */
318 FLOW_DISSECTOR_KEY_ENC_IPV4_ADDRS, /* struct flow_dissector_key_ipv4_addrs */
319 FLOW_DISSECTOR_KEY_ENC_IPV6_ADDRS, /* struct flow_dissector_key_ipv6_addrs */
320 FLOW_DISSECTOR_KEY_ENC_CONTROL, /* struct flow_dissector_key_control */
f4d997fd 321 FLOW_DISSECTOR_KEY_ENC_PORTS, /* struct flow_dissector_key_ports */
029c1ecb 322 FLOW_DISSECTOR_KEY_MPLS, /* struct flow_dissector_key_mpls */
ac4bb5de 323 FLOW_DISSECTOR_KEY_TCP, /* struct flow_dissector_key_tcp */
518d8a2e 324 FLOW_DISSECTOR_KEY_IP, /* struct flow_dissector_key_ip */
91c45956 325 FLOW_DISSECTOR_KEY_CVLAN, /* struct flow_dissector_key_vlan */
5544adb9 326 FLOW_DISSECTOR_KEY_ENC_IP, /* struct flow_dissector_key_ip */
92e2c405 327 FLOW_DISSECTOR_KEY_ENC_OPTS, /* struct flow_dissector_key_enc_opts */
82828b88 328 FLOW_DISSECTOR_KEY_META, /* struct flow_dissector_key_meta */
75a56758 329 FLOW_DISSECTOR_KEY_CT, /* struct flow_dissector_key_ct */
0cb09aff 330 FLOW_DISSECTOR_KEY_HASH, /* struct flow_dissector_key_hash */
34951fcf 331 FLOW_DISSECTOR_KEY_NUM_OF_VLANS, /* struct flow_dissector_key_num_of_vlans */
46126db9 332 FLOW_DISSECTOR_KEY_PPPOE, /* struct flow_dissector_key_pppoe */
dda2fa08 333 FLOW_DISSECTOR_KEY_L2TPV3, /* struct flow_dissector_key_l2tpv3 */
92e2c405 334
fbff949e
JP
335 FLOW_DISSECTOR_KEY_MAX,
336};
337
807e165d 338#define FLOW_DISSECTOR_F_PARSE_1ST_FRAG BIT(0)
1cc26450
SF
339#define FLOW_DISSECTOR_F_STOP_AT_FLOW_LABEL BIT(1)
340#define FLOW_DISSECTOR_F_STOP_AT_ENCAP BIT(2)
6de6e46d 341#define FLOW_DISSECTOR_F_STOP_BEFORE_ENCAP BIT(3)
807e165d 342
fbff949e
JP
343struct flow_dissector_key {
344 enum flow_dissector_key_id key_id;
345 size_t offset; /* offset of struct flow_dissector_key_*
346 in target the struct */
347};
348
349struct flow_dissector {
350 unsigned int used_keys; /* each bit repesents presence of one key id */
351 unsigned short int offset[FLOW_DISSECTOR_KEY_MAX];
352};
353
72a338bc
PA
354struct flow_keys_basic {
355 struct flow_dissector_key_control control;
356 struct flow_dissector_key_basic basic;
357};
358
06635a35 359struct flow_keys {
42aecaa9
TH
360 struct flow_dissector_key_control control;
361#define FLOW_KEYS_HASH_START_FIELD basic
55667441 362 struct flow_dissector_key_basic basic __aligned(SIPHASH_ALIGNMENT);
d34af823 363 struct flow_dissector_key_tags tags;
f6a66927 364 struct flow_dissector_key_vlan vlan;
24c590e3 365 struct flow_dissector_key_vlan cvlan;
1fdd512c 366 struct flow_dissector_key_keyid keyid;
42aecaa9 367 struct flow_dissector_key_ports ports;
5dec597e 368 struct flow_dissector_key_icmp icmp;
98298e6c 369 /* 'addrs' must be the last member */
42aecaa9 370 struct flow_dissector_key_addrs addrs;
06635a35
JP
371};
372
42aecaa9
TH
373#define FLOW_KEYS_HASH_OFFSET \
374 offsetof(struct flow_keys, FLOW_KEYS_HASH_START_FIELD)
375
c3f83241
TH
376__be32 flow_get_u32_src(const struct flow_keys *flow);
377__be32 flow_get_u32_dst(const struct flow_keys *flow);
378
06635a35 379extern struct flow_dissector flow_keys_dissector;
72a338bc 380extern struct flow_dissector flow_keys_basic_dissector;
06635a35 381
2f59e1eb
TH
382/* struct flow_keys_digest:
383 *
384 * This structure is used to hold a digest of the full flow keys. This is a
385 * larger "hash" of a flow to allow definitively matching specific flows where
386 * the 32 bit skb->hash is not large enough. The size is limited to 16 bytes so
53bc017f 387 * that it can be used in CB of skb (see sch_choke for an example).
2f59e1eb
TH
388 */
389#define FLOW_KEYS_DIGEST_LEN 16
390struct flow_keys_digest {
391 u8 data[FLOW_KEYS_DIGEST_LEN];
392};
393
394void make_flow_keys_digest(struct flow_keys_digest *digest,
395 const struct flow_keys *flow);
396
66fdd05e 397static inline bool flow_keys_have_l4(const struct flow_keys *keys)
bcc83839
TH
398{
399 return (keys->ports.ports || keys->tags.flow_label);
400}
401
c6cc1ca7 402u32 flow_hash_from_keys(struct flow_keys *keys);
5dec597e
MC
403void skb_flow_get_icmp_tci(const struct sk_buff *skb,
404 struct flow_dissector_key_icmp *key_icmp,
f96533cd 405 const void *data, int thoff, int hlen);
c6cc1ca7 406
8de2d793
AV
407static inline bool dissector_uses_key(const struct flow_dissector *flow_dissector,
408 enum flow_dissector_key_id key_id)
409{
410 return flow_dissector->used_keys & (1 << key_id);
411}
412
413static inline void *skb_flow_dissector_target(struct flow_dissector *flow_dissector,
414 enum flow_dissector_key_id key_id,
415 void *target_container)
416{
417 return ((char *)target_container) + flow_dissector->offset[key_id];
418}
419
089b19a9
SF
420struct bpf_flow_dissector {
421 struct bpf_flow_keys *flow_keys;
422 const struct sk_buff *skb;
dac06b32
AL
423 const void *data;
424 const void *data_end;
089b19a9
SF
425};
426
8a9093c7
JB
427static inline void
428flow_dissector_init_keys(struct flow_dissector_key_control *key_control,
429 struct flow_dissector_key_basic *key_basic)
430{
431 memset(key_control, 0, sizeof(*key_control));
432 memset(key_basic, 0, sizeof(*key_basic));
433}
434
b27f7bb5 435#ifdef CONFIG_BPF_SYSCALL
3b701699
JS
436int flow_dissector_bpf_prog_attach_check(struct net *net,
437 struct bpf_prog *prog);
b27f7bb5
JS
438#endif /* CONFIG_BPF_SYSCALL */
439
0744dd00 440#endif