xref: /OK3568_Linux_fs/kernel/drivers/net/ethernet/freescale/dpaa2/dpkg.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause) */
2*4882a593Smuzhiyun /* Copyright 2013-2015 Freescale Semiconductor Inc.
3*4882a593Smuzhiyun  */
4*4882a593Smuzhiyun #ifndef __FSL_DPKG_H_
5*4882a593Smuzhiyun #define __FSL_DPKG_H_
6*4882a593Smuzhiyun 
7*4882a593Smuzhiyun #include <linux/types.h>
8*4882a593Smuzhiyun 
9*4882a593Smuzhiyun /* Data Path Key Generator API
10*4882a593Smuzhiyun  * Contains initialization APIs and runtime APIs for the Key Generator
11*4882a593Smuzhiyun  */
12*4882a593Smuzhiyun 
13*4882a593Smuzhiyun /** Key Generator properties */
14*4882a593Smuzhiyun 
15*4882a593Smuzhiyun /**
16*4882a593Smuzhiyun  * Number of masks per key extraction
17*4882a593Smuzhiyun  */
18*4882a593Smuzhiyun #define DPKG_NUM_OF_MASKS		4
19*4882a593Smuzhiyun /**
20*4882a593Smuzhiyun  * Number of extractions per key profile
21*4882a593Smuzhiyun  */
22*4882a593Smuzhiyun #define DPKG_MAX_NUM_OF_EXTRACTS	10
23*4882a593Smuzhiyun 
24*4882a593Smuzhiyun /**
25*4882a593Smuzhiyun  * enum dpkg_extract_from_hdr_type - Selecting extraction by header types
26*4882a593Smuzhiyun  * @DPKG_FROM_HDR: Extract selected bytes from header, by offset
27*4882a593Smuzhiyun  * @DPKG_FROM_FIELD: Extract selected bytes from header, by offset from field
28*4882a593Smuzhiyun  * @DPKG_FULL_FIELD: Extract a full field
29*4882a593Smuzhiyun  */
30*4882a593Smuzhiyun enum dpkg_extract_from_hdr_type {
31*4882a593Smuzhiyun 	DPKG_FROM_HDR = 0,
32*4882a593Smuzhiyun 	DPKG_FROM_FIELD = 1,
33*4882a593Smuzhiyun 	DPKG_FULL_FIELD = 2
34*4882a593Smuzhiyun };
35*4882a593Smuzhiyun 
36*4882a593Smuzhiyun /**
37*4882a593Smuzhiyun  * enum dpkg_extract_type - Enumeration for selecting extraction type
38*4882a593Smuzhiyun  * @DPKG_EXTRACT_FROM_HDR: Extract from the header
39*4882a593Smuzhiyun  * @DPKG_EXTRACT_FROM_DATA: Extract from data not in specific header
40*4882a593Smuzhiyun  * @DPKG_EXTRACT_FROM_PARSE: Extract from parser-result;
41*4882a593Smuzhiyun  *	e.g. can be used to extract header existence;
42*4882a593Smuzhiyun  *	please refer to 'Parse Result definition' section in the parser BG
43*4882a593Smuzhiyun  */
44*4882a593Smuzhiyun enum dpkg_extract_type {
45*4882a593Smuzhiyun 	DPKG_EXTRACT_FROM_HDR = 0,
46*4882a593Smuzhiyun 	DPKG_EXTRACT_FROM_DATA = 1,
47*4882a593Smuzhiyun 	DPKG_EXTRACT_FROM_PARSE = 3
48*4882a593Smuzhiyun };
49*4882a593Smuzhiyun 
50*4882a593Smuzhiyun /**
51*4882a593Smuzhiyun  * struct dpkg_mask - A structure for defining a single extraction mask
52*4882a593Smuzhiyun  * @mask: Byte mask for the extracted content
53*4882a593Smuzhiyun  * @offset: Offset within the extracted content
54*4882a593Smuzhiyun  */
55*4882a593Smuzhiyun struct dpkg_mask {
56*4882a593Smuzhiyun 	u8 mask;
57*4882a593Smuzhiyun 	u8 offset;
58*4882a593Smuzhiyun };
59*4882a593Smuzhiyun 
60*4882a593Smuzhiyun /* Protocol fields */
61*4882a593Smuzhiyun 
62*4882a593Smuzhiyun /* Ethernet fields */
63*4882a593Smuzhiyun #define NH_FLD_ETH_DA				BIT(0)
64*4882a593Smuzhiyun #define NH_FLD_ETH_SA				BIT(1)
65*4882a593Smuzhiyun #define NH_FLD_ETH_LENGTH			BIT(2)
66*4882a593Smuzhiyun #define NH_FLD_ETH_TYPE				BIT(3)
67*4882a593Smuzhiyun #define NH_FLD_ETH_FINAL_CKSUM			BIT(4)
68*4882a593Smuzhiyun #define NH_FLD_ETH_PADDING			BIT(5)
69*4882a593Smuzhiyun #define NH_FLD_ETH_ALL_FIELDS			(BIT(6) - 1)
70*4882a593Smuzhiyun 
71*4882a593Smuzhiyun /* VLAN fields */
72*4882a593Smuzhiyun #define NH_FLD_VLAN_VPRI			BIT(0)
73*4882a593Smuzhiyun #define NH_FLD_VLAN_CFI				BIT(1)
74*4882a593Smuzhiyun #define NH_FLD_VLAN_VID				BIT(2)
75*4882a593Smuzhiyun #define NH_FLD_VLAN_LENGTH			BIT(3)
76*4882a593Smuzhiyun #define NH_FLD_VLAN_TYPE			BIT(4)
77*4882a593Smuzhiyun #define NH_FLD_VLAN_ALL_FIELDS			(BIT(5) - 1)
78*4882a593Smuzhiyun 
79*4882a593Smuzhiyun #define NH_FLD_VLAN_TCI				(NH_FLD_VLAN_VPRI | \
80*4882a593Smuzhiyun 						 NH_FLD_VLAN_CFI | \
81*4882a593Smuzhiyun 						 NH_FLD_VLAN_VID)
82*4882a593Smuzhiyun 
83*4882a593Smuzhiyun /* IP (generic) fields */
84*4882a593Smuzhiyun #define NH_FLD_IP_VER				BIT(0)
85*4882a593Smuzhiyun #define NH_FLD_IP_DSCP				BIT(2)
86*4882a593Smuzhiyun #define NH_FLD_IP_ECN				BIT(3)
87*4882a593Smuzhiyun #define NH_FLD_IP_PROTO				BIT(4)
88*4882a593Smuzhiyun #define NH_FLD_IP_SRC				BIT(5)
89*4882a593Smuzhiyun #define NH_FLD_IP_DST				BIT(6)
90*4882a593Smuzhiyun #define NH_FLD_IP_TOS_TC			BIT(7)
91*4882a593Smuzhiyun #define NH_FLD_IP_ID				BIT(8)
92*4882a593Smuzhiyun #define NH_FLD_IP_ALL_FIELDS			(BIT(9) - 1)
93*4882a593Smuzhiyun 
94*4882a593Smuzhiyun /* IPV4 fields */
95*4882a593Smuzhiyun #define NH_FLD_IPV4_VER				BIT(0)
96*4882a593Smuzhiyun #define NH_FLD_IPV4_HDR_LEN			BIT(1)
97*4882a593Smuzhiyun #define NH_FLD_IPV4_TOS				BIT(2)
98*4882a593Smuzhiyun #define NH_FLD_IPV4_TOTAL_LEN			BIT(3)
99*4882a593Smuzhiyun #define NH_FLD_IPV4_ID				BIT(4)
100*4882a593Smuzhiyun #define NH_FLD_IPV4_FLAG_D			BIT(5)
101*4882a593Smuzhiyun #define NH_FLD_IPV4_FLAG_M			BIT(6)
102*4882a593Smuzhiyun #define NH_FLD_IPV4_OFFSET			BIT(7)
103*4882a593Smuzhiyun #define NH_FLD_IPV4_TTL				BIT(8)
104*4882a593Smuzhiyun #define NH_FLD_IPV4_PROTO			BIT(9)
105*4882a593Smuzhiyun #define NH_FLD_IPV4_CKSUM			BIT(10)
106*4882a593Smuzhiyun #define NH_FLD_IPV4_SRC_IP			BIT(11)
107*4882a593Smuzhiyun #define NH_FLD_IPV4_DST_IP			BIT(12)
108*4882a593Smuzhiyun #define NH_FLD_IPV4_OPTS			BIT(13)
109*4882a593Smuzhiyun #define NH_FLD_IPV4_OPTS_COUNT			BIT(14)
110*4882a593Smuzhiyun #define NH_FLD_IPV4_ALL_FIELDS			(BIT(15) - 1)
111*4882a593Smuzhiyun 
112*4882a593Smuzhiyun /* IPV6 fields */
113*4882a593Smuzhiyun #define NH_FLD_IPV6_VER				BIT(0)
114*4882a593Smuzhiyun #define NH_FLD_IPV6_TC				BIT(1)
115*4882a593Smuzhiyun #define NH_FLD_IPV6_SRC_IP			BIT(2)
116*4882a593Smuzhiyun #define NH_FLD_IPV6_DST_IP			BIT(3)
117*4882a593Smuzhiyun #define NH_FLD_IPV6_NEXT_HDR			BIT(4)
118*4882a593Smuzhiyun #define NH_FLD_IPV6_FL				BIT(5)
119*4882a593Smuzhiyun #define NH_FLD_IPV6_HOP_LIMIT			BIT(6)
120*4882a593Smuzhiyun #define NH_FLD_IPV6_ID				BIT(7)
121*4882a593Smuzhiyun #define NH_FLD_IPV6_ALL_FIELDS			(BIT(8) - 1)
122*4882a593Smuzhiyun 
123*4882a593Smuzhiyun /* ICMP fields */
124*4882a593Smuzhiyun #define NH_FLD_ICMP_TYPE			BIT(0)
125*4882a593Smuzhiyun #define NH_FLD_ICMP_CODE			BIT(1)
126*4882a593Smuzhiyun #define NH_FLD_ICMP_CKSUM			BIT(2)
127*4882a593Smuzhiyun #define NH_FLD_ICMP_ID				BIT(3)
128*4882a593Smuzhiyun #define NH_FLD_ICMP_SQ_NUM			BIT(4)
129*4882a593Smuzhiyun #define NH_FLD_ICMP_ALL_FIELDS			(BIT(5) - 1)
130*4882a593Smuzhiyun 
131*4882a593Smuzhiyun /* IGMP fields */
132*4882a593Smuzhiyun #define NH_FLD_IGMP_VERSION			BIT(0)
133*4882a593Smuzhiyun #define NH_FLD_IGMP_TYPE			BIT(1)
134*4882a593Smuzhiyun #define NH_FLD_IGMP_CKSUM			BIT(2)
135*4882a593Smuzhiyun #define NH_FLD_IGMP_DATA			BIT(3)
136*4882a593Smuzhiyun #define NH_FLD_IGMP_ALL_FIELDS			(BIT(4) - 1)
137*4882a593Smuzhiyun 
138*4882a593Smuzhiyun /* TCP fields */
139*4882a593Smuzhiyun #define NH_FLD_TCP_PORT_SRC			BIT(0)
140*4882a593Smuzhiyun #define NH_FLD_TCP_PORT_DST			BIT(1)
141*4882a593Smuzhiyun #define NH_FLD_TCP_SEQ				BIT(2)
142*4882a593Smuzhiyun #define NH_FLD_TCP_ACK				BIT(3)
143*4882a593Smuzhiyun #define NH_FLD_TCP_OFFSET			BIT(4)
144*4882a593Smuzhiyun #define NH_FLD_TCP_FLAGS			BIT(5)
145*4882a593Smuzhiyun #define NH_FLD_TCP_WINDOW			BIT(6)
146*4882a593Smuzhiyun #define NH_FLD_TCP_CKSUM			BIT(7)
147*4882a593Smuzhiyun #define NH_FLD_TCP_URGPTR			BIT(8)
148*4882a593Smuzhiyun #define NH_FLD_TCP_OPTS				BIT(9)
149*4882a593Smuzhiyun #define NH_FLD_TCP_OPTS_COUNT			BIT(10)
150*4882a593Smuzhiyun #define NH_FLD_TCP_ALL_FIELDS			(BIT(11) - 1)
151*4882a593Smuzhiyun 
152*4882a593Smuzhiyun /* UDP fields */
153*4882a593Smuzhiyun #define NH_FLD_UDP_PORT_SRC			BIT(0)
154*4882a593Smuzhiyun #define NH_FLD_UDP_PORT_DST			BIT(1)
155*4882a593Smuzhiyun #define NH_FLD_UDP_LEN				BIT(2)
156*4882a593Smuzhiyun #define NH_FLD_UDP_CKSUM			BIT(3)
157*4882a593Smuzhiyun #define NH_FLD_UDP_ALL_FIELDS			(BIT(4) - 1)
158*4882a593Smuzhiyun 
159*4882a593Smuzhiyun /* UDP-lite fields */
160*4882a593Smuzhiyun #define NH_FLD_UDP_LITE_PORT_SRC		BIT(0)
161*4882a593Smuzhiyun #define NH_FLD_UDP_LITE_PORT_DST		BIT(1)
162*4882a593Smuzhiyun #define NH_FLD_UDP_LITE_ALL_FIELDS		(BIT(2) - 1)
163*4882a593Smuzhiyun 
164*4882a593Smuzhiyun /* UDP-encap-ESP fields */
165*4882a593Smuzhiyun #define NH_FLD_UDP_ENC_ESP_PORT_SRC		BIT(0)
166*4882a593Smuzhiyun #define NH_FLD_UDP_ENC_ESP_PORT_DST		BIT(1)
167*4882a593Smuzhiyun #define NH_FLD_UDP_ENC_ESP_LEN			BIT(2)
168*4882a593Smuzhiyun #define NH_FLD_UDP_ENC_ESP_CKSUM		BIT(3)
169*4882a593Smuzhiyun #define NH_FLD_UDP_ENC_ESP_SPI			BIT(4)
170*4882a593Smuzhiyun #define NH_FLD_UDP_ENC_ESP_SEQUENCE_NUM		BIT(5)
171*4882a593Smuzhiyun #define NH_FLD_UDP_ENC_ESP_ALL_FIELDS		(BIT(6) - 1)
172*4882a593Smuzhiyun 
173*4882a593Smuzhiyun /* SCTP fields */
174*4882a593Smuzhiyun #define NH_FLD_SCTP_PORT_SRC			BIT(0)
175*4882a593Smuzhiyun #define NH_FLD_SCTP_PORT_DST			BIT(1)
176*4882a593Smuzhiyun #define NH_FLD_SCTP_VER_TAG			BIT(2)
177*4882a593Smuzhiyun #define NH_FLD_SCTP_CKSUM			BIT(3)
178*4882a593Smuzhiyun #define NH_FLD_SCTP_ALL_FIELDS			(BIT(4) - 1)
179*4882a593Smuzhiyun 
180*4882a593Smuzhiyun /* DCCP fields */
181*4882a593Smuzhiyun #define NH_FLD_DCCP_PORT_SRC			BIT(0)
182*4882a593Smuzhiyun #define NH_FLD_DCCP_PORT_DST			BIT(1)
183*4882a593Smuzhiyun #define NH_FLD_DCCP_ALL_FIELDS			(BIT(2) - 1)
184*4882a593Smuzhiyun 
185*4882a593Smuzhiyun /* IPHC fields */
186*4882a593Smuzhiyun #define NH_FLD_IPHC_CID				BIT(0)
187*4882a593Smuzhiyun #define NH_FLD_IPHC_CID_TYPE			BIT(1)
188*4882a593Smuzhiyun #define NH_FLD_IPHC_HCINDEX			BIT(2)
189*4882a593Smuzhiyun #define NH_FLD_IPHC_GEN				BIT(3)
190*4882a593Smuzhiyun #define NH_FLD_IPHC_D_BIT			BIT(4)
191*4882a593Smuzhiyun #define NH_FLD_IPHC_ALL_FIELDS			(BIT(5) - 1)
192*4882a593Smuzhiyun 
193*4882a593Smuzhiyun /* SCTP fields */
194*4882a593Smuzhiyun #define NH_FLD_SCTP_CHUNK_DATA_TYPE		BIT(0)
195*4882a593Smuzhiyun #define NH_FLD_SCTP_CHUNK_DATA_FLAGS		BIT(1)
196*4882a593Smuzhiyun #define NH_FLD_SCTP_CHUNK_DATA_LENGTH		BIT(2)
197*4882a593Smuzhiyun #define NH_FLD_SCTP_CHUNK_DATA_TSN		BIT(3)
198*4882a593Smuzhiyun #define NH_FLD_SCTP_CHUNK_DATA_STREAM_ID	BIT(4)
199*4882a593Smuzhiyun #define NH_FLD_SCTP_CHUNK_DATA_STREAM_SQN	BIT(5)
200*4882a593Smuzhiyun #define NH_FLD_SCTP_CHUNK_DATA_PAYLOAD_PID	BIT(6)
201*4882a593Smuzhiyun #define NH_FLD_SCTP_CHUNK_DATA_UNORDERED	BIT(7)
202*4882a593Smuzhiyun #define NH_FLD_SCTP_CHUNK_DATA_BEGGINING	BIT(8)
203*4882a593Smuzhiyun #define NH_FLD_SCTP_CHUNK_DATA_END		BIT(9)
204*4882a593Smuzhiyun #define NH_FLD_SCTP_CHUNK_DATA_ALL_FIELDS	(BIT(10) - 1)
205*4882a593Smuzhiyun 
206*4882a593Smuzhiyun /* L2TPV2 fields */
207*4882a593Smuzhiyun #define NH_FLD_L2TPV2_TYPE_BIT			BIT(0)
208*4882a593Smuzhiyun #define NH_FLD_L2TPV2_LENGTH_BIT		BIT(1)
209*4882a593Smuzhiyun #define NH_FLD_L2TPV2_SEQUENCE_BIT		BIT(2)
210*4882a593Smuzhiyun #define NH_FLD_L2TPV2_OFFSET_BIT		BIT(3)
211*4882a593Smuzhiyun #define NH_FLD_L2TPV2_PRIORITY_BIT		BIT(4)
212*4882a593Smuzhiyun #define NH_FLD_L2TPV2_VERSION			BIT(5)
213*4882a593Smuzhiyun #define NH_FLD_L2TPV2_LEN			BIT(6)
214*4882a593Smuzhiyun #define NH_FLD_L2TPV2_TUNNEL_ID			BIT(7)
215*4882a593Smuzhiyun #define NH_FLD_L2TPV2_SESSION_ID		BIT(8)
216*4882a593Smuzhiyun #define NH_FLD_L2TPV2_NS			BIT(9)
217*4882a593Smuzhiyun #define NH_FLD_L2TPV2_NR			BIT(10)
218*4882a593Smuzhiyun #define NH_FLD_L2TPV2_OFFSET_SIZE		BIT(11)
219*4882a593Smuzhiyun #define NH_FLD_L2TPV2_FIRST_BYTE		BIT(12)
220*4882a593Smuzhiyun #define NH_FLD_L2TPV2_ALL_FIELDS		(BIT(13) - 1)
221*4882a593Smuzhiyun 
222*4882a593Smuzhiyun /* L2TPV3 fields */
223*4882a593Smuzhiyun #define NH_FLD_L2TPV3_CTRL_TYPE_BIT		BIT(0)
224*4882a593Smuzhiyun #define NH_FLD_L2TPV3_CTRL_LENGTH_BIT		BIT(1)
225*4882a593Smuzhiyun #define NH_FLD_L2TPV3_CTRL_SEQUENCE_BIT		BIT(2)
226*4882a593Smuzhiyun #define NH_FLD_L2TPV3_CTRL_VERSION		BIT(3)
227*4882a593Smuzhiyun #define NH_FLD_L2TPV3_CTRL_LENGTH		BIT(4)
228*4882a593Smuzhiyun #define NH_FLD_L2TPV3_CTRL_CONTROL		BIT(5)
229*4882a593Smuzhiyun #define NH_FLD_L2TPV3_CTRL_SENT			BIT(6)
230*4882a593Smuzhiyun #define NH_FLD_L2TPV3_CTRL_RECV			BIT(7)
231*4882a593Smuzhiyun #define NH_FLD_L2TPV3_CTRL_FIRST_BYTE		BIT(8)
232*4882a593Smuzhiyun #define NH_FLD_L2TPV3_CTRL_ALL_FIELDS		(BIT(9) - 1)
233*4882a593Smuzhiyun 
234*4882a593Smuzhiyun #define NH_FLD_L2TPV3_SESS_TYPE_BIT		BIT(0)
235*4882a593Smuzhiyun #define NH_FLD_L2TPV3_SESS_VERSION		BIT(1)
236*4882a593Smuzhiyun #define NH_FLD_L2TPV3_SESS_ID			BIT(2)
237*4882a593Smuzhiyun #define NH_FLD_L2TPV3_SESS_COOKIE		BIT(3)
238*4882a593Smuzhiyun #define NH_FLD_L2TPV3_SESS_ALL_FIELDS		(BIT(4) - 1)
239*4882a593Smuzhiyun 
240*4882a593Smuzhiyun /* PPP fields */
241*4882a593Smuzhiyun #define NH_FLD_PPP_PID				BIT(0)
242*4882a593Smuzhiyun #define NH_FLD_PPP_COMPRESSED			BIT(1)
243*4882a593Smuzhiyun #define NH_FLD_PPP_ALL_FIELDS			(BIT(2) - 1)
244*4882a593Smuzhiyun 
245*4882a593Smuzhiyun /* PPPoE fields */
246*4882a593Smuzhiyun #define NH_FLD_PPPOE_VER			BIT(0)
247*4882a593Smuzhiyun #define NH_FLD_PPPOE_TYPE			BIT(1)
248*4882a593Smuzhiyun #define NH_FLD_PPPOE_CODE			BIT(2)
249*4882a593Smuzhiyun #define NH_FLD_PPPOE_SID			BIT(3)
250*4882a593Smuzhiyun #define NH_FLD_PPPOE_LEN			BIT(4)
251*4882a593Smuzhiyun #define NH_FLD_PPPOE_SESSION			BIT(5)
252*4882a593Smuzhiyun #define NH_FLD_PPPOE_PID			BIT(6)
253*4882a593Smuzhiyun #define NH_FLD_PPPOE_ALL_FIELDS			(BIT(7) - 1)
254*4882a593Smuzhiyun 
255*4882a593Smuzhiyun /* PPP-Mux fields */
256*4882a593Smuzhiyun #define NH_FLD_PPPMUX_PID			BIT(0)
257*4882a593Smuzhiyun #define NH_FLD_PPPMUX_CKSUM			BIT(1)
258*4882a593Smuzhiyun #define NH_FLD_PPPMUX_COMPRESSED		BIT(2)
259*4882a593Smuzhiyun #define NH_FLD_PPPMUX_ALL_FIELDS		(BIT(3) - 1)
260*4882a593Smuzhiyun 
261*4882a593Smuzhiyun /* PPP-Mux sub-frame fields */
262*4882a593Smuzhiyun #define NH_FLD_PPPMUX_SUBFRM_PFF		BIT(0)
263*4882a593Smuzhiyun #define NH_FLD_PPPMUX_SUBFRM_LXT		BIT(1)
264*4882a593Smuzhiyun #define NH_FLD_PPPMUX_SUBFRM_LEN		BIT(2)
265*4882a593Smuzhiyun #define NH_FLD_PPPMUX_SUBFRM_PID		BIT(3)
266*4882a593Smuzhiyun #define NH_FLD_PPPMUX_SUBFRM_USE_PID		BIT(4)
267*4882a593Smuzhiyun #define NH_FLD_PPPMUX_SUBFRM_ALL_FIELDS		(BIT(5) - 1)
268*4882a593Smuzhiyun 
269*4882a593Smuzhiyun /* LLC fields */
270*4882a593Smuzhiyun #define NH_FLD_LLC_DSAP				BIT(0)
271*4882a593Smuzhiyun #define NH_FLD_LLC_SSAP				BIT(1)
272*4882a593Smuzhiyun #define NH_FLD_LLC_CTRL				BIT(2)
273*4882a593Smuzhiyun #define NH_FLD_LLC_ALL_FIELDS			(BIT(3) - 1)
274*4882a593Smuzhiyun 
275*4882a593Smuzhiyun /* NLPID fields */
276*4882a593Smuzhiyun #define NH_FLD_NLPID_NLPID			BIT(0)
277*4882a593Smuzhiyun #define NH_FLD_NLPID_ALL_FIELDS			(BIT(1) - 1)
278*4882a593Smuzhiyun 
279*4882a593Smuzhiyun /* SNAP fields */
280*4882a593Smuzhiyun #define NH_FLD_SNAP_OUI				BIT(0)
281*4882a593Smuzhiyun #define NH_FLD_SNAP_PID				BIT(1)
282*4882a593Smuzhiyun #define NH_FLD_SNAP_ALL_FIELDS			(BIT(2) - 1)
283*4882a593Smuzhiyun 
284*4882a593Smuzhiyun /* LLC SNAP fields */
285*4882a593Smuzhiyun #define NH_FLD_LLC_SNAP_TYPE			BIT(0)
286*4882a593Smuzhiyun #define NH_FLD_LLC_SNAP_ALL_FIELDS		(BIT(1) - 1)
287*4882a593Smuzhiyun 
288*4882a593Smuzhiyun /* ARP fields */
289*4882a593Smuzhiyun #define NH_FLD_ARP_HTYPE			BIT(0)
290*4882a593Smuzhiyun #define NH_FLD_ARP_PTYPE			BIT(1)
291*4882a593Smuzhiyun #define NH_FLD_ARP_HLEN				BIT(2)
292*4882a593Smuzhiyun #define NH_FLD_ARP_PLEN				BIT(3)
293*4882a593Smuzhiyun #define NH_FLD_ARP_OPER				BIT(4)
294*4882a593Smuzhiyun #define NH_FLD_ARP_SHA				BIT(5)
295*4882a593Smuzhiyun #define NH_FLD_ARP_SPA				BIT(6)
296*4882a593Smuzhiyun #define NH_FLD_ARP_THA				BIT(7)
297*4882a593Smuzhiyun #define NH_FLD_ARP_TPA				BIT(8)
298*4882a593Smuzhiyun #define NH_FLD_ARP_ALL_FIELDS			(BIT(9) - 1)
299*4882a593Smuzhiyun 
300*4882a593Smuzhiyun /* RFC2684 fields */
301*4882a593Smuzhiyun #define NH_FLD_RFC2684_LLC			BIT(0)
302*4882a593Smuzhiyun #define NH_FLD_RFC2684_NLPID			BIT(1)
303*4882a593Smuzhiyun #define NH_FLD_RFC2684_OUI			BIT(2)
304*4882a593Smuzhiyun #define NH_FLD_RFC2684_PID			BIT(3)
305*4882a593Smuzhiyun #define NH_FLD_RFC2684_VPN_OUI			BIT(4)
306*4882a593Smuzhiyun #define NH_FLD_RFC2684_VPN_IDX			BIT(5)
307*4882a593Smuzhiyun #define NH_FLD_RFC2684_ALL_FIELDS		(BIT(6) - 1)
308*4882a593Smuzhiyun 
309*4882a593Smuzhiyun /* User defined fields */
310*4882a593Smuzhiyun #define NH_FLD_USER_DEFINED_SRCPORT		BIT(0)
311*4882a593Smuzhiyun #define NH_FLD_USER_DEFINED_PCDID		BIT(1)
312*4882a593Smuzhiyun #define NH_FLD_USER_DEFINED_ALL_FIELDS		(BIT(2) - 1)
313*4882a593Smuzhiyun 
314*4882a593Smuzhiyun /* Payload fields */
315*4882a593Smuzhiyun #define NH_FLD_PAYLOAD_BUFFER			BIT(0)
316*4882a593Smuzhiyun #define NH_FLD_PAYLOAD_SIZE			BIT(1)
317*4882a593Smuzhiyun #define NH_FLD_MAX_FRM_SIZE			BIT(2)
318*4882a593Smuzhiyun #define NH_FLD_MIN_FRM_SIZE			BIT(3)
319*4882a593Smuzhiyun #define NH_FLD_PAYLOAD_TYPE			BIT(4)
320*4882a593Smuzhiyun #define NH_FLD_FRAME_SIZE			BIT(5)
321*4882a593Smuzhiyun #define NH_FLD_PAYLOAD_ALL_FIELDS		(BIT(6) - 1)
322*4882a593Smuzhiyun 
323*4882a593Smuzhiyun /* GRE fields */
324*4882a593Smuzhiyun #define NH_FLD_GRE_TYPE				BIT(0)
325*4882a593Smuzhiyun #define NH_FLD_GRE_ALL_FIELDS			(BIT(1) - 1)
326*4882a593Smuzhiyun 
327*4882a593Smuzhiyun /* MINENCAP fields */
328*4882a593Smuzhiyun #define NH_FLD_MINENCAP_SRC_IP			BIT(0)
329*4882a593Smuzhiyun #define NH_FLD_MINENCAP_DST_IP			BIT(1)
330*4882a593Smuzhiyun #define NH_FLD_MINENCAP_TYPE			BIT(2)
331*4882a593Smuzhiyun #define NH_FLD_MINENCAP_ALL_FIELDS		(BIT(3) - 1)
332*4882a593Smuzhiyun 
333*4882a593Smuzhiyun /* IPSEC AH fields */
334*4882a593Smuzhiyun #define NH_FLD_IPSEC_AH_SPI			BIT(0)
335*4882a593Smuzhiyun #define NH_FLD_IPSEC_AH_NH			BIT(1)
336*4882a593Smuzhiyun #define NH_FLD_IPSEC_AH_ALL_FIELDS		(BIT(2) - 1)
337*4882a593Smuzhiyun 
338*4882a593Smuzhiyun /* IPSEC ESP fields */
339*4882a593Smuzhiyun #define NH_FLD_IPSEC_ESP_SPI			BIT(0)
340*4882a593Smuzhiyun #define NH_FLD_IPSEC_ESP_SEQUENCE_NUM		BIT(1)
341*4882a593Smuzhiyun #define NH_FLD_IPSEC_ESP_ALL_FIELDS		(BIT(2) - 1)
342*4882a593Smuzhiyun 
343*4882a593Smuzhiyun /* MPLS fields */
344*4882a593Smuzhiyun #define NH_FLD_MPLS_LABEL_STACK			BIT(0)
345*4882a593Smuzhiyun #define NH_FLD_MPLS_LABEL_STACK_ALL_FIELDS	(BIT(1) - 1)
346*4882a593Smuzhiyun 
347*4882a593Smuzhiyun /* MACSEC fields */
348*4882a593Smuzhiyun #define NH_FLD_MACSEC_SECTAG			BIT(0)
349*4882a593Smuzhiyun #define NH_FLD_MACSEC_ALL_FIELDS		(BIT(1) - 1)
350*4882a593Smuzhiyun 
351*4882a593Smuzhiyun /* GTP fields */
352*4882a593Smuzhiyun #define NH_FLD_GTP_TEID				BIT(0)
353*4882a593Smuzhiyun 
354*4882a593Smuzhiyun /* Supported protocols */
355*4882a593Smuzhiyun enum net_prot {
356*4882a593Smuzhiyun 	NET_PROT_NONE = 0,
357*4882a593Smuzhiyun 	NET_PROT_PAYLOAD,
358*4882a593Smuzhiyun 	NET_PROT_ETH,
359*4882a593Smuzhiyun 	NET_PROT_VLAN,
360*4882a593Smuzhiyun 	NET_PROT_IPV4,
361*4882a593Smuzhiyun 	NET_PROT_IPV6,
362*4882a593Smuzhiyun 	NET_PROT_IP,
363*4882a593Smuzhiyun 	NET_PROT_TCP,
364*4882a593Smuzhiyun 	NET_PROT_UDP,
365*4882a593Smuzhiyun 	NET_PROT_UDP_LITE,
366*4882a593Smuzhiyun 	NET_PROT_IPHC,
367*4882a593Smuzhiyun 	NET_PROT_SCTP,
368*4882a593Smuzhiyun 	NET_PROT_SCTP_CHUNK_DATA,
369*4882a593Smuzhiyun 	NET_PROT_PPPOE,
370*4882a593Smuzhiyun 	NET_PROT_PPP,
371*4882a593Smuzhiyun 	NET_PROT_PPPMUX,
372*4882a593Smuzhiyun 	NET_PROT_PPPMUX_SUBFRM,
373*4882a593Smuzhiyun 	NET_PROT_L2TPV2,
374*4882a593Smuzhiyun 	NET_PROT_L2TPV3_CTRL,
375*4882a593Smuzhiyun 	NET_PROT_L2TPV3_SESS,
376*4882a593Smuzhiyun 	NET_PROT_LLC,
377*4882a593Smuzhiyun 	NET_PROT_LLC_SNAP,
378*4882a593Smuzhiyun 	NET_PROT_NLPID,
379*4882a593Smuzhiyun 	NET_PROT_SNAP,
380*4882a593Smuzhiyun 	NET_PROT_MPLS,
381*4882a593Smuzhiyun 	NET_PROT_IPSEC_AH,
382*4882a593Smuzhiyun 	NET_PROT_IPSEC_ESP,
383*4882a593Smuzhiyun 	NET_PROT_UDP_ENC_ESP, /* RFC 3948 */
384*4882a593Smuzhiyun 	NET_PROT_MACSEC,
385*4882a593Smuzhiyun 	NET_PROT_GRE,
386*4882a593Smuzhiyun 	NET_PROT_MINENCAP,
387*4882a593Smuzhiyun 	NET_PROT_DCCP,
388*4882a593Smuzhiyun 	NET_PROT_ICMP,
389*4882a593Smuzhiyun 	NET_PROT_IGMP,
390*4882a593Smuzhiyun 	NET_PROT_ARP,
391*4882a593Smuzhiyun 	NET_PROT_CAPWAP_DATA,
392*4882a593Smuzhiyun 	NET_PROT_CAPWAP_CTRL,
393*4882a593Smuzhiyun 	NET_PROT_RFC2684,
394*4882a593Smuzhiyun 	NET_PROT_ICMPV6,
395*4882a593Smuzhiyun 	NET_PROT_FCOE,
396*4882a593Smuzhiyun 	NET_PROT_FIP,
397*4882a593Smuzhiyun 	NET_PROT_ISCSI,
398*4882a593Smuzhiyun 	NET_PROT_GTP,
399*4882a593Smuzhiyun 	NET_PROT_USER_DEFINED_L2,
400*4882a593Smuzhiyun 	NET_PROT_USER_DEFINED_L3,
401*4882a593Smuzhiyun 	NET_PROT_USER_DEFINED_L4,
402*4882a593Smuzhiyun 	NET_PROT_USER_DEFINED_L5,
403*4882a593Smuzhiyun 	NET_PROT_USER_DEFINED_SHIM1,
404*4882a593Smuzhiyun 	NET_PROT_USER_DEFINED_SHIM2,
405*4882a593Smuzhiyun 
406*4882a593Smuzhiyun 	NET_PROT_DUMMY_LAST
407*4882a593Smuzhiyun };
408*4882a593Smuzhiyun 
409*4882a593Smuzhiyun /**
410*4882a593Smuzhiyun  * struct dpkg_extract - A structure for defining a single extraction
411*4882a593Smuzhiyun  * @type: Determines how the union below is interpreted:
412*4882a593Smuzhiyun  *	DPKG_EXTRACT_FROM_HDR: selects 'from_hdr';
413*4882a593Smuzhiyun  *	DPKG_EXTRACT_FROM_DATA: selects 'from_data';
414*4882a593Smuzhiyun  *	DPKG_EXTRACT_FROM_PARSE: selects 'from_parse'
415*4882a593Smuzhiyun  * @extract: Selects extraction method
416*4882a593Smuzhiyun  * @extract.from_hdr: Used when 'type = DPKG_EXTRACT_FROM_HDR'
417*4882a593Smuzhiyun  * @extract.from_data: Used when 'type = DPKG_EXTRACT_FROM_DATA'
418*4882a593Smuzhiyun  * @extract.from_parse:  Used when 'type = DPKG_EXTRACT_FROM_PARSE'
419*4882a593Smuzhiyun  * @extract.from_hdr.prot: Any of the supported headers
420*4882a593Smuzhiyun  * @extract.from_hdr.type: Defines the type of header extraction:
421*4882a593Smuzhiyun  *	DPKG_FROM_HDR: use size & offset below;
422*4882a593Smuzhiyun  *	DPKG_FROM_FIELD: use field, size and offset below;
423*4882a593Smuzhiyun  *	DPKG_FULL_FIELD: use field below
424*4882a593Smuzhiyun  * @extract.from_hdr.field: One of the supported fields (NH_FLD_)
425*4882a593Smuzhiyun  * @extract.from_hdr.size: Size in bytes
426*4882a593Smuzhiyun  * @extract.from_hdr.offset: Byte offset
427*4882a593Smuzhiyun  * @extract.from_hdr.hdr_index: Clear for cases not listed below;
428*4882a593Smuzhiyun  *	Used for protocols that may have more than a single
429*4882a593Smuzhiyun  *	header, 0 indicates an outer header;
430*4882a593Smuzhiyun  *	Supported protocols (possible values):
431*4882a593Smuzhiyun  *	NET_PROT_VLAN (0, HDR_INDEX_LAST);
432*4882a593Smuzhiyun  *	NET_PROT_MPLS (0, 1, HDR_INDEX_LAST);
433*4882a593Smuzhiyun  *	NET_PROT_IP(0, HDR_INDEX_LAST);
434*4882a593Smuzhiyun  *	NET_PROT_IPv4(0, HDR_INDEX_LAST);
435*4882a593Smuzhiyun  *	NET_PROT_IPv6(0, HDR_INDEX_LAST);
436*4882a593Smuzhiyun  * @extract.from_data.size: Size in bytes
437*4882a593Smuzhiyun  * @extract.from_data.offset: Byte offset
438*4882a593Smuzhiyun  * @extract.from_parse.size: Size in bytes
439*4882a593Smuzhiyun  * @extract.from_parse.offset: Byte offset
440*4882a593Smuzhiyun  * @num_of_byte_masks: Defines the number of valid entries in the array below;
441*4882a593Smuzhiyun  *		This is	also the number of bytes to be used as masks
442*4882a593Smuzhiyun  * @masks: Masks parameters
443*4882a593Smuzhiyun  */
444*4882a593Smuzhiyun struct dpkg_extract {
445*4882a593Smuzhiyun 	enum dpkg_extract_type type;
446*4882a593Smuzhiyun 	union {
447*4882a593Smuzhiyun 		struct {
448*4882a593Smuzhiyun 			enum net_prot			prot;
449*4882a593Smuzhiyun 			enum dpkg_extract_from_hdr_type type;
450*4882a593Smuzhiyun 			u32			field;
451*4882a593Smuzhiyun 			u8			size;
452*4882a593Smuzhiyun 			u8			offset;
453*4882a593Smuzhiyun 			u8			hdr_index;
454*4882a593Smuzhiyun 		} from_hdr;
455*4882a593Smuzhiyun 		struct {
456*4882a593Smuzhiyun 			u8 size;
457*4882a593Smuzhiyun 			u8 offset;
458*4882a593Smuzhiyun 		} from_data;
459*4882a593Smuzhiyun 		struct {
460*4882a593Smuzhiyun 			u8 size;
461*4882a593Smuzhiyun 			u8 offset;
462*4882a593Smuzhiyun 		} from_parse;
463*4882a593Smuzhiyun 	} extract;
464*4882a593Smuzhiyun 
465*4882a593Smuzhiyun 	u8		num_of_byte_masks;
466*4882a593Smuzhiyun 	struct dpkg_mask	masks[DPKG_NUM_OF_MASKS];
467*4882a593Smuzhiyun };
468*4882a593Smuzhiyun 
469*4882a593Smuzhiyun /**
470*4882a593Smuzhiyun  * struct dpkg_profile_cfg - A structure for defining a full Key Generation
471*4882a593Smuzhiyun  *				profile (rule)
472*4882a593Smuzhiyun  * @num_extracts: Defines the number of valid entries in the array below
473*4882a593Smuzhiyun  * @extracts: Array of required extractions
474*4882a593Smuzhiyun  */
475*4882a593Smuzhiyun struct dpkg_profile_cfg {
476*4882a593Smuzhiyun 	u8 num_extracts;
477*4882a593Smuzhiyun 	struct dpkg_extract extracts[DPKG_MAX_NUM_OF_EXTRACTS];
478*4882a593Smuzhiyun };
479*4882a593Smuzhiyun 
480*4882a593Smuzhiyun #endif /* __FSL_DPKG_H_ */
481