xref: /linux/include/uapi/linux/pkt_cls.h (revision fe33c0fbed75dd464747c0faaedf94c7d8eb4101)
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,
227adc5765SBaowen Zheng 	TCA_ACT_IN_HW_COUNT,
23607ca46eSDavid Howells 	__TCA_ACT_MAX
24607ca46eSDavid Howells };
25607ca46eSDavid Howells 
26695176bfSCong Wang /* See other TCA_ACT_FLAGS_ * flags in include/net/act_api.h. */
277adc5765SBaowen Zheng #define TCA_ACT_FLAGS_NO_PERCPU_STATS (1 << 0) /* Don't use percpu allocator for
28abbb0d33SVlad Buslov 						* actions stats.
29abbb0d33SVlad Buslov 						*/
307adc5765SBaowen Zheng #define TCA_ACT_FLAGS_SKIP_HW	(1 << 1) /* don't offload action to HW */
317adc5765SBaowen Zheng #define TCA_ACT_FLAGS_SKIP_SW	(1 << 2) /* don't use action in SW */
32abbb0d33SVlad Buslov 
3344f86580SJiri Pirko /* tca HW stats type
3444f86580SJiri Pirko  * When user does not pass the attribute, he does not care.
3544f86580SJiri Pirko  * It is the same as if he would pass the attribute with
3644f86580SJiri Pirko  * all supported bits set.
3744f86580SJiri Pirko  * In case no bits are set, user is not interested in getting any HW statistics.
3844f86580SJiri Pirko  */
390dfb2d82SJakub Kicinski #define TCA_ACT_HW_STATS_IMMEDIATE (1 << 0) /* Means that in dump, user
4044f86580SJiri Pirko 					     * gets the current HW stats
4144f86580SJiri Pirko 					     * state from the device
4244f86580SJiri Pirko 					     * queried at the dump time.
4344f86580SJiri Pirko 					     */
440dfb2d82SJakub Kicinski #define TCA_ACT_HW_STATS_DELAYED (1 << 1) /* Means that in dump, user gets
450dfb2d82SJakub Kicinski 					   * HW stats that might be out of date
460dfb2d82SJakub Kicinski 					   * for some time, maybe couple of
470dfb2d82SJakub Kicinski 					   * seconds. This is the case when
480dfb2d82SJakub Kicinski 					   * driver polls stats updates
490dfb2d82SJakub Kicinski 					   * periodically or when it gets async
500dfb2d82SJakub Kicinski 					   * stats update from the device.
5144f86580SJiri Pirko 					   */
5244f86580SJiri Pirko 
53607ca46eSDavid Howells #define TCA_ACT_MAX __TCA_ACT_MAX
54607ca46eSDavid Howells #define TCA_OLD_COMPAT (TCA_ACT_MAX+1)
55607ca46eSDavid Howells #define TCA_ACT_MAX_PRIO 32
56607ca46eSDavid Howells #define TCA_ACT_BIND	1
57607ca46eSDavid Howells #define TCA_ACT_NOBIND	0
58607ca46eSDavid Howells #define TCA_ACT_UNBIND	1
59607ca46eSDavid Howells #define TCA_ACT_NOUNBIND	0
60607ca46eSDavid Howells #define TCA_ACT_REPLACE		1
61607ca46eSDavid Howells #define TCA_ACT_NOREPLACE	0
62607ca46eSDavid Howells 
63607ca46eSDavid Howells #define TC_ACT_UNSPEC	(-1)
64607ca46eSDavid Howells #define TC_ACT_OK		0
65607ca46eSDavid Howells #define TC_ACT_RECLASSIFY	1
66607ca46eSDavid Howells #define TC_ACT_SHOT		2
67607ca46eSDavid Howells #define TC_ACT_PIPE		3
68607ca46eSDavid Howells #define TC_ACT_STOLEN		4
69607ca46eSDavid Howells #define TC_ACT_QUEUED		5
70607ca46eSDavid Howells #define TC_ACT_REPEAT		6
7127b29f63SAlexei Starovoitov #define TC_ACT_REDIRECT		7
72e25ea21fSJiri Pirko #define TC_ACT_TRAP		8 /* For hw path, this means "trap to cpu"
73e25ea21fSJiri Pirko 				   * and don't further process the frame
74e25ea21fSJiri Pirko 				   * in hardware. For sw path, this is
75e25ea21fSJiri Pirko 				   * equivalent of TC_ACT_STOLEN - drop
76e25ea21fSJiri Pirko 				   * the skb and act like everything
77e25ea21fSJiri Pirko 				   * is alright.
78e25ea21fSJiri Pirko 				   */
79802bfb19SPaolo Abeni #define TC_ACT_VALUE_MAX	TC_ACT_TRAP
809da3242eSJiri Pirko 
819da3242eSJiri Pirko /* There is a special kind of actions called "extended actions",
829da3242eSJiri Pirko  * which need a value parameter. These have a local opcode located in
839da3242eSJiri Pirko  * the highest nibble, starting from 1. The rest of the bits
849da3242eSJiri Pirko  * are used to carry the value. These two parts together make
859da3242eSJiri Pirko  * a combined opcode.
869da3242eSJiri Pirko  */
879da3242eSJiri Pirko #define __TC_ACT_EXT_SHIFT 28
889da3242eSJiri Pirko #define __TC_ACT_EXT(local) ((local) << __TC_ACT_EXT_SHIFT)
899da3242eSJiri Pirko #define TC_ACT_EXT_VAL_MASK ((1 << __TC_ACT_EXT_SHIFT) - 1)
90802bfb19SPaolo Abeni #define TC_ACT_EXT_OPCODE(combined) ((combined) & (~TC_ACT_EXT_VAL_MASK))
91802bfb19SPaolo Abeni #define TC_ACT_EXT_CMP(combined, opcode) (TC_ACT_EXT_OPCODE(combined) == opcode)
929da3242eSJiri Pirko 
939da3242eSJiri Pirko #define TC_ACT_JUMP __TC_ACT_EXT(1)
94db50514fSJiri Pirko #define TC_ACT_GOTO_CHAIN __TC_ACT_EXT(2)
95802bfb19SPaolo Abeni #define TC_ACT_EXT_OPCODE_MAX	TC_ACT_GOTO_CHAIN
96607ca46eSDavid Howells 
97257eededSEli Cohen /* These macros are put here for binary compatibility with userspace apps that
98257eededSEli Cohen  * make use of them. For kernel code and new userspace apps, use the TCA_ID_*
99257eededSEli Cohen  * versions.
100257eededSEli Cohen  */
101257eededSEli Cohen #define TCA_ACT_GACT 5
102*ba24ea12SJamal Hadi Salim #define TCA_ACT_IPT 6 /* obsoleted, can be reused */
103257eededSEli Cohen #define TCA_ACT_PEDIT 7
104257eededSEli Cohen #define TCA_ACT_MIRRED 8
105257eededSEli Cohen #define TCA_ACT_NAT 9
106257eededSEli Cohen #define TCA_ACT_XT 10
107257eededSEli Cohen #define TCA_ACT_SKBEDIT 11
108257eededSEli Cohen #define TCA_ACT_VLAN 12
109257eededSEli Cohen #define TCA_ACT_BPF 13
110257eededSEli Cohen #define TCA_ACT_CONNMARK 14
111257eededSEli Cohen #define TCA_ACT_SKBMOD 15
112257eededSEli Cohen #define TCA_ACT_CSUM 16
113257eededSEli Cohen #define TCA_ACT_TUNNEL_KEY 17
114257eededSEli Cohen #define TCA_ACT_SIMP 22
115257eededSEli Cohen #define TCA_ACT_IFE 25
116257eededSEli Cohen #define TCA_ACT_SAMPLE 26
117257eededSEli Cohen 
118607ca46eSDavid Howells /* Action type identifiers*/
119eddd2cf1SEli Cohen enum tca_id {
120607ca46eSDavid Howells 	TCA_ID_UNSPEC = 0,
121607ca46eSDavid Howells 	TCA_ID_POLICE = 1,
122257eededSEli Cohen 	TCA_ID_GACT = TCA_ACT_GACT,
123*ba24ea12SJamal Hadi Salim 	TCA_ID_IPT = TCA_ACT_IPT, /* Obsoleted, can be reused */
124257eededSEli Cohen 	TCA_ID_PEDIT = TCA_ACT_PEDIT,
125257eededSEli Cohen 	TCA_ID_MIRRED = TCA_ACT_MIRRED,
126257eededSEli Cohen 	TCA_ID_NAT = TCA_ACT_NAT,
127257eededSEli Cohen 	TCA_ID_XT = TCA_ACT_XT,
128257eededSEli Cohen 	TCA_ID_SKBEDIT = TCA_ACT_SKBEDIT,
129257eededSEli Cohen 	TCA_ID_VLAN = TCA_ACT_VLAN,
130257eededSEli Cohen 	TCA_ID_BPF = TCA_ACT_BPF,
131257eededSEli Cohen 	TCA_ID_CONNMARK = TCA_ACT_CONNMARK,
132257eededSEli Cohen 	TCA_ID_SKBMOD = TCA_ACT_SKBMOD,
133257eededSEli Cohen 	TCA_ID_CSUM = TCA_ACT_CSUM,
134257eededSEli Cohen 	TCA_ID_TUNNEL_KEY = TCA_ACT_TUNNEL_KEY,
135257eededSEli Cohen 	TCA_ID_SIMP = TCA_ACT_SIMP,
136257eededSEli Cohen 	TCA_ID_IFE = TCA_ACT_IFE,
137257eededSEli Cohen 	TCA_ID_SAMPLE = TCA_ACT_SAMPLE,
13824ec483cSKevin 'ldir' Darbyshire-Bryant 	TCA_ID_CTINFO,
1392a2ea508SJohn Hurley 	TCA_ID_MPLS,
140b57dc7c1SPaul Blakey 	TCA_ID_CT,
141a51c328dSPo Liu 	TCA_ID_GATE,
1422a2ea508SJohn Hurley 	/* other actions go here */
143607ca46eSDavid Howells 	__TCA_ID_MAX = 255
144607ca46eSDavid Howells };
145607ca46eSDavid Howells 
146607ca46eSDavid Howells #define TCA_ID_MAX __TCA_ID_MAX
147607ca46eSDavid Howells 
148607ca46eSDavid Howells struct tc_police {
149607ca46eSDavid Howells 	__u32			index;
150607ca46eSDavid Howells 	int			action;
151607ca46eSDavid Howells #define TC_POLICE_UNSPEC	TC_ACT_UNSPEC
152607ca46eSDavid Howells #define TC_POLICE_OK		TC_ACT_OK
153607ca46eSDavid Howells #define TC_POLICE_RECLASSIFY	TC_ACT_RECLASSIFY
154607ca46eSDavid Howells #define TC_POLICE_SHOT		TC_ACT_SHOT
155607ca46eSDavid Howells #define TC_POLICE_PIPE		TC_ACT_PIPE
156607ca46eSDavid Howells 
157607ca46eSDavid Howells 	__u32			limit;
158607ca46eSDavid Howells 	__u32			burst;
159607ca46eSDavid Howells 	__u32			mtu;
160607ca46eSDavid Howells 	struct tc_ratespec	rate;
161607ca46eSDavid Howells 	struct tc_ratespec	peakrate;
162607ca46eSDavid Howells 	int			refcnt;
163607ca46eSDavid Howells 	int			bindcnt;
164607ca46eSDavid Howells 	__u32			capab;
165607ca46eSDavid Howells };
166607ca46eSDavid Howells 
167607ca46eSDavid Howells struct tcf_t {
168607ca46eSDavid Howells 	__u64   install;
169607ca46eSDavid Howells 	__u64   lastuse;
170607ca46eSDavid Howells 	__u64   expires;
17153eb440fSJamal Hadi Salim 	__u64   firstuse;
172607ca46eSDavid Howells };
173607ca46eSDavid Howells 
174607ca46eSDavid Howells struct tc_cnt {
175607ca46eSDavid Howells 	int                   refcnt;
176607ca46eSDavid Howells 	int                   bindcnt;
177607ca46eSDavid Howells };
178607ca46eSDavid Howells 
179607ca46eSDavid Howells #define tc_gen \
180607ca46eSDavid Howells 	__u32                 index; \
181607ca46eSDavid Howells 	__u32                 capab; \
182607ca46eSDavid Howells 	int                   action; \
183607ca46eSDavid Howells 	int                   refcnt; \
184607ca46eSDavid Howells 	int                   bindcnt
185607ca46eSDavid Howells 
186607ca46eSDavid Howells enum {
187607ca46eSDavid Howells 	TCA_POLICE_UNSPEC,
188607ca46eSDavid Howells 	TCA_POLICE_TBF,
189607ca46eSDavid Howells 	TCA_POLICE_RATE,
190607ca46eSDavid Howells 	TCA_POLICE_PEAKRATE,
191607ca46eSDavid Howells 	TCA_POLICE_AVRATE,
192607ca46eSDavid Howells 	TCA_POLICE_RESULT,
1933d3ed181SJamal Hadi Salim 	TCA_POLICE_TM,
1943d3ed181SJamal Hadi Salim 	TCA_POLICE_PAD,
195d1967e49SDavid Dai 	TCA_POLICE_RATE64,
196d1967e49SDavid Dai 	TCA_POLICE_PEAKRATE64,
1972ffe0395SBaowen Zheng 	TCA_POLICE_PKTRATE64,
1982ffe0395SBaowen Zheng 	TCA_POLICE_PKTBURST64,
199607ca46eSDavid Howells 	__TCA_POLICE_MAX
200607ca46eSDavid Howells #define TCA_POLICE_RESULT TCA_POLICE_RESULT
201607ca46eSDavid Howells };
202607ca46eSDavid Howells 
203607ca46eSDavid Howells #define TCA_POLICE_MAX (__TCA_POLICE_MAX - 1)
204607ca46eSDavid Howells 
205760edee8SSamudrala, Sridhar /* tca flags definitions */
206e696028aSOr Gerlitz #define TCA_CLS_FLAGS_SKIP_HW	(1 << 0) /* don't offload filter to HW */
207e696028aSOr Gerlitz #define TCA_CLS_FLAGS_SKIP_SW	(1 << 1) /* don't use filter in SW */
208e696028aSOr Gerlitz #define TCA_CLS_FLAGS_IN_HW	(1 << 2) /* filter is offloaded to HW */
209e696028aSOr Gerlitz #define TCA_CLS_FLAGS_NOT_IN_HW (1 << 3) /* filter isn't offloaded to HW */
21081c7288bSMarcelo Ricardo Leitner #define TCA_CLS_FLAGS_VERBOSE	(1 << 4) /* verbose logging */
211760edee8SSamudrala, Sridhar 
212607ca46eSDavid Howells /* U32 filters */
213607ca46eSDavid Howells 
214607ca46eSDavid Howells #define TC_U32_HTID(h) ((h)&0xFFF00000)
215607ca46eSDavid Howells #define TC_U32_USERHTID(h) (TC_U32_HTID(h)>>20)
216607ca46eSDavid Howells #define TC_U32_HASH(h) (((h)>>12)&0xFF)
217607ca46eSDavid Howells #define TC_U32_NODE(h) ((h)&0xFFF)
218607ca46eSDavid Howells #define TC_U32_KEY(h) ((h)&0xFFFFF)
219607ca46eSDavid Howells #define TC_U32_UNSPEC	0
220607ca46eSDavid Howells #define TC_U32_ROOT	(0xFFF00000)
221607ca46eSDavid Howells 
222607ca46eSDavid Howells enum {
223607ca46eSDavid Howells 	TCA_U32_UNSPEC,
224607ca46eSDavid Howells 	TCA_U32_CLASSID,
225607ca46eSDavid Howells 	TCA_U32_HASH,
226607ca46eSDavid Howells 	TCA_U32_LINK,
227607ca46eSDavid Howells 	TCA_U32_DIVISOR,
228607ca46eSDavid Howells 	TCA_U32_SEL,
229607ca46eSDavid Howells 	TCA_U32_POLICE,
230607ca46eSDavid Howells 	TCA_U32_ACT,
231607ca46eSDavid Howells 	TCA_U32_INDEV,
232607ca46eSDavid Howells 	TCA_U32_PCNT,
233607ca46eSDavid Howells 	TCA_U32_MARK,
2349e8ce79cSJohn Fastabend 	TCA_U32_FLAGS,
2359854518eSNicolas Dichtel 	TCA_U32_PAD,
236607ca46eSDavid Howells 	__TCA_U32_MAX
237607ca46eSDavid Howells };
238607ca46eSDavid Howells 
239607ca46eSDavid Howells #define TCA_U32_MAX (__TCA_U32_MAX - 1)
240607ca46eSDavid Howells 
241607ca46eSDavid Howells struct tc_u32_key {
242607ca46eSDavid Howells 	__be32		mask;
243607ca46eSDavid Howells 	__be32		val;
244607ca46eSDavid Howells 	int		off;
245607ca46eSDavid Howells 	int		offmask;
246607ca46eSDavid Howells };
247607ca46eSDavid Howells 
248607ca46eSDavid Howells struct tc_u32_sel {
249607ca46eSDavid Howells 	unsigned char		flags;
250607ca46eSDavid Howells 	unsigned char		offshift;
251607ca46eSDavid Howells 	unsigned char		nkeys;
252607ca46eSDavid Howells 
253607ca46eSDavid Howells 	__be16			offmask;
254607ca46eSDavid Howells 	__u16			off;
255607ca46eSDavid Howells 	short			offoff;
256607ca46eSDavid Howells 
257607ca46eSDavid Howells 	short			hoff;
258607ca46eSDavid Howells 	__be32			hmask;
25994dfc73eSGustavo A. R. Silva 	struct tc_u32_key	keys[];
260607ca46eSDavid Howells };
261607ca46eSDavid Howells 
262607ca46eSDavid Howells struct tc_u32_mark {
263607ca46eSDavid Howells 	__u32		val;
264607ca46eSDavid Howells 	__u32		mask;
265607ca46eSDavid Howells 	__u32		success;
266607ca46eSDavid Howells };
267607ca46eSDavid Howells 
268607ca46eSDavid Howells struct tc_u32_pcnt {
269607ca46eSDavid Howells 	__u64 rcnt;
270607ca46eSDavid Howells 	__u64 rhit;
27194dfc73eSGustavo A. R. Silva 	__u64 kcnts[];
272607ca46eSDavid Howells };
273607ca46eSDavid Howells 
274607ca46eSDavid Howells /* Flags */
275607ca46eSDavid Howells 
276607ca46eSDavid Howells #define TC_U32_TERMINAL		1
277607ca46eSDavid Howells #define TC_U32_OFFSET		2
278607ca46eSDavid Howells #define TC_U32_VAROFFSET	4
279607ca46eSDavid Howells #define TC_U32_EAT		8
280607ca46eSDavid Howells 
281607ca46eSDavid Howells #define TC_U32_MAXDEPTH 8
282607ca46eSDavid Howells 
283607ca46eSDavid Howells /* ROUTE filter */
284607ca46eSDavid Howells 
285607ca46eSDavid Howells enum {
286607ca46eSDavid Howells 	TCA_ROUTE4_UNSPEC,
287607ca46eSDavid Howells 	TCA_ROUTE4_CLASSID,
288607ca46eSDavid Howells 	TCA_ROUTE4_TO,
289607ca46eSDavid Howells 	TCA_ROUTE4_FROM,
290607ca46eSDavid Howells 	TCA_ROUTE4_IIF,
291607ca46eSDavid Howells 	TCA_ROUTE4_POLICE,
292607ca46eSDavid Howells 	TCA_ROUTE4_ACT,
293607ca46eSDavid Howells 	__TCA_ROUTE4_MAX
294607ca46eSDavid Howells };
295607ca46eSDavid Howells 
296607ca46eSDavid Howells #define TCA_ROUTE4_MAX (__TCA_ROUTE4_MAX - 1)
297607ca46eSDavid Howells 
298607ca46eSDavid Howells 
299607ca46eSDavid Howells /* FW filter */
300607ca46eSDavid Howells 
301607ca46eSDavid Howells enum {
302607ca46eSDavid Howells 	TCA_FW_UNSPEC,
303607ca46eSDavid Howells 	TCA_FW_CLASSID,
304607ca46eSDavid Howells 	TCA_FW_POLICE,
305a5148626SJiri Pirko 	TCA_FW_INDEV,
306607ca46eSDavid Howells 	TCA_FW_ACT, /* used by CONFIG_NET_CLS_ACT */
307607ca46eSDavid Howells 	TCA_FW_MASK,
308607ca46eSDavid Howells 	__TCA_FW_MAX
309607ca46eSDavid Howells };
310607ca46eSDavid Howells 
311607ca46eSDavid Howells #define TCA_FW_MAX (__TCA_FW_MAX - 1)
312607ca46eSDavid Howells 
313607ca46eSDavid Howells /* Flow filter */
314607ca46eSDavid Howells 
315607ca46eSDavid Howells enum {
316607ca46eSDavid Howells 	FLOW_KEY_SRC,
317607ca46eSDavid Howells 	FLOW_KEY_DST,
318607ca46eSDavid Howells 	FLOW_KEY_PROTO,
319607ca46eSDavid Howells 	FLOW_KEY_PROTO_SRC,
320607ca46eSDavid Howells 	FLOW_KEY_PROTO_DST,
321607ca46eSDavid Howells 	FLOW_KEY_IIF,
322607ca46eSDavid Howells 	FLOW_KEY_PRIORITY,
323607ca46eSDavid Howells 	FLOW_KEY_MARK,
324607ca46eSDavid Howells 	FLOW_KEY_NFCT,
325607ca46eSDavid Howells 	FLOW_KEY_NFCT_SRC,
326607ca46eSDavid Howells 	FLOW_KEY_NFCT_DST,
327607ca46eSDavid Howells 	FLOW_KEY_NFCT_PROTO_SRC,
328607ca46eSDavid Howells 	FLOW_KEY_NFCT_PROTO_DST,
329607ca46eSDavid Howells 	FLOW_KEY_RTCLASSID,
330607ca46eSDavid Howells 	FLOW_KEY_SKUID,
331607ca46eSDavid Howells 	FLOW_KEY_SKGID,
332607ca46eSDavid Howells 	FLOW_KEY_VLAN_TAG,
333607ca46eSDavid Howells 	FLOW_KEY_RXHASH,
334607ca46eSDavid Howells 	__FLOW_KEY_MAX,
335607ca46eSDavid Howells };
336607ca46eSDavid Howells 
337607ca46eSDavid Howells #define FLOW_KEY_MAX	(__FLOW_KEY_MAX - 1)
338607ca46eSDavid Howells 
339607ca46eSDavid Howells enum {
340607ca46eSDavid Howells 	FLOW_MODE_MAP,
341607ca46eSDavid Howells 	FLOW_MODE_HASH,
342607ca46eSDavid Howells };
343607ca46eSDavid Howells 
344607ca46eSDavid Howells enum {
345607ca46eSDavid Howells 	TCA_FLOW_UNSPEC,
346607ca46eSDavid Howells 	TCA_FLOW_KEYS,
347607ca46eSDavid Howells 	TCA_FLOW_MODE,
348607ca46eSDavid Howells 	TCA_FLOW_BASECLASS,
349607ca46eSDavid Howells 	TCA_FLOW_RSHIFT,
350607ca46eSDavid Howells 	TCA_FLOW_ADDEND,
351607ca46eSDavid Howells 	TCA_FLOW_MASK,
352607ca46eSDavid Howells 	TCA_FLOW_XOR,
353607ca46eSDavid Howells 	TCA_FLOW_DIVISOR,
354607ca46eSDavid Howells 	TCA_FLOW_ACT,
355607ca46eSDavid Howells 	TCA_FLOW_POLICE,
356607ca46eSDavid Howells 	TCA_FLOW_EMATCHES,
357607ca46eSDavid Howells 	TCA_FLOW_PERTURB,
358607ca46eSDavid Howells 	__TCA_FLOW_MAX
359607ca46eSDavid Howells };
360607ca46eSDavid Howells 
361607ca46eSDavid Howells #define TCA_FLOW_MAX	(__TCA_FLOW_MAX - 1)
362607ca46eSDavid Howells 
363607ca46eSDavid Howells /* Basic filter */
364607ca46eSDavid Howells 
3655954894bSCong Wang struct tc_basic_pcnt {
3665954894bSCong Wang 	__u64 rcnt;
3675954894bSCong Wang 	__u64 rhit;
3685954894bSCong Wang };
3695954894bSCong Wang 
370607ca46eSDavid Howells enum {
371607ca46eSDavid Howells 	TCA_BASIC_UNSPEC,
372607ca46eSDavid Howells 	TCA_BASIC_CLASSID,
373607ca46eSDavid Howells 	TCA_BASIC_EMATCHES,
374607ca46eSDavid Howells 	TCA_BASIC_ACT,
375607ca46eSDavid Howells 	TCA_BASIC_POLICE,
3765954894bSCong Wang 	TCA_BASIC_PCNT,
3775954894bSCong Wang 	TCA_BASIC_PAD,
378607ca46eSDavid Howells 	__TCA_BASIC_MAX
379607ca46eSDavid Howells };
380607ca46eSDavid Howells 
381607ca46eSDavid Howells #define TCA_BASIC_MAX (__TCA_BASIC_MAX - 1)
382607ca46eSDavid Howells 
383607ca46eSDavid Howells 
384607ca46eSDavid Howells /* Cgroup classifier */
385607ca46eSDavid Howells 
386607ca46eSDavid Howells enum {
387607ca46eSDavid Howells 	TCA_CGROUP_UNSPEC,
388607ca46eSDavid Howells 	TCA_CGROUP_ACT,
389607ca46eSDavid Howells 	TCA_CGROUP_POLICE,
390607ca46eSDavid Howells 	TCA_CGROUP_EMATCHES,
391607ca46eSDavid Howells 	__TCA_CGROUP_MAX,
392607ca46eSDavid Howells };
393607ca46eSDavid Howells 
394607ca46eSDavid Howells #define TCA_CGROUP_MAX (__TCA_CGROUP_MAX - 1)
395607ca46eSDavid Howells 
3967d1d65cbSDaniel Borkmann /* BPF classifier */
3977d1d65cbSDaniel Borkmann 
398045efa82SDaniel Borkmann #define TCA_BPF_FLAG_ACT_DIRECT		(1 << 0)
399045efa82SDaniel Borkmann 
4007d1d65cbSDaniel Borkmann enum {
4017d1d65cbSDaniel Borkmann 	TCA_BPF_UNSPEC,
4027d1d65cbSDaniel Borkmann 	TCA_BPF_ACT,
4037d1d65cbSDaniel Borkmann 	TCA_BPF_POLICE,
4047d1d65cbSDaniel Borkmann 	TCA_BPF_CLASSID,
4057d1d65cbSDaniel Borkmann 	TCA_BPF_OPS_LEN,
4067d1d65cbSDaniel Borkmann 	TCA_BPF_OPS,
407e2e9b654SDaniel Borkmann 	TCA_BPF_FD,
408e2e9b654SDaniel Borkmann 	TCA_BPF_NAME,
409045efa82SDaniel Borkmann 	TCA_BPF_FLAGS,
4100d01d45fSJakub Kicinski 	TCA_BPF_FLAGS_GEN,
411f1f7714eSDaniel Borkmann 	TCA_BPF_TAG,
412e8628307SDaniel Borkmann 	TCA_BPF_ID,
4137d1d65cbSDaniel Borkmann 	__TCA_BPF_MAX,
4147d1d65cbSDaniel Borkmann };
4157d1d65cbSDaniel Borkmann 
4167d1d65cbSDaniel Borkmann #define TCA_BPF_MAX (__TCA_BPF_MAX - 1)
4177d1d65cbSDaniel Borkmann 
41877b9900eSJiri Pirko /* Flower classifier */
41977b9900eSJiri Pirko 
42077b9900eSJiri Pirko enum {
42177b9900eSJiri Pirko 	TCA_FLOWER_UNSPEC,
42277b9900eSJiri Pirko 	TCA_FLOWER_CLASSID,
42377b9900eSJiri Pirko 	TCA_FLOWER_INDEV,
42477b9900eSJiri Pirko 	TCA_FLOWER_ACT,
42577b9900eSJiri Pirko 	TCA_FLOWER_KEY_ETH_DST,		/* ETH_ALEN */
42677b9900eSJiri Pirko 	TCA_FLOWER_KEY_ETH_DST_MASK,	/* ETH_ALEN */
42777b9900eSJiri Pirko 	TCA_FLOWER_KEY_ETH_SRC,		/* ETH_ALEN */
42877b9900eSJiri Pirko 	TCA_FLOWER_KEY_ETH_SRC_MASK,	/* ETH_ALEN */
42977b9900eSJiri Pirko 	TCA_FLOWER_KEY_ETH_TYPE,	/* be16 */
43077b9900eSJiri Pirko 	TCA_FLOWER_KEY_IP_PROTO,	/* u8 */
43177b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV4_SRC,	/* be32 */
43277b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV4_SRC_MASK,	/* be32 */
43377b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV4_DST,	/* be32 */
43477b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV4_DST_MASK,	/* be32 */
43577b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV6_SRC,	/* struct in6_addr */
43677b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV6_SRC_MASK,	/* struct in6_addr */
43777b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV6_DST,	/* struct in6_addr */
43877b9900eSJiri Pirko 	TCA_FLOWER_KEY_IPV6_DST_MASK,	/* struct in6_addr */
43977b9900eSJiri Pirko 	TCA_FLOWER_KEY_TCP_SRC,		/* be16 */
44077b9900eSJiri Pirko 	TCA_FLOWER_KEY_TCP_DST,		/* be16 */
44177b9900eSJiri Pirko 	TCA_FLOWER_KEY_UDP_SRC,		/* be16 */
44277b9900eSJiri Pirko 	TCA_FLOWER_KEY_UDP_DST,		/* be16 */
4435b33f488SAmir Vadai 
4445b33f488SAmir Vadai 	TCA_FLOWER_FLAGS,
44537a6c151SOr Gerlitz 	TCA_FLOWER_KEY_VLAN_ID,		/* be16 */
44637a6c151SOr Gerlitz 	TCA_FLOWER_KEY_VLAN_PRIO,	/* u8   */
44737a6c151SOr Gerlitz 	TCA_FLOWER_KEY_VLAN_ETH_TYPE,	/* be16 */
448bc3103f1SAmir Vadai 
449bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_KEY_ID,	/* be32 */
450bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV4_SRC,	/* be32 */
451bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV4_SRC_MASK,/* be32 */
452bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV4_DST,	/* be32 */
453bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV4_DST_MASK,/* be32 */
454bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV6_SRC,	/* struct in6_addr */
455bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV6_SRC_MASK,/* struct in6_addr */
456bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV6_DST,	/* struct in6_addr */
457bc3103f1SAmir Vadai 	TCA_FLOWER_KEY_ENC_IPV6_DST_MASK,/* struct in6_addr */
458bc3103f1SAmir Vadai 
459aa72d708SOr Gerlitz 	TCA_FLOWER_KEY_TCP_SRC_MASK,	/* be16 */
460aa72d708SOr Gerlitz 	TCA_FLOWER_KEY_TCP_DST_MASK,	/* be16 */
461aa72d708SOr Gerlitz 	TCA_FLOWER_KEY_UDP_SRC_MASK,	/* be16 */
462aa72d708SOr Gerlitz 	TCA_FLOWER_KEY_UDP_DST_MASK,	/* be16 */
4635976c5f4SSimon Horman 	TCA_FLOWER_KEY_SCTP_SRC_MASK,	/* be16 */
4645976c5f4SSimon Horman 	TCA_FLOWER_KEY_SCTP_DST_MASK,	/* be16 */
4655976c5f4SSimon Horman 
4665976c5f4SSimon Horman 	TCA_FLOWER_KEY_SCTP_SRC,	/* be16 */
4675976c5f4SSimon Horman 	TCA_FLOWER_KEY_SCTP_DST,	/* be16 */
468f4d997fdSHadar Hen Zion 
469f4d997fdSHadar Hen Zion 	TCA_FLOWER_KEY_ENC_UDP_SRC_PORT,	/* be16 */
470f4d997fdSHadar Hen Zion 	TCA_FLOWER_KEY_ENC_UDP_SRC_PORT_MASK,	/* be16 */
471f4d997fdSHadar Hen Zion 	TCA_FLOWER_KEY_ENC_UDP_DST_PORT,	/* be16 */
472f4d997fdSHadar Hen Zion 	TCA_FLOWER_KEY_ENC_UDP_DST_PORT_MASK,	/* be16 */
473faa3ffceSOr Gerlitz 
474faa3ffceSOr Gerlitz 	TCA_FLOWER_KEY_FLAGS,		/* be32 */
475faa3ffceSOr Gerlitz 	TCA_FLOWER_KEY_FLAGS_MASK,	/* be32 */
4767b684884SSimon Horman 
4777b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV4_CODE,	/* u8 */
4787b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV4_CODE_MASK,/* u8 */
4797b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV4_TYPE,	/* u8 */
4807b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV4_TYPE_MASK,/* u8 */
4817b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV6_CODE,	/* u8 */
4827b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV6_CODE_MASK,/* u8 */
4837b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV6_TYPE,	/* u8 */
4847b684884SSimon Horman 	TCA_FLOWER_KEY_ICMPV6_TYPE_MASK,/* u8 */
4857b684884SSimon Horman 
48699d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_SIP,		/* be32 */
48799d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_SIP_MASK,	/* be32 */
48899d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_TIP,		/* be32 */
48999d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_TIP_MASK,	/* be32 */
49099d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_OP,		/* u8 */
49199d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_OP_MASK,	/* u8 */
49299d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_SHA,		/* ETH_ALEN */
49399d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_SHA_MASK,	/* ETH_ALEN */
49499d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_THA,		/* ETH_ALEN */
49599d31326SSimon Horman 	TCA_FLOWER_KEY_ARP_THA_MASK,	/* ETH_ALEN */
49699d31326SSimon Horman 
497a577d8f7SBenjamin LaHaise 	TCA_FLOWER_KEY_MPLS_TTL,	/* u8 - 8 bits */
498a577d8f7SBenjamin LaHaise 	TCA_FLOWER_KEY_MPLS_BOS,	/* u8 - 1 bit */
499a577d8f7SBenjamin LaHaise 	TCA_FLOWER_KEY_MPLS_TC,		/* u8 - 3 bits */
500a577d8f7SBenjamin LaHaise 	TCA_FLOWER_KEY_MPLS_LABEL,	/* be32 - 20 bits */
501a577d8f7SBenjamin LaHaise 
502fdfc7dd6SJiri Pirko 	TCA_FLOWER_KEY_TCP_FLAGS,	/* be16 */
503fdfc7dd6SJiri Pirko 	TCA_FLOWER_KEY_TCP_FLAGS_MASK,	/* be16 */
504fdfc7dd6SJiri Pirko 
5054d80cc0aSOr Gerlitz 	TCA_FLOWER_KEY_IP_TOS,		/* u8 */
5064d80cc0aSOr Gerlitz 	TCA_FLOWER_KEY_IP_TOS_MASK,	/* u8 */
5074d80cc0aSOr Gerlitz 	TCA_FLOWER_KEY_IP_TTL,		/* u8 */
5084d80cc0aSOr Gerlitz 	TCA_FLOWER_KEY_IP_TTL_MASK,	/* u8 */
5094d80cc0aSOr Gerlitz 
510d64efd09SJianbo Liu 	TCA_FLOWER_KEY_CVLAN_ID,	/* be16 */
511d64efd09SJianbo Liu 	TCA_FLOWER_KEY_CVLAN_PRIO,	/* u8   */
512d64efd09SJianbo Liu 	TCA_FLOWER_KEY_CVLAN_ETH_TYPE,	/* be16 */
513d64efd09SJianbo Liu 
5140e2c17b6SOr Gerlitz 	TCA_FLOWER_KEY_ENC_IP_TOS,	/* u8 */
5150e2c17b6SOr Gerlitz 	TCA_FLOWER_KEY_ENC_IP_TOS_MASK,	/* u8 */
5160e2c17b6SOr Gerlitz 	TCA_FLOWER_KEY_ENC_IP_TTL,	/* u8 */
5170e2c17b6SOr Gerlitz 	TCA_FLOWER_KEY_ENC_IP_TTL_MASK,	/* u8 */
5180e2c17b6SOr Gerlitz 
5190a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPTS,
5200a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPTS_MASK,
5210a6e7778SPieter Jansen van Vuuren 
52286c55361SVlad Buslov 	TCA_FLOWER_IN_HW_COUNT,
52386c55361SVlad Buslov 
5245c72299fSAmritha Nambiar 	TCA_FLOWER_KEY_PORT_SRC_MIN,	/* be16 */
5255c72299fSAmritha Nambiar 	TCA_FLOWER_KEY_PORT_SRC_MAX,	/* be16 */
5265c72299fSAmritha Nambiar 	TCA_FLOWER_KEY_PORT_DST_MIN,	/* be16 */
5275c72299fSAmritha Nambiar 	TCA_FLOWER_KEY_PORT_DST_MAX,	/* be16 */
5285c72299fSAmritha Nambiar 
529e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_STATE,	/* u16 */
530e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_STATE_MASK,	/* u16 */
531e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_ZONE,		/* u16 */
532e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_ZONE_MASK,	/* u16 */
533e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_MARK,		/* u32 */
534e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_MARK_MASK,	/* u32 */
535e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_LABELS,	/* u128 */
536e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_LABELS_MASK,	/* u128 */
537e0ace68aSPaul Blakey 
53861aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPTS,
53961aec25aSGuillaume Nault 
5405923b8f7SAriel Levkovich 	TCA_FLOWER_KEY_HASH,		/* u32 */
5415923b8f7SAriel Levkovich 	TCA_FLOWER_KEY_HASH_MASK,	/* u32 */
5425923b8f7SAriel Levkovich 
543b4000312SBoris Sukholitko 	TCA_FLOWER_KEY_NUM_OF_VLANS,    /* u8 */
544b4000312SBoris Sukholitko 
5455008750eSWojciech Drewek 	TCA_FLOWER_KEY_PPPOE_SID,	/* be16 */
5465008750eSWojciech Drewek 	TCA_FLOWER_KEY_PPP_PROTO,	/* be16 */
5475008750eSWojciech Drewek 
5488b189ea0SWojciech Drewek 	TCA_FLOWER_KEY_L2TPV3_SID,	/* be32 */
5498b189ea0SWojciech Drewek 
5501a432018SIdo Schimmel 	TCA_FLOWER_L2_MISS,		/* u8 */
5511a432018SIdo Schimmel 
5527cfffd5fSZahari Doychev 	TCA_FLOWER_KEY_CFM,		/* nested */
5537cfffd5fSZahari Doychev 
5544c13eda7SRatheesh Kannoth 	TCA_FLOWER_KEY_SPI,		/* be32 */
5554c13eda7SRatheesh Kannoth 	TCA_FLOWER_KEY_SPI_MASK,	/* be32 */
5564c13eda7SRatheesh Kannoth 
55777b9900eSJiri Pirko 	__TCA_FLOWER_MAX,
55877b9900eSJiri Pirko };
55977b9900eSJiri Pirko 
56077b9900eSJiri Pirko #define TCA_FLOWER_MAX (__TCA_FLOWER_MAX - 1)
56177b9900eSJiri Pirko 
562faa3ffceSOr Gerlitz enum {
563e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_FLAGS_NEW = 1 << 0, /* Beginning of a new connection. */
564e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_FLAGS_ESTABLISHED = 1 << 1, /* Part of an existing connection. */
565e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_FLAGS_RELATED = 1 << 2, /* Related to an established connection. */
566e0ace68aSPaul Blakey 	TCA_FLOWER_KEY_CT_FLAGS_TRACKED = 1 << 3, /* Conntrack has occurred. */
5677baf2429Swenxu 	TCA_FLOWER_KEY_CT_FLAGS_INVALID = 1 << 4, /* Conntrack is invalid. */
5688c85d18cSPaul Blakey 	TCA_FLOWER_KEY_CT_FLAGS_REPLY = 1 << 5, /* Packet is in the reply direction. */
5691bcc51acSwenxu 	__TCA_FLOWER_KEY_CT_FLAGS_MAX,
570e0ace68aSPaul Blakey };
571e0ace68aSPaul Blakey 
572e0ace68aSPaul Blakey enum {
5730a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPTS_UNSPEC,
5740a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPTS_GENEVE, /* Nested
5750a6e7778SPieter Jansen van Vuuren 					 * TCA_FLOWER_KEY_ENC_OPT_GENEVE_
5760a6e7778SPieter Jansen van Vuuren 					 * attributes
5770a6e7778SPieter Jansen van Vuuren 					 */
578d8f9dfaeSXin Long 	TCA_FLOWER_KEY_ENC_OPTS_VXLAN,	/* Nested
579d8f9dfaeSXin Long 					 * TCA_FLOWER_KEY_ENC_OPT_VXLAN_
580d8f9dfaeSXin Long 					 * attributes
581d8f9dfaeSXin Long 					 */
58279b1011cSXin Long 	TCA_FLOWER_KEY_ENC_OPTS_ERSPAN,	/* Nested
58379b1011cSXin Long 					 * TCA_FLOWER_KEY_ENC_OPT_ERSPAN_
58479b1011cSXin Long 					 * attributes
58579b1011cSXin Long 					 */
586e3acda7aSWojciech Drewek 	TCA_FLOWER_KEY_ENC_OPTS_GTP,	/* Nested
587e3acda7aSWojciech Drewek 					 * TCA_FLOWER_KEY_ENC_OPT_GTP_
588e3acda7aSWojciech Drewek 					 * attributes
589e3acda7aSWojciech Drewek 					 */
5900a6e7778SPieter Jansen van Vuuren 	__TCA_FLOWER_KEY_ENC_OPTS_MAX,
5910a6e7778SPieter Jansen van Vuuren };
5920a6e7778SPieter Jansen van Vuuren 
5930a6e7778SPieter Jansen van Vuuren #define TCA_FLOWER_KEY_ENC_OPTS_MAX (__TCA_FLOWER_KEY_ENC_OPTS_MAX - 1)
5940a6e7778SPieter Jansen van Vuuren 
5950a6e7778SPieter Jansen van Vuuren enum {
5960a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPT_GENEVE_UNSPEC,
5970a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPT_GENEVE_CLASS,            /* u16 */
5980a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPT_GENEVE_TYPE,             /* u8 */
5990a6e7778SPieter Jansen van Vuuren 	TCA_FLOWER_KEY_ENC_OPT_GENEVE_DATA,             /* 4 to 128 bytes */
6000a6e7778SPieter Jansen van Vuuren 
6010a6e7778SPieter Jansen van Vuuren 	__TCA_FLOWER_KEY_ENC_OPT_GENEVE_MAX,
6020a6e7778SPieter Jansen van Vuuren };
6030a6e7778SPieter Jansen van Vuuren 
6040a6e7778SPieter Jansen van Vuuren #define TCA_FLOWER_KEY_ENC_OPT_GENEVE_MAX \
6050a6e7778SPieter Jansen van Vuuren 		(__TCA_FLOWER_KEY_ENC_OPT_GENEVE_MAX - 1)
6060a6e7778SPieter Jansen van Vuuren 
6070a6e7778SPieter Jansen van Vuuren enum {
608d8f9dfaeSXin Long 	TCA_FLOWER_KEY_ENC_OPT_VXLAN_UNSPEC,
609d8f9dfaeSXin Long 	TCA_FLOWER_KEY_ENC_OPT_VXLAN_GBP,		/* u32 */
610d8f9dfaeSXin Long 	__TCA_FLOWER_KEY_ENC_OPT_VXLAN_MAX,
611d8f9dfaeSXin Long };
612d8f9dfaeSXin Long 
613d8f9dfaeSXin Long #define TCA_FLOWER_KEY_ENC_OPT_VXLAN_MAX \
614d8f9dfaeSXin Long 		(__TCA_FLOWER_KEY_ENC_OPT_VXLAN_MAX - 1)
615d8f9dfaeSXin Long 
616d8f9dfaeSXin Long enum {
61779b1011cSXin Long 	TCA_FLOWER_KEY_ENC_OPT_ERSPAN_UNSPEC,
61879b1011cSXin Long 	TCA_FLOWER_KEY_ENC_OPT_ERSPAN_VER,              /* u8 */
61979b1011cSXin Long 	TCA_FLOWER_KEY_ENC_OPT_ERSPAN_INDEX,            /* be32 */
62079b1011cSXin Long 	TCA_FLOWER_KEY_ENC_OPT_ERSPAN_DIR,              /* u8 */
62179b1011cSXin Long 	TCA_FLOWER_KEY_ENC_OPT_ERSPAN_HWID,             /* u8 */
62279b1011cSXin Long 	__TCA_FLOWER_KEY_ENC_OPT_ERSPAN_MAX,
62379b1011cSXin Long };
62479b1011cSXin Long 
62579b1011cSXin Long #define TCA_FLOWER_KEY_ENC_OPT_ERSPAN_MAX \
62679b1011cSXin Long 		(__TCA_FLOWER_KEY_ENC_OPT_ERSPAN_MAX - 1)
62779b1011cSXin Long 
62879b1011cSXin Long enum {
629e3acda7aSWojciech Drewek 	TCA_FLOWER_KEY_ENC_OPT_GTP_UNSPEC,
630e3acda7aSWojciech Drewek 	TCA_FLOWER_KEY_ENC_OPT_GTP_PDU_TYPE,		/* u8 */
631e3acda7aSWojciech Drewek 	TCA_FLOWER_KEY_ENC_OPT_GTP_QFI,			/* u8 */
632e3acda7aSWojciech Drewek 
633e3acda7aSWojciech Drewek 	__TCA_FLOWER_KEY_ENC_OPT_GTP_MAX,
634e3acda7aSWojciech Drewek };
635e3acda7aSWojciech Drewek 
636e3acda7aSWojciech Drewek #define TCA_FLOWER_KEY_ENC_OPT_GTP_MAX \
637e3acda7aSWojciech Drewek 		(__TCA_FLOWER_KEY_ENC_OPT_GTP_MAX - 1)
638e3acda7aSWojciech Drewek 
639e3acda7aSWojciech Drewek enum {
64061aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPTS_UNSPEC,
64161aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPTS_LSE,
64261aec25aSGuillaume Nault 	__TCA_FLOWER_KEY_MPLS_OPTS_MAX,
64361aec25aSGuillaume Nault };
64461aec25aSGuillaume Nault 
64561aec25aSGuillaume Nault #define TCA_FLOWER_KEY_MPLS_OPTS_MAX (__TCA_FLOWER_KEY_MPLS_OPTS_MAX - 1)
64661aec25aSGuillaume Nault 
64761aec25aSGuillaume Nault enum {
64861aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPT_LSE_UNSPEC,
64961aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPT_LSE_DEPTH,
65061aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPT_LSE_TTL,
65161aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPT_LSE_BOS,
65261aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPT_LSE_TC,
65361aec25aSGuillaume Nault 	TCA_FLOWER_KEY_MPLS_OPT_LSE_LABEL,
65461aec25aSGuillaume Nault 	__TCA_FLOWER_KEY_MPLS_OPT_LSE_MAX,
65561aec25aSGuillaume Nault };
65661aec25aSGuillaume Nault 
65761aec25aSGuillaume Nault #define TCA_FLOWER_KEY_MPLS_OPT_LSE_MAX \
65861aec25aSGuillaume Nault 		(__TCA_FLOWER_KEY_MPLS_OPT_LSE_MAX - 1)
65961aec25aSGuillaume Nault 
66061aec25aSGuillaume Nault enum {
661faa3ffceSOr Gerlitz 	TCA_FLOWER_KEY_FLAGS_IS_FRAGMENT = (1 << 0),
662459d153dSPieter Jansen van Vuuren 	TCA_FLOWER_KEY_FLAGS_FRAG_IS_FIRST = (1 << 1),
663faa3ffceSOr Gerlitz };
664faa3ffceSOr Gerlitz 
6657cfffd5fSZahari Doychev enum {
6667cfffd5fSZahari Doychev 	TCA_FLOWER_KEY_CFM_OPT_UNSPEC,
6677cfffd5fSZahari Doychev 	TCA_FLOWER_KEY_CFM_MD_LEVEL,
6687cfffd5fSZahari Doychev 	TCA_FLOWER_KEY_CFM_OPCODE,
6694d50e500SEric Dumazet 	__TCA_FLOWER_KEY_CFM_OPT_MAX,
6707cfffd5fSZahari Doychev };
6717cfffd5fSZahari Doychev 
6724d50e500SEric Dumazet #define TCA_FLOWER_KEY_CFM_OPT_MAX (__TCA_FLOWER_KEY_CFM_OPT_MAX - 1)
6734d50e500SEric Dumazet 
6745c72299fSAmritha Nambiar #define TCA_FLOWER_MASK_FLAGS_RANGE	(1 << 0) /* Range-based match */
6755c72299fSAmritha Nambiar 
676bf3994d2SJiri Pirko /* Match-all classifier */
677bf3994d2SJiri Pirko 
678f88c19aaSCong Wang struct tc_matchall_pcnt {
679f88c19aaSCong Wang 	__u64 rhit;
680f88c19aaSCong Wang };
681f88c19aaSCong Wang 
682bf3994d2SJiri Pirko enum {
683bf3994d2SJiri Pirko 	TCA_MATCHALL_UNSPEC,
684bf3994d2SJiri Pirko 	TCA_MATCHALL_CLASSID,
685bf3994d2SJiri Pirko 	TCA_MATCHALL_ACT,
686b87f7936SYotam Gigi 	TCA_MATCHALL_FLAGS,
687f88c19aaSCong Wang 	TCA_MATCHALL_PCNT,
688f88c19aaSCong Wang 	TCA_MATCHALL_PAD,
689bf3994d2SJiri Pirko 	__TCA_MATCHALL_MAX,
690bf3994d2SJiri Pirko };
691bf3994d2SJiri Pirko 
692bf3994d2SJiri Pirko #define TCA_MATCHALL_MAX (__TCA_MATCHALL_MAX - 1)
693bf3994d2SJiri Pirko 
694607ca46eSDavid Howells /* Extended Matches */
695607ca46eSDavid Howells 
696607ca46eSDavid Howells struct tcf_ematch_tree_hdr {
697607ca46eSDavid Howells 	__u16		nmatches;
698607ca46eSDavid Howells 	__u16		progid;
699607ca46eSDavid Howells };
700607ca46eSDavid Howells 
701607ca46eSDavid Howells enum {
702607ca46eSDavid Howells 	TCA_EMATCH_TREE_UNSPEC,
703607ca46eSDavid Howells 	TCA_EMATCH_TREE_HDR,
704607ca46eSDavid Howells 	TCA_EMATCH_TREE_LIST,
705607ca46eSDavid Howells 	__TCA_EMATCH_TREE_MAX
706607ca46eSDavid Howells };
707607ca46eSDavid Howells #define TCA_EMATCH_TREE_MAX (__TCA_EMATCH_TREE_MAX - 1)
708607ca46eSDavid Howells 
709607ca46eSDavid Howells struct tcf_ematch_hdr {
710607ca46eSDavid Howells 	__u16		matchid;
711607ca46eSDavid Howells 	__u16		kind;
712607ca46eSDavid Howells 	__u16		flags;
713607ca46eSDavid Howells 	__u16		pad; /* currently unused */
714607ca46eSDavid Howells };
715607ca46eSDavid Howells 
716607ca46eSDavid Howells /*  0                   1
717607ca46eSDavid Howells  *  0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5
718607ca46eSDavid Howells  * +-----------------------+-+-+---+
719607ca46eSDavid Howells  * |         Unused        |S|I| R |
720607ca46eSDavid Howells  * +-----------------------+-+-+---+
721607ca46eSDavid Howells  *
722607ca46eSDavid Howells  * R(2) ::= relation to next ematch
723607ca46eSDavid Howells  *          where: 0 0 END (last ematch)
724607ca46eSDavid Howells  *                 0 1 AND
725607ca46eSDavid Howells  *                 1 0 OR
726607ca46eSDavid Howells  *                 1 1 Unused (invalid)
727607ca46eSDavid Howells  * I(1) ::= invert result
728607ca46eSDavid Howells  * S(1) ::= simple payload
729607ca46eSDavid Howells  */
730607ca46eSDavid Howells #define TCF_EM_REL_END	0
731607ca46eSDavid Howells #define TCF_EM_REL_AND	(1<<0)
732607ca46eSDavid Howells #define TCF_EM_REL_OR	(1<<1)
733607ca46eSDavid Howells #define TCF_EM_INVERT	(1<<2)
734607ca46eSDavid Howells #define TCF_EM_SIMPLE	(1<<3)
735607ca46eSDavid Howells 
736607ca46eSDavid Howells #define TCF_EM_REL_MASK	3
737607ca46eSDavid Howells #define TCF_EM_REL_VALID(v) (((v) & TCF_EM_REL_MASK) != TCF_EM_REL_MASK)
738607ca46eSDavid Howells 
739607ca46eSDavid Howells enum {
740607ca46eSDavid Howells 	TCF_LAYER_LINK,
741607ca46eSDavid Howells 	TCF_LAYER_NETWORK,
742607ca46eSDavid Howells 	TCF_LAYER_TRANSPORT,
743607ca46eSDavid Howells 	__TCF_LAYER_MAX
744607ca46eSDavid Howells };
745607ca46eSDavid Howells #define TCF_LAYER_MAX (__TCF_LAYER_MAX - 1)
746607ca46eSDavid Howells 
747607ca46eSDavid Howells /* Ematch type assignments
748607ca46eSDavid Howells  *   1..32767		Reserved for ematches inside kernel tree
749607ca46eSDavid Howells  *   32768..65535	Free to use, not reliable
750607ca46eSDavid Howells  */
751607ca46eSDavid Howells #define	TCF_EM_CONTAINER	0
752607ca46eSDavid Howells #define	TCF_EM_CMP		1
753607ca46eSDavid Howells #define	TCF_EM_NBYTE		2
754607ca46eSDavid Howells #define	TCF_EM_U32		3
755607ca46eSDavid Howells #define	TCF_EM_META		4
756607ca46eSDavid Howells #define	TCF_EM_TEXT		5
757607ca46eSDavid Howells #define	TCF_EM_VLAN		6
758607ca46eSDavid Howells #define	TCF_EM_CANID		7
759607ca46eSDavid Howells #define	TCF_EM_IPSET		8
760ccc007e4SEyal Birger #define	TCF_EM_IPT		9
761ccc007e4SEyal Birger #define	TCF_EM_MAX		9
762607ca46eSDavid Howells 
763607ca46eSDavid Howells enum {
764607ca46eSDavid Howells 	TCF_EM_PROG_TC
765607ca46eSDavid Howells };
766607ca46eSDavid Howells 
767607ca46eSDavid Howells enum {
768607ca46eSDavid Howells 	TCF_EM_OPND_EQ,
769607ca46eSDavid Howells 	TCF_EM_OPND_GT,
770607ca46eSDavid Howells 	TCF_EM_OPND_LT
771607ca46eSDavid Howells };
772607ca46eSDavid Howells 
773607ca46eSDavid Howells #endif
774