xref: /linux/include/uapi/linux/pkt_cls.h (revision 8c85d18ce647ac2517a1a1bb01b02648e23700e6)
16f52b16cSGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
2607ca46eSDavid Howells #ifndef __LINUX_PKT_CLS_H
3607ca46eSDavid Howells #define __LINUX_PKT_CLS_H
4607ca46eSDavid Howells 
5607ca46eSDavid Howells #include <linux/types.h>
6607ca46eSDavid Howells #include <linux/pkt_sched.h>
7607ca46eSDavid Howells 
81045ba77SJamal Hadi Salim #define TC_COOKIE_MAX_SIZE 16
91045ba77SJamal Hadi Salim 
10607ca46eSDavid Howells /* Action attributes */
11607ca46eSDavid Howells enum {
12607ca46eSDavid Howells 	TCA_ACT_UNSPEC,
13607ca46eSDavid Howells 	TCA_ACT_KIND,
14607ca46eSDavid Howells 	TCA_ACT_OPTIONS,
15607ca46eSDavid Howells 	TCA_ACT_INDEX,
16607ca46eSDavid Howells 	TCA_ACT_STATS,
179854518eSNicolas Dichtel 	TCA_ACT_PAD,
181045ba77SJamal Hadi Salim 	TCA_ACT_COOKIE,
19abbb0d33SVlad Buslov 	TCA_ACT_FLAGS,
200dfb2d82SJakub Kicinski 	TCA_ACT_HW_STATS,
2193a129ebSJiri Pirko 	TCA_ACT_USED_HW_STATS,
22607ca46eSDavid Howells 	__TCA_ACT_MAX
23607ca46eSDavid Howells };
24607ca46eSDavid Howells 
25abbb0d33SVlad Buslov #define TCA_ACT_FLAGS_NO_PERCPU_STATS 1 /* Don't use percpu allocator for
26abbb0d33SVlad Buslov 					 * actions stats.
27abbb0d33SVlad Buslov 					 */
28abbb0d33SVlad Buslov 
2944f86580SJiri Pirko /* tca HW stats type
3044f86580SJiri Pirko  * When user does not pass the attribute, he does not care.
3144f86580SJiri Pirko  * It is the same as if he would pass the attribute with
3244f86580SJiri Pirko  * all supported bits set.
3344f86580SJiri Pirko  * In case no bits are set, user is not interested in getting any HW statistics.
3444f86580SJiri Pirko  */
350dfb2d82SJakub Kicinski #define TCA_ACT_HW_STATS_IMMEDIATE (1 << 0) /* Means that in dump, user
3644f86580SJiri Pirko 					     * gets the current HW stats
3744f86580SJiri Pirko 					     * state from the device
3844f86580SJiri Pirko 					     * queried at the dump time.
3944f86580SJiri Pirko 					     */
400dfb2d82SJakub Kicinski #define TCA_ACT_HW_STATS_DELAYED (1 << 1) /* Means that in dump, user gets
410dfb2d82SJakub Kicinski 					   * HW stats that might be out of date
420dfb2d82SJakub Kicinski 					   * for some time, maybe couple of
430dfb2d82SJakub Kicinski 					   * seconds. This is the case when
440dfb2d82SJakub Kicinski 					   * driver polls stats updates
450dfb2d82SJakub Kicinski 					   * periodically or when it gets async
460dfb2d82SJakub Kicinski 					   * stats update from the device.
4744f86580SJiri Pirko 					   */
4844f86580SJiri Pirko 
49607ca46eSDavid Howells #define TCA_ACT_MAX __TCA_ACT_MAX
50607ca46eSDavid Howells #define TCA_OLD_COMPAT (TCA_ACT_MAX+1)
51607ca46eSDavid Howells #define TCA_ACT_MAX_PRIO 32
52607ca46eSDavid Howells #define TCA_ACT_BIND	1
53607ca46eSDavid Howells #define TCA_ACT_NOBIND	0
54607ca46eSDavid Howells #define TCA_ACT_UNBIND	1
55607ca46eSDavid Howells #define TCA_ACT_NOUNBIND	0
56607ca46eSDavid Howells #define TCA_ACT_REPLACE		1
57607ca46eSDavid Howells #define TCA_ACT_NOREPLACE	0
58607ca46eSDavid Howells 
59607ca46eSDavid Howells #define TC_ACT_UNSPEC	(-1)
60607ca46eSDavid Howells #define TC_ACT_OK		0
61607ca46eSDavid Howells #define TC_ACT_RECLASSIFY	1
62607ca46eSDavid Howells #define TC_ACT_SHOT		2
63607ca46eSDavid Howells #define TC_ACT_PIPE		3
64607ca46eSDavid Howells #define TC_ACT_STOLEN		4
65607ca46eSDavid Howells #define TC_ACT_QUEUED		5
66607ca46eSDavid Howells #define TC_ACT_REPEAT		6
6727b29f63SAlexei Starovoitov #define TC_ACT_REDIRECT		7
68e25ea21fSJiri Pirko #define TC_ACT_TRAP		8 /* For hw path, this means "trap to cpu"
69e25ea21fSJiri Pirko 				   * and don't further process the frame
70e25ea21fSJiri Pirko 				   * in hardware. For sw path, this is
71e25ea21fSJiri Pirko 				   * equivalent of TC_ACT_STOLEN - drop
72e25ea21fSJiri Pirko 				   * the skb and act like everything
73e25ea21fSJiri Pirko 				   * is alright.
74e25ea21fSJiri Pirko 				   */
75802bfb19SPaolo Abeni #define TC_ACT_VALUE_MAX	TC_ACT_TRAP
769da3242eSJiri Pirko 
779da3242eSJiri Pirko /* There is a special kind of actions called "extended actions",
789da3242eSJiri Pirko  * which need a value parameter. These have a local opcode located in
799da3242eSJiri Pirko  * the highest nibble, starting from 1. The rest of the bits
809da3242eSJiri Pirko  * are used to carry the value. These two parts together make
819da3242eSJiri Pirko  * a combined opcode.
829da3242eSJiri Pirko  */
839da3242eSJiri Pirko #define __TC_ACT_EXT_SHIFT 28
849da3242eSJiri Pirko #define __TC_ACT_EXT(local) ((local) << __TC_ACT_EXT_SHIFT)
859da3242eSJiri Pirko #define TC_ACT_EXT_VAL_MASK ((1 << __TC_ACT_EXT_SHIFT) - 1)
86802bfb19SPaolo Abeni #define TC_ACT_EXT_OPCODE(combined) ((combined) & (~TC_ACT_EXT_VAL_MASK))
87802bfb19SPaolo Abeni #define TC_ACT_EXT_CMP(combined, opcode) (TC_ACT_EXT_OPCODE(combined) == opcode)
889da3242eSJiri Pirko 
899da3242eSJiri Pirko #define TC_ACT_JUMP __TC_ACT_EXT(1)
90db50514fSJiri Pirko #define TC_ACT_GOTO_CHAIN __TC_ACT_EXT(2)
91802bfb19SPaolo Abeni #define TC_ACT_EXT_OPCODE_MAX	TC_ACT_GOTO_CHAIN
92607ca46eSDavid Howells 
93257eededSEli Cohen /* These macros are put here for binary compatibility with userspace apps that
94257eededSEli Cohen  * make use of them. For kernel code and new userspace apps, use the TCA_ID_*
95257eededSEli Cohen  * versions.
96257eededSEli Cohen  */
97257eededSEli Cohen #define TCA_ACT_GACT 5
98257eededSEli Cohen #define TCA_ACT_IPT 6
99257eededSEli Cohen #define TCA_ACT_PEDIT 7
100257eededSEli Cohen #define TCA_ACT_MIRRED 8
101257eededSEli Cohen #define TCA_ACT_NAT 9
102257eededSEli Cohen #define TCA_ACT_XT 10
103257eededSEli Cohen #define TCA_ACT_SKBEDIT 11
104257eededSEli Cohen #define TCA_ACT_VLAN 12
105257eededSEli Cohen #define TCA_ACT_BPF 13
106257eededSEli Cohen #define TCA_ACT_CONNMARK 14
107257eededSEli Cohen #define TCA_ACT_SKBMOD 15
108257eededSEli Cohen #define TCA_ACT_CSUM 16
109257eededSEli Cohen #define TCA_ACT_TUNNEL_KEY 17
110257eededSEli Cohen #define TCA_ACT_SIMP 22
111257eededSEli Cohen #define TCA_ACT_IFE 25
112257eededSEli Cohen #define TCA_ACT_SAMPLE 26
113257eededSEli Cohen 
114607ca46eSDavid Howells /* Action type identifiers*/
115eddd2cf1SEli Cohen enum tca_id {
116607ca46eSDavid Howells 	TCA_ID_UNSPEC = 0,
117607ca46eSDavid Howells 	TCA_ID_POLICE = 1,
118257eededSEli Cohen 	TCA_ID_GACT = TCA_ACT_GACT,
119257eededSEli Cohen 	TCA_ID_IPT = TCA_ACT_IPT,
120257eededSEli Cohen 	TCA_ID_PEDIT = TCA_ACT_PEDIT,
121257eededSEli Cohen 	TCA_ID_MIRRED = TCA_ACT_MIRRED,
122257eededSEli Cohen 	TCA_ID_NAT = TCA_ACT_NAT,
123257eededSEli Cohen 	TCA_ID_XT = TCA_ACT_XT,
124257eededSEli Cohen 	TCA_ID_SKBEDIT = TCA_ACT_SKBEDIT,
125257eededSEli Cohen 	TCA_ID_VLAN = TCA_ACT_VLAN,
126257eededSEli Cohen 	TCA_ID_BPF = TCA_ACT_BPF,
127257eededSEli Cohen 	TCA_ID_CONNMARK = TCA_ACT_CONNMARK,
128257eededSEli Cohen 	TCA_ID_SKBMOD = TCA_ACT_SKBMOD,
129257eededSEli Cohen 	TCA_ID_CSUM = TCA_ACT_CSUM,
130257eededSEli Cohen 	TCA_ID_TUNNEL_KEY = TCA_ACT_TUNNEL_KEY,
131257eededSEli Cohen 	TCA_ID_SIMP = TCA_ACT_SIMP,
132257eededSEli Cohen 	TCA_ID_IFE = TCA_ACT_IFE,
133257eededSEli Cohen 	TCA_ID_SAMPLE = TCA_ACT_SAMPLE,
13424ec483cSKevin 'ldir' Darbyshire-Bryant 	TCA_ID_CTINFO,
1352a2ea508SJohn Hurley 	TCA_ID_MPLS,
136b57dc7c1SPaul Blakey 	TCA_ID_CT,
137a51c328dSPo Liu 	TCA_ID_GATE,
1382a2ea508SJohn Hurley 	/* other actions go here */
139607ca46eSDavid Howells 	__TCA_ID_MAX = 255
140607ca46eSDavid Howells };
141607ca46eSDavid Howells 
142607ca46eSDavid Howells #define TCA_ID_MAX __TCA_ID_MAX
143607ca46eSDavid Howells 
144607ca46eSDavid Howells struct tc_police {
145607ca46eSDavid Howells 	__u32			index;
146607ca46eSDavid Howells 	int			action;
147607ca46eSDavid Howells #define TC_POLICE_UNSPEC	TC_ACT_UNSPEC
148607ca46eSDavid Howells #define TC_POLICE_OK		TC_ACT_OK
149607ca46eSDavid Howells #define TC_POLICE_RECLASSIFY	TC_ACT_RECLASSIFY
150607ca46eSDavid Howells #define TC_POLICE_SHOT		TC_ACT_SHOT
151607ca46eSDavid Howells #define TC_POLICE_PIPE		TC_ACT_PIPE
152607ca46eSDavid Howells 
153607ca46eSDavid Howells 	__u32			limit;
154607ca46eSDavid Howells 	__u32			burst;
155607ca46eSDavid Howells 	__u32			mtu;
156607ca46eSDavid Howells 	struct tc_ratespec	rate;
157607ca46eSDavid Howells 	struct tc_ratespec	peakrate;
158607ca46eSDavid Howells 	int			refcnt;
159607ca46eSDavid Howells 	int			bindcnt;
160607ca46eSDavid Howells 	__u32			capab;
161607ca46eSDavid Howells };
162607ca46eSDavid Howells 
163607ca46eSDavid Howells struct tcf_t {
164607ca46eSDavid Howells 	__u64   install;
165607ca46eSDavid Howells 	__u64   lastuse;
166607ca46eSDavid Howells 	__u64   expires;
16753eb440fSJamal Hadi Salim 	__u64   firstuse;
168607ca46eSDavid Howells };
169607ca46eSDavid Howells 
170607ca46eSDavid Howells struct tc_cnt {
171607ca46eSDavid Howells 	int                   refcnt;
172607ca46eSDavid Howells 	int                   bindcnt;
173607ca46eSDavid Howells };
174607ca46eSDavid Howells 
175607ca46eSDavid Howells #define tc_gen \
176607ca46eSDavid Howells 	__u32                 index; \
177607ca46eSDavid Howells 	__u32                 capab; \
178607ca46eSDavid Howells 	int                   action; \
179607ca46eSDavid Howells 	int                   refcnt; \
180607ca46eSDavid Howells 	int                   bindcnt
181607ca46eSDavid Howells 
182607ca46eSDavid Howells enum {
183607ca46eSDavid Howells 	TCA_POLICE_UNSPEC,
184607ca46eSDavid Howells 	TCA_POLICE_TBF,
185607ca46eSDavid Howells 	TCA_POLICE_RATE,
186607ca46eSDavid Howells 	TCA_POLICE_PEAKRATE,
187607ca46eSDavid Howells 	TCA_POLICE_AVRATE,
188607ca46eSDavid Howells 	TCA_POLICE_RESULT,
1893d3ed181SJamal Hadi Salim 	TCA_POLICE_TM,
1903d3ed181SJamal Hadi Salim 	TCA_POLICE_PAD,
191d1967e49SDavid Dai 	TCA_POLICE_RATE64,
192d1967e49SDavid Dai 	TCA_POLICE_PEAKRATE64,
193607ca46eSDavid Howells 	__TCA_POLICE_MAX
194607ca46eSDavid Howells #define TCA_POLICE_RESULT TCA_POLICE_RESULT
195607ca46eSDavid Howells };
196607ca46eSDavid Howells 
197607ca46eSDavid Howells #define TCA_POLICE_MAX (__TCA_POLICE_MAX - 1)
198607ca46eSDavid Howells 
199760edee8SSamudrala, Sridhar /* tca flags definitions */
200e696028aSOr Gerlitz #define TCA_CLS_FLAGS_SKIP_HW	(1 << 0) /* don't offload filter to HW */
201e696028aSOr Gerlitz #define TCA_CLS_FLAGS_SKIP_SW	(1 << 1) /* don't use filter in SW */
202e696028aSOr Gerlitz #define TCA_CLS_FLAGS_IN_HW	(1 << 2) /* filter is offloaded to HW */
203e696028aSOr Gerlitz #define TCA_CLS_FLAGS_NOT_IN_HW (1 << 3) /* filter isn't offloaded to HW */
20481c7288bSMarcelo Ricardo Leitner #define TCA_CLS_FLAGS_VERBOSE	(1 << 4) /* verbose logging */
205760edee8SSamudrala, Sridhar 
206607ca46eSDavid Howells /* U32 filters */
207607ca46eSDavid Howells 
208607ca46eSDavid Howells #define TC_U32_HTID(h) ((h)&0xFFF00000)
209607ca46eSDavid Howells #define TC_U32_USERHTID(h) (TC_U32_HTID(h)>>20)
210607ca46eSDavid Howells #define TC_U32_HASH(h) (((h)>>12)&0xFF)
211607ca46eSDavid Howells #define TC_U32_NODE(h) ((h)&0xFFF)
212607ca46eSDavid Howells #define TC_U32_KEY(h) ((h)&0xFFFFF)
213607ca46eSDavid Howells #define TC_U32_UNSPEC	0
214607ca46eSDavid Howells #define TC_U32_ROOT	(0xFFF00000)
215607ca46eSDavid Howells 
216607ca46eSDavid Howells enum {
217607ca46eSDavid Howells 	TCA_U32_UNSPEC,
218607ca46eSDavid Howells 	TCA_U32_CLASSID,
219607ca46eSDavid Howells 	TCA_U32_HASH,
220607ca46eSDavid Howells 	TCA_U32_LINK,
221607ca46eSDavid Howells 	TCA_U32_DIVISOR,
222607ca46eSDavid Howells 	TCA_U32_SEL,
223607ca46eSDavid Howells 	TCA_U32_POLICE,
224607ca46eSDavid Howells 	TCA_U32_ACT,
225607ca46eSDavid Howells 	TCA_U32_INDEV,
226607ca46eSDavid Howells 	TCA_U32_PCNT,
227607ca46eSDavid Howells 	TCA_U32_MARK,
2289e8ce79cSJohn Fastabend 	TCA_U32_FLAGS,
2299854518eSNicolas Dichtel 	TCA_U32_PAD,
230607ca46eSDavid Howells 	__TCA_U32_MAX
231607ca46eSDavid Howells };
232607ca46eSDavid Howells 
233607ca46eSDavid Howells #define TCA_U32_MAX (__TCA_U32_MAX - 1)
234607ca46eSDavid Howells 
235607ca46eSDavid Howells struct tc_u32_key {
236607ca46eSDavid Howells 	__be32		mask;
237607ca46eSDavid Howells 	__be32		val;
238607ca46eSDavid Howells 	int		off;
239607ca46eSDavid Howells 	int		offmask;
240607ca46eSDavid Howells };
241607ca46eSDavid Howells 
242607ca46eSDavid Howells struct tc_u32_sel {
243607ca46eSDavid Howells 	unsigned char		flags;
244607ca46eSDavid Howells 	unsigned char		offshift;
245607ca46eSDavid Howells 	unsigned char		nkeys;
246607ca46eSDavid Howells 
247607ca46eSDavid Howells 	__be16			offmask;
248607ca46eSDavid Howells 	__u16			off;
249607ca46eSDavid Howells 	short			offoff;
250607ca46eSDavid Howells 
251607ca46eSDavid Howells 	short			hoff;
252607ca46eSDavid Howells 	__be32			hmask;
253607ca46eSDavid Howells 	struct tc_u32_key	keys[0];
254607ca46eSDavid Howells };
255607ca46eSDavid Howells 
256607ca46eSDavid Howells struct tc_u32_mark {
257607ca46eSDavid Howells 	__u32		val;
258607ca46eSDavid Howells 	__u32		mask;
259607ca46eSDavid Howells 	__u32		success;
260607ca46eSDavid Howells };
261607ca46eSDavid Howells 
262607ca46eSDavid Howells struct tc_u32_pcnt {
263607ca46eSDavid Howells 	__u64 rcnt;
264607ca46eSDavid Howells 	__u64 rhit;
265607ca46eSDavid Howells 	__u64 kcnts[0];
266607ca46eSDavid Howells };
267607ca46eSDavid Howells 
268607ca46eSDavid Howells /* Flags */
269607ca46eSDavid Howells 
270607ca46eSDavid Howells #define TC_U32_TERMINAL		1
271607ca46eSDavid Howells #define TC_U32_OFFSET		2
272607ca46eSDavid Howells #define TC_U32_VAROFFSET	4
273607ca46eSDavid Howells #define TC_U32_EAT		8
274607ca46eSDavid Howells 
275607ca46eSDavid Howells #define TC_U32_MAXDEPTH 8
276607ca46eSDavid Howells 
277607ca46eSDavid Howells 
278607ca46eSDavid Howells /* RSVP filter */
279607ca46eSDavid Howells 
280607ca46eSDavid Howells enum {
281607ca46eSDavid Howells 	TCA_RSVP_UNSPEC,
282607ca46eSDavid Howells 	TCA_RSVP_CLASSID,
283607ca46eSDavid Howells 	TCA_RSVP_DST,
284607ca46eSDavid Howells 	TCA_RSVP_SRC,
285607ca46eSDavid Howells 	TCA_RSVP_PINFO,
286607ca46eSDavid Howells 	TCA_RSVP_POLICE,
287607ca46eSDavid Howells 	TCA_RSVP_ACT,
288607ca46eSDavid Howells 	__TCA_RSVP_MAX
289607ca46eSDavid Howells };
290607ca46eSDavid Howells 
291607ca46eSDavid Howells #define TCA_RSVP_MAX (__TCA_RSVP_MAX - 1 )
292607ca46eSDavid Howells 
293607ca46eSDavid Howells struct tc_rsvp_gpi {
294607ca46eSDavid Howells 	__u32	key;
295607ca46eSDavid Howells 	__u32	mask;
296607ca46eSDavid Howells 	int	offset;
297607ca46eSDavid Howells };
298607ca46eSDavid Howells 
299607ca46eSDavid Howells struct tc_rsvp_pinfo {
300607ca46eSDavid Howells 	struct tc_rsvp_gpi dpi;
301607ca46eSDavid Howells 	struct tc_rsvp_gpi spi;
302607ca46eSDavid Howells 	__u8	protocol;
303607ca46eSDavid Howells 	__u8	tunnelid;
304607ca46eSDavid Howells 	__u8	tunnelhdr;
305607ca46eSDavid Howells 	__u8	pad;
306607ca46eSDavid Howells };
307607ca46eSDavid Howells 
308607ca46eSDavid Howells /* ROUTE filter */
309607ca46eSDavid Howells 
310607ca46eSDavid Howells enum {
311607ca46eSDavid Howells 	TCA_ROUTE4_UNSPEC,
312607ca46eSDavid Howells 	TCA_ROUTE4_CLASSID,
313607ca46eSDavid Howells 	TCA_ROUTE4_TO,
314607ca46eSDavid Howells 	TCA_ROUTE4_FROM,
315607ca46eSDavid Howells 	TCA_ROUTE4_IIF,
316607ca46eSDavid Howells 	TCA_ROUTE4_POLICE,
317607ca46eSDavid Howells 	TCA_ROUTE4_ACT,
318607ca46eSDavid Howells 	__TCA_ROUTE4_MAX
319607ca46eSDavid Howells };
320607ca46eSDavid Howells 
321607ca46eSDavid Howells #define TCA_ROUTE4_MAX (__TCA_ROUTE4_MAX - 1)
322607ca46eSDavid Howells 
323607ca46eSDavid Howells 
324607ca46eSDavid Howells /* FW filter */
325607ca46eSDavid Howells 
326607ca46eSDavid Howells enum {
327607ca46eSDavid Howells 	TCA_FW_UNSPEC,
328607ca46eSDavid Howells 	TCA_FW_CLASSID,
329607ca46eSDavid Howells 	TCA_FW_POLICE,
330a5148626SJiri Pirko 	TCA_FW_INDEV,
331607ca46eSDavid Howells 	TCA_FW_ACT, /* used by CONFIG_NET_CLS_ACT */
332607ca46eSDavid Howells 	TCA_FW_MASK,
333607ca46eSDavid Howells 	__TCA_FW_MAX
334607ca46eSDavid Howells };
335607ca46eSDavid Howells 
336607ca46eSDavid Howells #define TCA_FW_MAX (__TCA_FW_MAX - 1)
337607ca46eSDavid Howells 
338607ca46eSDavid Howells /* TC index filter */
339607ca46eSDavid Howells 
340607ca46eSDavid Howells enum {
341607ca46eSDavid Howells 	TCA_TCINDEX_UNSPEC,
342607ca46eSDavid Howells 	TCA_TCINDEX_HASH,
343607ca46eSDavid Howells 	TCA_TCINDEX_MASK,
344607ca46eSDavid Howells 	TCA_TCINDEX_SHIFT,
345607ca46eSDavid Howells 	TCA_TCINDEX_FALL_THROUGH,
346607ca46eSDavid Howells 	TCA_TCINDEX_CLASSID,
347607ca46eSDavid Howells 	TCA_TCINDEX_POLICE,
348607ca46eSDavid Howells 	TCA_TCINDEX_ACT,
349607ca46eSDavid Howells 	__TCA_TCINDEX_MAX
350607ca46eSDavid Howells };
351607ca46eSDavid Howells 
352607ca46eSDavid Howells #define TCA_TCINDEX_MAX     (__TCA_TCINDEX_MAX - 1)
353607ca46eSDavid Howells 
354607ca46eSDavid Howells /* Flow filter */
355607ca46eSDavid Howells 
356607ca46eSDavid Howells enum {
357607ca46eSDavid Howells 	FLOW_KEY_SRC,
358607ca46eSDavid Howells 	FLOW_KEY_DST,
359607ca46eSDavid Howells 	FLOW_KEY_PROTO,
360607ca46eSDavid Howells 	FLOW_KEY_PROTO_SRC,
361607ca46eSDavid Howells 	FLOW_KEY_PROTO_DST,
362607ca46eSDavid Howells 	FLOW_KEY_IIF,
363607ca46eSDavid Howells 	FLOW_KEY_PRIORITY,
364607ca46eSDavid Howells 	FLOW_KEY_MARK,
365607ca46eSDavid Howells 	FLOW_KEY_NFCT,
366607ca46eSDavid Howells 	FLOW_KEY_NFCT_SRC,
367607ca46eSDavid Howells 	FLOW_KEY_NFCT_DST,
368607ca46eSDavid Howells 	FLOW_KEY_NFCT_PROTO_SRC,
369607ca46eSDavid Howells 	FLOW_KEY_NFCT_PROTO_DST,
370607ca46eSDavid Howells 	FLOW_KEY_RTCLASSID,
371607ca46eSDavid Howells 	FLOW_KEY_SKUID,
372607ca46eSDavid Howells 	FLOW_KEY_SKGID,
373607ca46eSDavid Howells 	FLOW_KEY_VLAN_TAG,
374607ca46eSDavid Howells 	FLOW_KEY_RXHASH,
375607ca46eSDavid Howells 	__FLOW_KEY_MAX,
376607ca46eSDavid Howells };
377607ca46eSDavid Howells 
378607ca46eSDavid Howells #define FLOW_KEY_MAX	(__FLOW_KEY_MAX - 1)
379607ca46eSDavid Howells 
380607ca46eSDavid Howells enum {
381607ca46eSDavid Howells 	FLOW_MODE_MAP,
382607ca46eSDavid Howells 	FLOW_MODE_HASH,
383607ca46eSDavid Howells };
384607ca46eSDavid Howells 
385607ca46eSDavid Howells enum {
386607ca46eSDavid Howells 	TCA_FLOW_UNSPEC,
387607ca46eSDavid Howells 	TCA_FLOW_KEYS,
388607ca46eSDavid Howells 	TCA_FLOW_MODE,
389607ca46eSDavid Howells 	TCA_FLOW_BASECLASS,
390607ca46eSDavid Howells 	TCA_FLOW_RSHIFT,
391607ca46eSDavid Howells 	TCA_FLOW_ADDEND,
392607ca46eSDavid Howells 	TCA_FLOW_MASK,
393607ca46eSDavid Howells 	TCA_FLOW_XOR,
394607ca46eSDavid Howells 	TCA_FLOW_DIVISOR,
395607ca46eSDavid Howells 	TCA_FLOW_ACT,
396607ca46eSDavid Howells 	TCA_FLOW_POLICE,
397607ca46eSDavid Howells 	TCA_FLOW_EMATCHES,
398607ca46eSDavid Howells 	TCA_FLOW_PERTURB,
399607ca46eSDavid Howells 	__TCA_FLOW_MAX
400607ca46eSDavid Howells };
401607ca46eSDavid Howells 
402607ca46eSDavid Howells #define TCA_FLOW_MAX	(__TCA_FLOW_MAX - 1)
403607ca46eSDavid Howells 
404607ca46eSDavid Howells /* Basic filter */
405607ca46eSDavid Howells 
4065954894bSCong Wang struct tc_basic_pcnt {
4075954894bSCong Wang 	__u64 rcnt;
4085954894bSCong Wang 	__u64 rhit;
4095954894bSCong Wang };
4105954894bSCong Wang 
411607ca46eSDavid Howells enum {
412607ca46eSDavid Howells 	TCA_BASIC_UNSPEC,
413607ca46eSDavid Howells 	TCA_BASIC_CLASSID,
414607ca46eSDavid Howells 	TCA_BASIC_EMATCHES,
415607ca46eSDavid Howells 	TCA_BASIC_ACT,
416607ca46eSDavid Howells 	TCA_BASIC_POLICE,
4175954894bSCong Wang 	TCA_BASIC_PCNT,
4185954894bSCong Wang 	TCA_BASIC_PAD,
419607ca46eSDavid Howells 	__TCA_BASIC_MAX
420607ca46eSDavid Howells };
421607ca46eSDavid Howells 
422607ca46eSDavid Howells #define TCA_BASIC_MAX (__TCA_BASIC_MAX - 1)
423607ca46eSDavid Howells 
424607ca46eSDavid Howells 
425607ca46eSDavid Howells /* Cgroup classifier */
426607ca46eSDavid Howells 
427607ca46eSDavid Howells enum {
428607ca46eSDavid Howells 	TCA_CGROUP_UNSPEC,
429607ca46eSDavid Howells 	TCA_CGROUP_ACT,
430607ca46eSDavid Howells 	TCA_CGROUP_POLICE,
431607ca46eSDavid Howells 	TCA_CGROUP_EMATCHES,
432607ca46eSDavid Howells 	__TCA_CGROUP_MAX,
433607ca46eSDavid Howells };
434607ca46eSDavid Howells 
435607ca46eSDavid Howells #define TCA_CGROUP_MAX (__TCA_CGROUP_MAX - 1)
436607ca46eSDavid Howells 
4377d1d65cbSDaniel Borkmann /* BPF classifier */
4387d1d65cbSDaniel Borkmann 
439045efa82SDaniel Borkmann #define TCA_BPF_FLAG_ACT_DIRECT		(1 << 0)
440045efa82SDaniel Borkmann 
4417d1d65cbSDaniel Borkmann enum {
4427d1d65cbSDaniel Borkmann 	TCA_BPF_UNSPEC,
4437d1d65cbSDaniel Borkmann 	TCA_BPF_ACT,
4447d1d65cbSDaniel Borkmann 	TCA_BPF_POLICE,
4457d1d65cbSDaniel Borkmann 	TCA_BPF_CLASSID,
4467d1d65cbSDaniel Borkmann 	TCA_BPF_OPS_LEN,
4477d1d65cbSDaniel Borkmann 	TCA_BPF_OPS,
448e2e9b654SDaniel Borkmann 	TCA_BPF_FD,
449e2e9b654SDaniel Borkmann 	TCA_BPF_NAME,
450045efa82SDaniel Borkmann 	TCA_BPF_FLAGS,
4510d01d45fSJakub Kicinski 	TCA_BPF_FLAGS_GEN,
452f1f7714eSDaniel Borkmann 	TCA_BPF_TAG,
453e8628307SDaniel Borkmann 	TCA_BPF_ID,
4547d1d65cbSDaniel Borkmann 	__TCA_BPF_MAX,
4557d1d65cbSDaniel Borkmann };
4567d1d65cbSDaniel Borkmann 
4577d1d65cbSDaniel Borkmann #define TCA_BPF_MAX (__TCA_BPF_MAX - 1)
4587d1d65cbSDaniel Borkmann 
45977b9900eSJiri Pirko /* Flower classifier */
46077b9900eSJiri Pirko 
46177b9900eSJiri Pirko enum {
46277b9900eSJiri Pirko 	TCA_FLOWER_UNSPEC,
46377b9900eSJiri Pirko 	TCA_FLOWER_CLASSID,
46477b9900eSJiri Pirko 	TCA_FLOWER_INDEV,
46577b9900eSJiri Pirko 	TCA_FLOWER_ACT,
46677b9900eSJiri Pirko 	TCA_FLOWER_KEY_ETH_DST,		/* ETH_ALEN */
46777b9900eSJiri Pirko 	TCA_FLOWER_KEY_ETH_DST_MASK,	/* ETH_ALEN */
46877b9900eSJiri Pirko 	TCA_FLOWER_KEY_ETH_SRC,		/* ETH_ALEN */
46977b9900eSJiri Pirko 	TCA_FLOWER_KEY_ETH_SRC_MASK,	/* ETH_ALEN */
47077b9900eSJiri Pirko 	TCA_FLOWER_KEY_ETH_TYPE,	/* be16 */
47177b9900eSJiri Pirko 	TCA_FLOWER_KEY_IP_PROTO,	/* u8 */
47277b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV4_SRC,	/* be32 */
47377b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV4_SRC_MASK,	/* be32 */
47477b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV4_DST,	/* be32 */
47577b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV4_DST_MASK,	/* be32 */
47677b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV6_SRC,	/* struct in6_addr */
47777b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV6_SRC_MASK,	/* struct in6_addr */
47877b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV6_DST,	/* struct in6_addr */
47977b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV6_DST_MASK,	/* struct in6_addr */
48077b9900eSJiri Pirko 	TCA_FLOWER_KEY_TCP_SRC,		/* be16 */
48177b9900eSJiri Pirko 	TCA_FLOWER_KEY_TCP_DST,		/* be16 */
48277b9900eSJiri Pirko 	TCA_FLOWER_KEY_UDP_SRC,		/* be16 */
48377b9900eSJiri Pirko 	TCA_FLOWER_KEY_UDP_DST,		/* be16 */
4845b33f488SAmir Vadai 
4855b33f488SAmir Vadai 	TCA_FLOWER_FLAGS,
48637a6c151SOr Gerlitz 	TCA_FLOWER_KEY_VLAN_ID,		/* be16 */
48737a6c151SOr Gerlitz 	TCA_FLOWER_KEY_VLAN_PRIO,	/* u8   */
48837a6c151SOr Gerlitz 	TCA_FLOWER_KEY_VLAN_ETH_TYPE,	/* be16 */
489bc3103f1SAmir Vadai 
490bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_KEY_ID,	/* be32 */
491bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV4_SRC,	/* be32 */
492bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV4_SRC_MASK,/* be32 */
493bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV4_DST,	/* be32 */
494bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV4_DST_MASK,/* be32 */
495bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV6_SRC,	/* struct in6_addr */
496bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV6_SRC_MASK,/* struct in6_addr */
497bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV6_DST,	/* struct in6_addr */
498bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV6_DST_MASK,/* struct in6_addr */
499bc3103f1SAmir Vadai 
500aa72d708SOr Gerlitz 	TCA_FLOWER_KEY_TCP_SRC_MASK,	/* be16 */
501aa72d708SOr Gerlitz 	TCA_FLOWER_KEY_TCP_DST_MASK,	/* be16 */
502aa72d708SOr Gerlitz 	TCA_FLOWER_KEY_UDP_SRC_MASK,	/* be16 */
503aa72d708SOr Gerlitz 	TCA_FLOWER_KEY_UDP_DST_MASK,	/* be16 */
5045976c5f4SSimon Horman 	TCA_FLOWER_KEY_SCTP_SRC_MASK,	/* be16 */
5055976c5f4SSimon Horman 	TCA_FLOWER_KEY_SCTP_DST_MASK,	/* be16 */
5065976c5f4SSimon Horman 
5075976c5f4SSimon Horman 	TCA_FLOWER_KEY_SCTP_SRC,	/* be16 */
5085976c5f4SSimon Horman 	TCA_FLOWER_KEY_SCTP_DST,	/* be16 */
509f4d997fdSHadar Hen Zion 
510f4d997fdSHadar Hen Zion 	TCA_FLOWER_KEY_ENC_UDP_SRC_PORT,	/* be16 */
511f4d997fdSHadar Hen Zion 	TCA_FLOWER_KEY_ENC_UDP_SRC_PORT_MASK,	/* be16 */
512f4d997fdSHadar Hen Zion 	TCA_FLOWER_KEY_ENC_UDP_DST_PORT,	/* be16 */
513f4d997fdSHadar Hen Zion 	TCA_FLOWER_KEY_ENC_UDP_DST_PORT_MASK,	/* be16 */
514faa3ffceSOr Gerlitz 
515faa3ffceSOr Gerlitz 	TCA_FLOWER_KEY_FLAGS,		/* be32 */
516faa3ffceSOr Gerlitz 	TCA_FLOWER_KEY_FLAGS_MASK,	/* be32 */
5177b684884SSimon Horman 
5187b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV4_CODE,	/* u8 */
5197b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV4_CODE_MASK,/* u8 */
5207b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV4_TYPE,	/* u8 */
5217b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV4_TYPE_MASK,/* u8 */
5227b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV6_CODE,	/* u8 */
5237b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV6_CODE_MASK,/* u8 */
5247b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV6_TYPE,	/* u8 */
5257b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV6_TYPE_MASK,/* u8 */
5267b684884SSimon Horman 
52799d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_SIP,		/* be32 */
52899d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_SIP_MASK,	/* be32 */
52999d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_TIP,		/* be32 */
53099d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_TIP_MASK,	/* be32 */
53199d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_OP,		/* u8 */
53299d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_OP_MASK,	/* u8 */
53399d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_SHA,		/* ETH_ALEN */
53499d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_SHA_MASK,	/* ETH_ALEN */
53599d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_THA,		/* ETH_ALEN */
53699d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_THA_MASK,	/* ETH_ALEN */
53799d31326SSimon Horman 
538a577d8f7SBenjamin LaHaise 	TCA_FLOWER_KEY_MPLS_TTL,	/* u8 - 8 bits */
539a577d8f7SBenjamin LaHaise 	TCA_FLOWER_KEY_MPLS_BOS,	/* u8 - 1 bit */
540a577d8f7SBenjamin LaHaise 	TCA_FLOWER_KEY_MPLS_TC,		/* u8 - 3 bits */
541a577d8f7SBenjamin LaHaise 	TCA_FLOWER_KEY_MPLS_LABEL,	/* be32 - 20 bits */
542a577d8f7SBenjamin LaHaise 
543fdfc7dd6SJiri Pirko 	TCA_FLOWER_KEY_TCP_FLAGS,	/* be16 */
544fdfc7dd6SJiri Pirko 	TCA_FLOWER_KEY_TCP_FLAGS_MASK,	/* be16 */
545fdfc7dd6SJiri Pirko 
5464d80cc0aSOr Gerlitz 	TCA_FLOWER_KEY_IP_TOS,		/* u8 */
5474d80cc0aSOr Gerlitz 	TCA_FLOWER_KEY_IP_TOS_MASK,	/* u8 */
5484d80cc0aSOr Gerlitz 	TCA_FLOWER_KEY_IP_TTL,		/* u8 */
5494d80cc0aSOr Gerlitz 	TCA_FLOWER_KEY_IP_TTL_MASK,	/* u8 */
5504d80cc0aSOr Gerlitz 
551d64efd09SJianbo Liu 	TCA_FLOWER_KEY_CVLAN_ID,	/* be16 */
552d64efd09SJianbo Liu 	TCA_FLOWER_KEY_CVLAN_PRIO,	/* u8   */
553d64efd09SJianbo Liu 	TCA_FLOWER_KEY_CVLAN_ETH_TYPE,	/* be16 */
554d64efd09SJianbo Liu 
5550e2c17b6SOr Gerlitz 	TCA_FLOWER_KEY_ENC_IP_TOS,	/* u8 */
5560e2c17b6SOr Gerlitz 	TCA_FLOWER_KEY_ENC_IP_TOS_MASK,	/* u8 */
5570e2c17b6SOr Gerlitz 	TCA_FLOWER_KEY_ENC_IP_TTL,	/* u8 */
5580e2c17b6SOr Gerlitz 	TCA_FLOWER_KEY_ENC_IP_TTL_MASK,	/* u8 */
5590e2c17b6SOr Gerlitz 
5600a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPTS,
5610a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPTS_MASK,
5620a6e7778SPieter Jansen van Vuuren 
56386c55361SVlad Buslov 	TCA_FLOWER_IN_HW_COUNT,
56486c55361SVlad Buslov 
5655c72299fSAmritha Nambiar 	TCA_FLOWER_KEY_PORT_SRC_MIN,	/* be16 */
5665c72299fSAmritha Nambiar 	TCA_FLOWER_KEY_PORT_SRC_MAX,	/* be16 */
5675c72299fSAmritha Nambiar 	TCA_FLOWER_KEY_PORT_DST_MIN,	/* be16 */
5685c72299fSAmritha Nambiar 	TCA_FLOWER_KEY_PORT_DST_MAX,	/* be16 */
5695c72299fSAmritha Nambiar 
570e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_STATE,	/* u16 */
571e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_STATE_MASK,	/* u16 */
572e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_ZONE,		/* u16 */
573e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_ZONE_MASK,	/* u16 */
574e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_MARK,		/* u32 */
575e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_MARK_MASK,	/* u32 */
576e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_LABELS,	/* u128 */
577e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_LABELS_MASK,	/* u128 */
578e0ace68aSPaul Blakey 
57961aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPTS,
58061aec25aSGuillaume Nault 
5815923b8f7SAriel Levkovich 	TCA_FLOWER_KEY_HASH,		/* u32 */
5825923b8f7SAriel Levkovich 	TCA_FLOWER_KEY_HASH_MASK,	/* u32 */
5835923b8f7SAriel Levkovich 
58477b9900eSJiri Pirko 	__TCA_FLOWER_MAX,
58577b9900eSJiri Pirko };
58677b9900eSJiri Pirko 
58777b9900eSJiri Pirko #define TCA_FLOWER_MAX (__TCA_FLOWER_MAX - 1)
58877b9900eSJiri Pirko 
589faa3ffceSOr Gerlitz enum {
590e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_FLAGS_NEW = 1 << 0, /* Beginning of a new connection. */
591e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_FLAGS_ESTABLISHED = 1 << 1, /* Part of an existing connection. */
592e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_FLAGS_RELATED = 1 << 2, /* Related to an established connection. */
593e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_FLAGS_TRACKED = 1 << 3, /* Conntrack has occurred. */
5947baf2429Swenxu 	TCA_FLOWER_KEY_CT_FLAGS_INVALID = 1 << 4, /* Conntrack is invalid. */
595*8c85d18cSPaul Blakey 	TCA_FLOWER_KEY_CT_FLAGS_REPLY = 1 << 5, /* Packet is in the reply direction. */
596e0ace68aSPaul Blakey };
597e0ace68aSPaul Blakey 
598e0ace68aSPaul Blakey enum {
5990a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPTS_UNSPEC,
6000a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPTS_GENEVE, /* Nested
6010a6e7778SPieter Jansen van Vuuren 					 * TCA_FLOWER_KEY_ENC_OPT_GENEVE_
6020a6e7778SPieter Jansen van Vuuren 					 * attributes
6030a6e7778SPieter Jansen van Vuuren 					 */
604d8f9dfaeSXin Long 	TCA_FLOWER_KEY_ENC_OPTS_VXLAN,	/* Nested
605d8f9dfaeSXin Long 					 * TCA_FLOWER_KEY_ENC_OPT_VXLAN_
606d8f9dfaeSXin Long 					 * attributes
607d8f9dfaeSXin Long 					 */
60879b1011cSXin Long 	TCA_FLOWER_KEY_ENC_OPTS_ERSPAN,	/* Nested
60979b1011cSXin Long 					 * TCA_FLOWER_KEY_ENC_OPT_ERSPAN_
61079b1011cSXin Long 					 * attributes
61179b1011cSXin Long 					 */
6120a6e7778SPieter Jansen van Vuuren 	__TCA_FLOWER_KEY_ENC_OPTS_MAX,
6130a6e7778SPieter Jansen van Vuuren };
6140a6e7778SPieter Jansen van Vuuren 
6150a6e7778SPieter Jansen van Vuuren #define TCA_FLOWER_KEY_ENC_OPTS_MAX (__TCA_FLOWER_KEY_ENC_OPTS_MAX - 1)
6160a6e7778SPieter Jansen van Vuuren 
6170a6e7778SPieter Jansen van Vuuren enum {
6180a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPT_GENEVE_UNSPEC,
6190a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPT_GENEVE_CLASS,            /* u16 */
6200a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPT_GENEVE_TYPE,             /* u8 */
6210a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPT_GENEVE_DATA,             /* 4 to 128 bytes */
6220a6e7778SPieter Jansen van Vuuren 
6230a6e7778SPieter Jansen van Vuuren 	__TCA_FLOWER_KEY_ENC_OPT_GENEVE_MAX,
6240a6e7778SPieter Jansen van Vuuren };
6250a6e7778SPieter Jansen van Vuuren 
6260a6e7778SPieter Jansen van Vuuren #define TCA_FLOWER_KEY_ENC_OPT_GENEVE_MAX \
6270a6e7778SPieter Jansen van Vuuren 		(__TCA_FLOWER_KEY_ENC_OPT_GENEVE_MAX - 1)
6280a6e7778SPieter Jansen van Vuuren 
6290a6e7778SPieter Jansen van Vuuren enum {
630d8f9dfaeSXin Long 	TCA_FLOWER_KEY_ENC_OPT_VXLAN_UNSPEC,
631d8f9dfaeSXin Long 	TCA_FLOWER_KEY_ENC_OPT_VXLAN_GBP,		/* u32 */
632d8f9dfaeSXin Long 	__TCA_FLOWER_KEY_ENC_OPT_VXLAN_MAX,
633d8f9dfaeSXin Long };
634d8f9dfaeSXin Long 
635d8f9dfaeSXin Long #define TCA_FLOWER_KEY_ENC_OPT_VXLAN_MAX \
636d8f9dfaeSXin Long 		(__TCA_FLOWER_KEY_ENC_OPT_VXLAN_MAX - 1)
637d8f9dfaeSXin Long 
638d8f9dfaeSXin Long enum {
63979b1011cSXin Long 	TCA_FLOWER_KEY_ENC_OPT_ERSPAN_UNSPEC,
64079b1011cSXin Long 	TCA_FLOWER_KEY_ENC_OPT_ERSPAN_VER,              /* u8 */
64179b1011cSXin Long 	TCA_FLOWER_KEY_ENC_OPT_ERSPAN_INDEX,            /* be32 */
64279b1011cSXin Long 	TCA_FLOWER_KEY_ENC_OPT_ERSPAN_DIR,              /* u8 */
64379b1011cSXin Long 	TCA_FLOWER_KEY_ENC_OPT_ERSPAN_HWID,             /* u8 */
64479b1011cSXin Long 	__TCA_FLOWER_KEY_ENC_OPT_ERSPAN_MAX,
64579b1011cSXin Long };
64679b1011cSXin Long 
64779b1011cSXin Long #define TCA_FLOWER_KEY_ENC_OPT_ERSPAN_MAX \
64879b1011cSXin Long 		(__TCA_FLOWER_KEY_ENC_OPT_ERSPAN_MAX - 1)
64979b1011cSXin Long 
65079b1011cSXin Long enum {
65161aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPTS_UNSPEC,
65261aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPTS_LSE,
65361aec25aSGuillaume Nault 	__TCA_FLOWER_KEY_MPLS_OPTS_MAX,
65461aec25aSGuillaume Nault };
65561aec25aSGuillaume Nault 
65661aec25aSGuillaume Nault #define TCA_FLOWER_KEY_MPLS_OPTS_MAX (__TCA_FLOWER_KEY_MPLS_OPTS_MAX - 1)
65761aec25aSGuillaume Nault 
65861aec25aSGuillaume Nault enum {
65961aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPT_LSE_UNSPEC,
66061aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPT_LSE_DEPTH,
66161aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPT_LSE_TTL,
66261aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPT_LSE_BOS,
66361aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPT_LSE_TC,
66461aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPT_LSE_LABEL,
66561aec25aSGuillaume Nault 	__TCA_FLOWER_KEY_MPLS_OPT_LSE_MAX,
66661aec25aSGuillaume Nault };
66761aec25aSGuillaume Nault 
66861aec25aSGuillaume Nault #define TCA_FLOWER_KEY_MPLS_OPT_LSE_MAX \
66961aec25aSGuillaume Nault 		(__TCA_FLOWER_KEY_MPLS_OPT_LSE_MAX - 1)
67061aec25aSGuillaume Nault 
67161aec25aSGuillaume Nault enum {
672faa3ffceSOr Gerlitz 	TCA_FLOWER_KEY_FLAGS_IS_FRAGMENT = (1 << 0),
673459d153dSPieter Jansen van Vuuren 	TCA_FLOWER_KEY_FLAGS_FRAG_IS_FIRST = (1 << 1),
674faa3ffceSOr Gerlitz };
675faa3ffceSOr Gerlitz 
6765c72299fSAmritha Nambiar #define TCA_FLOWER_MASK_FLAGS_RANGE	(1 << 0) /* Range-based match */
6775c72299fSAmritha Nambiar 
678bf3994d2SJiri Pirko /* Match-all classifier */
679bf3994d2SJiri Pirko 
680f88c19aaSCong Wang struct tc_matchall_pcnt {
681f88c19aaSCong Wang 	__u64 rhit;
682f88c19aaSCong Wang };
683f88c19aaSCong Wang 
684bf3994d2SJiri Pirko enum {
685bf3994d2SJiri Pirko 	TCA_MATCHALL_UNSPEC,
686bf3994d2SJiri Pirko 	TCA_MATCHALL_CLASSID,
687bf3994d2SJiri Pirko 	TCA_MATCHALL_ACT,
688b87f7936SYotam Gigi 	TCA_MATCHALL_FLAGS,
689f88c19aaSCong Wang 	TCA_MATCHALL_PCNT,
690f88c19aaSCong Wang 	TCA_MATCHALL_PAD,
691bf3994d2SJiri Pirko 	__TCA_MATCHALL_MAX,
692bf3994d2SJiri Pirko };
693bf3994d2SJiri Pirko 
694bf3994d2SJiri Pirko #define TCA_MATCHALL_MAX (__TCA_MATCHALL_MAX - 1)
695bf3994d2SJiri Pirko 
696607ca46eSDavid Howells /* Extended Matches */
697607ca46eSDavid Howells 
698607ca46eSDavid Howells struct tcf_ematch_tree_hdr {
699607ca46eSDavid Howells 	__u16		nmatches;
700607ca46eSDavid Howells 	__u16		progid;
701607ca46eSDavid Howells };
702607ca46eSDavid Howells 
703607ca46eSDavid Howells enum {
704607ca46eSDavid Howells 	TCA_EMATCH_TREE_UNSPEC,
705607ca46eSDavid Howells 	TCA_EMATCH_TREE_HDR,
706607ca46eSDavid Howells 	TCA_EMATCH_TREE_LIST,
707607ca46eSDavid Howells 	__TCA_EMATCH_TREE_MAX
708607ca46eSDavid Howells };
709607ca46eSDavid Howells #define TCA_EMATCH_TREE_MAX (__TCA_EMATCH_TREE_MAX - 1)
710607ca46eSDavid Howells 
711607ca46eSDavid Howells struct tcf_ematch_hdr {
712607ca46eSDavid Howells 	__u16		matchid;
713607ca46eSDavid Howells 	__u16		kind;
714607ca46eSDavid Howells 	__u16		flags;
715607ca46eSDavid Howells 	__u16		pad; /* currently unused */
716607ca46eSDavid Howells };
717607ca46eSDavid Howells 
718607ca46eSDavid Howells /*  0                   1
719607ca46eSDavid Howells  *  0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5
720607ca46eSDavid Howells  * +-----------------------+-+-+---+
721607ca46eSDavid Howells  * |         Unused        |S|I| R |
722607ca46eSDavid Howells  * +-----------------------+-+-+---+
723607ca46eSDavid Howells  *
724607ca46eSDavid Howells  * R(2) ::= relation to next ematch
725607ca46eSDavid Howells  *          where: 0 0 END (last ematch)
726607ca46eSDavid Howells  *                 0 1 AND
727607ca46eSDavid Howells  *                 1 0 OR
728607ca46eSDavid Howells  *                 1 1 Unused (invalid)
729607ca46eSDavid Howells  * I(1) ::= invert result
730607ca46eSDavid Howells  * S(1) ::= simple payload
731607ca46eSDavid Howells  */
732607ca46eSDavid Howells #define TCF_EM_REL_END	0
733607ca46eSDavid Howells #define TCF_EM_REL_AND	(1<<0)
734607ca46eSDavid Howells #define TCF_EM_REL_OR	(1<<1)
735607ca46eSDavid Howells #define TCF_EM_INVERT	(1<<2)
736607ca46eSDavid Howells #define TCF_EM_SIMPLE	(1<<3)
737607ca46eSDavid Howells 
738607ca46eSDavid Howells #define TCF_EM_REL_MASK	3
739607ca46eSDavid Howells #define TCF_EM_REL_VALID(v) (((v) & TCF_EM_REL_MASK) != TCF_EM_REL_MASK)
740607ca46eSDavid Howells 
741607ca46eSDavid Howells enum {
742607ca46eSDavid Howells 	TCF_LAYER_LINK,
743607ca46eSDavid Howells 	TCF_LAYER_NETWORK,
744607ca46eSDavid Howells 	TCF_LAYER_TRANSPORT,
745607ca46eSDavid Howells 	__TCF_LAYER_MAX
746607ca46eSDavid Howells };
747607ca46eSDavid Howells #define TCF_LAYER_MAX (__TCF_LAYER_MAX - 1)
748607ca46eSDavid Howells 
749607ca46eSDavid Howells /* Ematch type assignments
750607ca46eSDavid Howells  *   1..32767		Reserved for ematches inside kernel tree
751607ca46eSDavid Howells  *   32768..65535	Free to use, not reliable
752607ca46eSDavid Howells  */
753607ca46eSDavid Howells #define	TCF_EM_CONTAINER	0
754607ca46eSDavid Howells #define	TCF_EM_CMP		1
755607ca46eSDavid Howells #define	TCF_EM_NBYTE		2
756607ca46eSDavid Howells #define	TCF_EM_U32		3
757607ca46eSDavid Howells #define	TCF_EM_META		4
758607ca46eSDavid Howells #define	TCF_EM_TEXT		5
759607ca46eSDavid Howells #define	TCF_EM_VLAN		6
760607ca46eSDavid Howells #define	TCF_EM_CANID		7
761607ca46eSDavid Howells #define	TCF_EM_IPSET		8
762ccc007e4SEyal Birger #define	TCF_EM_IPT		9
763ccc007e4SEyal Birger #define	TCF_EM_MAX		9
764607ca46eSDavid Howells 
765607ca46eSDavid Howells enum {
766607ca46eSDavid Howells 	TCF_EM_PROG_TC
767607ca46eSDavid Howells };
768607ca46eSDavid Howells 
769607ca46eSDavid Howells enum {
770607ca46eSDavid Howells 	TCF_EM_OPND_EQ,
771607ca46eSDavid Howells 	TCF_EM_OPND_GT,
772607ca46eSDavid Howells 	TCF_EM_OPND_LT
773607ca46eSDavid Howells };
774607ca46eSDavid Howells 
775607ca46eSDavid Howells #endif
776