xref: /freebsd/sys/dev/ice/ice_ddp_common.h (revision c9539b89010900499a200cdd6c0265ea5d950875)
1 /* SPDX-License-Identifier: BSD-3-Clause */
2 /*  Copyright (c) 2022, Intel Corporation
3  *  All rights reserved.
4  *
5  *  Redistribution and use in source and binary forms, with or without
6  *  modification, are permitted provided that the following conditions are met:
7  *
8  *   1. Redistributions of source code must retain the above copyright notice,
9  *      this list of conditions and the following disclaimer.
10  *
11  *   2. Redistributions in binary form must reproduce the above copyright
12  *      notice, this list of conditions and the following disclaimer in the
13  *      documentation and/or other materials provided with the distribution.
14  *
15  *   3. Neither the name of the Intel Corporation nor the names of its
16  *      contributors may be used to endorse or promote products derived from
17  *      this software without specific prior written permission.
18  *
19  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20  *  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21  *  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22  *  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
23  *  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24  *  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25  *  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26  *  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27  *  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28  *  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29  *  POSSIBILITY OF SUCH DAMAGE.
30  */
31 /*$FreeBSD$*/
32 
33 #ifndef _ICE_DDP_H_
34 #define _ICE_DDP_H_
35 
36 #include "ice_osdep.h"
37 #include "ice_adminq_cmd.h"
38 #include "ice_controlq.h"
39 #include "ice_status.h"
40 #include "ice_flex_type.h"
41 #include "ice_protocol_type.h"
42 
43 /* Package minimal version supported */
44 #define ICE_PKG_SUPP_VER_MAJ	1
45 #define ICE_PKG_SUPP_VER_MNR	3
46 
47 /* Package format version */
48 #define ICE_PKG_FMT_VER_MAJ	1
49 #define ICE_PKG_FMT_VER_MNR	0
50 #define ICE_PKG_FMT_VER_UPD	0
51 #define ICE_PKG_FMT_VER_DFT	0
52 
53 #define ICE_PKG_CNT 4
54 
55 enum ice_ddp_state {
56 	/* Indicates that this call to ice_init_pkg
57 	 * successfully loaded the requested DDP package
58 	 */
59 	ICE_DDP_PKG_SUCCESS				= 0,
60 
61 	/* Generic error for already loaded errors, it is mapped later to
62 	 * the more specific one (one of the next 3)
63 	 */
64 	ICE_DDP_PKG_ALREADY_LOADED			= -1,
65 
66 	/* Indicates that a DDP package of the same version has already been
67 	 * loaded onto the device by a previous call or by another PF
68 	 */
69 	ICE_DDP_PKG_SAME_VERSION_ALREADY_LOADED		= -2,
70 
71 	/* The device has a DDP package that is not supported by the driver */
72 	ICE_DDP_PKG_ALREADY_LOADED_NOT_SUPPORTED	= -3,
73 
74 	/* The device has a compatible package
75 	 * (but different from the request) already loaded
76 	 */
77 	ICE_DDP_PKG_COMPATIBLE_ALREADY_LOADED		= -4,
78 
79 	/* The firmware loaded on the device is not compatible with
80 	 * the DDP package loaded
81 	 */
82 	ICE_DDP_PKG_FW_MISMATCH				= -5,
83 
84 	/* The DDP package file is invalid */
85 	ICE_DDP_PKG_INVALID_FILE			= -6,
86 
87 	/* The version of the DDP package provided is higher than
88 	 * the driver supports
89 	 */
90 	ICE_DDP_PKG_FILE_VERSION_TOO_HIGH		= -7,
91 
92 	/* The version of the DDP package provided is lower than the
93 	 * driver supports
94 	 */
95 	ICE_DDP_PKG_FILE_VERSION_TOO_LOW		= -8,
96 
97 	/* Missing security manifest in DDP pkg */
98 	ICE_DDP_PKG_NO_SEC_MANIFEST			= -9,
99 
100 	/* The RSA signature of the DDP package file provided is invalid */
101 	ICE_DDP_PKG_FILE_SIGNATURE_INVALID		= -10,
102 
103 	/* The DDP package file security revision is too low and not
104 	 * supported by firmware
105 	 */
106 	ICE_DDP_PKG_SECURE_VERSION_NBR_TOO_LOW		= -11,
107 
108 	/* Manifest hash mismatch */
109 	ICE_DDP_PKG_MANIFEST_INVALID			= -12,
110 
111 	/* Buffer hash mismatches manifest */
112 	ICE_DDP_PKG_BUFFER_INVALID			= -13,
113 
114 	/* Other errors */
115 	ICE_DDP_PKG_ERR					= -14,
116 };
117 
118 /* Package and segment headers and tables */
119 struct ice_pkg_hdr {
120 	struct ice_pkg_ver pkg_format_ver;
121 	__le32 seg_count;
122 	__le32 seg_offset[STRUCT_HACK_VAR_LEN];
123 };
124 
125 /* Package signing algorithm types */
126 #define SEGMENT_SIGN_TYPE_INVALID	0x00000000
127 #define SEGMENT_SIGN_TYPE_RSA2K		0x00000001
128 #define SEGMENT_SIGN_TYPE_RSA3K		0x00000002
129 #define SEGMENT_SIGN_TYPE_RSA3K_SBB	0x00000003 /* Secure Boot Block */
130 
131 /* generic segment */
132 struct ice_generic_seg_hdr {
133 #define	SEGMENT_TYPE_INVALID	0x00000000
134 #define SEGMENT_TYPE_METADATA	0x00000001
135 #define SEGMENT_TYPE_ICE_E810	0x00000010
136 #define SEGMENT_TYPE_SIGNING	0x00001001
137 #define SEGMENT_TYPE_ICE_RUN_TIME_CFG 0x00000020
138 	__le32 seg_type;
139 	struct ice_pkg_ver seg_format_ver;
140 	__le32 seg_size;
141 	char seg_id[ICE_PKG_NAME_SIZE];
142 };
143 
144 /* ice specific segment */
145 
146 union ice_device_id {
147 	struct {
148 		__le16 device_id;
149 		__le16 vendor_id;
150 	} dev_vend_id;
151 	__le32 id;
152 };
153 
154 struct ice_device_id_entry {
155 	union ice_device_id device;
156 	union ice_device_id sub_device;
157 };
158 
159 struct ice_seg {
160 	struct ice_generic_seg_hdr hdr;
161 	__le32 device_table_count;
162 	struct ice_device_id_entry device_table[STRUCT_HACK_VAR_LEN];
163 };
164 
165 struct ice_nvm_table {
166 	__le32 table_count;
167 	__le32 vers[STRUCT_HACK_VAR_LEN];
168 };
169 
170 struct ice_buf {
171 #define ICE_PKG_BUF_SIZE	4096
172 	u8 buf[ICE_PKG_BUF_SIZE];
173 };
174 
175 struct ice_buf_table {
176 	__le32 buf_count;
177 	struct ice_buf buf_array[STRUCT_HACK_VAR_LEN];
178 };
179 
180 struct ice_run_time_cfg_seg {
181 	struct ice_generic_seg_hdr hdr;
182 	u8 rsvd[8];
183 	struct ice_buf_table buf_table;
184 };
185 
186 /* global metadata specific segment */
187 struct ice_global_metadata_seg {
188 	struct ice_generic_seg_hdr hdr;
189 	struct ice_pkg_ver pkg_ver;
190 	__le32 rsvd;
191 	char pkg_name[ICE_PKG_NAME_SIZE];
192 };
193 
194 #define ICE_MIN_S_OFF		12
195 #define ICE_MAX_S_OFF		4095
196 #define ICE_MIN_S_SZ		1
197 #define ICE_MAX_S_SZ		4084
198 
199 struct ice_sign_seg {
200 	struct ice_generic_seg_hdr hdr;
201 	__le32 seg_id;
202 	__le32 sign_type;
203 	__le32 signed_seg_idx;
204 	__le32 signed_buf_start;
205 	__le32 signed_buf_count;
206 #define ICE_SIGN_SEG_RESERVED_COUNT	44
207 	u8 reserved[ICE_SIGN_SEG_RESERVED_COUNT];
208 	struct ice_buf_table buf_tbl;
209 };
210 
211 /* section information */
212 struct ice_section_entry {
213 	__le32 type;
214 	__le16 offset;
215 	__le16 size;
216 };
217 
218 #define ICE_MIN_S_COUNT		1
219 #define ICE_MAX_S_COUNT		511
220 #define ICE_MIN_S_DATA_END	12
221 #define ICE_MAX_S_DATA_END	4096
222 
223 #define ICE_METADATA_BUF	0x80000000
224 
225 struct ice_buf_hdr {
226 	__le16 section_count;
227 	__le16 data_end;
228 	struct ice_section_entry section_entry[STRUCT_HACK_VAR_LEN];
229 };
230 
231 #define ICE_MAX_ENTRIES_IN_BUF(hd_sz, ent_sz) ((ICE_PKG_BUF_SIZE - \
232 	ice_struct_size((struct ice_buf_hdr *)0, section_entry, 1) - (hd_sz)) /\
233 	(ent_sz))
234 
235 /* ice package section IDs */
236 #define ICE_SID_METADATA		1
237 #define ICE_SID_XLT0_SW			10
238 #define ICE_SID_XLT_KEY_BUILDER_SW	11
239 #define ICE_SID_XLT1_SW			12
240 #define ICE_SID_XLT2_SW			13
241 #define ICE_SID_PROFID_TCAM_SW		14
242 #define ICE_SID_PROFID_REDIR_SW		15
243 #define ICE_SID_FLD_VEC_SW		16
244 #define ICE_SID_CDID_KEY_BUILDER_SW	17
245 #define ICE_SID_CDID_REDIR_SW		18
246 
247 #define ICE_SID_XLT0_ACL		20
248 #define ICE_SID_XLT_KEY_BUILDER_ACL	21
249 #define ICE_SID_XLT1_ACL		22
250 #define ICE_SID_XLT2_ACL		23
251 #define ICE_SID_PROFID_TCAM_ACL		24
252 #define ICE_SID_PROFID_REDIR_ACL	25
253 #define ICE_SID_FLD_VEC_ACL		26
254 #define ICE_SID_CDID_KEY_BUILDER_ACL	27
255 #define ICE_SID_CDID_REDIR_ACL		28
256 
257 #define ICE_SID_XLT0_FD			30
258 #define ICE_SID_XLT_KEY_BUILDER_FD	31
259 #define ICE_SID_XLT1_FD			32
260 #define ICE_SID_XLT2_FD			33
261 #define ICE_SID_PROFID_TCAM_FD		34
262 #define ICE_SID_PROFID_REDIR_FD		35
263 #define ICE_SID_FLD_VEC_FD		36
264 #define ICE_SID_CDID_KEY_BUILDER_FD	37
265 #define ICE_SID_CDID_REDIR_FD		38
266 
267 #define ICE_SID_XLT0_RSS		40
268 #define ICE_SID_XLT_KEY_BUILDER_RSS	41
269 #define ICE_SID_XLT1_RSS		42
270 #define ICE_SID_XLT2_RSS		43
271 #define ICE_SID_PROFID_TCAM_RSS		44
272 #define ICE_SID_PROFID_REDIR_RSS	45
273 #define ICE_SID_FLD_VEC_RSS		46
274 #define ICE_SID_CDID_KEY_BUILDER_RSS	47
275 #define ICE_SID_CDID_REDIR_RSS		48
276 
277 #define ICE_SID_RXPARSER_CAM		50
278 #define ICE_SID_RXPARSER_NOMATCH_CAM	51
279 #define ICE_SID_RXPARSER_IMEM		52
280 #define ICE_SID_RXPARSER_XLT0_BUILDER	53
281 #define ICE_SID_RXPARSER_NODE_PTYPE	54
282 #define ICE_SID_RXPARSER_MARKER_PTYPE	55
283 #define ICE_SID_RXPARSER_BOOST_TCAM	56
284 #define ICE_SID_RXPARSER_PROTO_GRP	57
285 #define ICE_SID_RXPARSER_METADATA_INIT	58
286 #define ICE_SID_RXPARSER_XLT0		59
287 
288 #define ICE_SID_TXPARSER_CAM		60
289 #define ICE_SID_TXPARSER_NOMATCH_CAM	61
290 #define ICE_SID_TXPARSER_IMEM		62
291 #define ICE_SID_TXPARSER_XLT0_BUILDER	63
292 #define ICE_SID_TXPARSER_NODE_PTYPE	64
293 #define ICE_SID_TXPARSER_MARKER_PTYPE	65
294 #define ICE_SID_TXPARSER_BOOST_TCAM	66
295 #define ICE_SID_TXPARSER_PROTO_GRP	67
296 #define ICE_SID_TXPARSER_METADATA_INIT	68
297 #define ICE_SID_TXPARSER_XLT0		69
298 
299 #define ICE_SID_RXPARSER_INIT_REDIR	70
300 #define ICE_SID_TXPARSER_INIT_REDIR	71
301 #define ICE_SID_RXPARSER_MARKER_GRP	72
302 #define ICE_SID_TXPARSER_MARKER_GRP	73
303 #define ICE_SID_RXPARSER_LAST_PROTO	74
304 #define ICE_SID_TXPARSER_LAST_PROTO	75
305 #define ICE_SID_RXPARSER_PG_SPILL	76
306 #define ICE_SID_TXPARSER_PG_SPILL	77
307 #define ICE_SID_RXPARSER_NOMATCH_SPILL	78
308 #define ICE_SID_TXPARSER_NOMATCH_SPILL	79
309 
310 #define ICE_SID_XLT0_PE			80
311 #define ICE_SID_XLT_KEY_BUILDER_PE	81
312 #define ICE_SID_XLT1_PE			82
313 #define ICE_SID_XLT2_PE			83
314 #define ICE_SID_PROFID_TCAM_PE		84
315 #define ICE_SID_PROFID_REDIR_PE		85
316 #define ICE_SID_FLD_VEC_PE		86
317 #define ICE_SID_CDID_KEY_BUILDER_PE	87
318 #define ICE_SID_CDID_REDIR_PE		88
319 
320 #define ICE_SID_RXPARSER_FLAG_REDIR	97
321 
322 /* Label Metadata section IDs */
323 #define ICE_SID_LBL_FIRST		0x80000010
324 #define ICE_SID_LBL_RXPARSER_IMEM	0x80000010
325 #define ICE_SID_LBL_TXPARSER_IMEM	0x80000011
326 #define ICE_SID_LBL_RESERVED_12		0x80000012
327 #define ICE_SID_LBL_RESERVED_13		0x80000013
328 #define ICE_SID_LBL_RXPARSER_MARKER	0x80000014
329 #define ICE_SID_LBL_TXPARSER_MARKER	0x80000015
330 #define ICE_SID_LBL_PTYPE		0x80000016
331 #define ICE_SID_LBL_PROTOCOL_ID		0x80000017
332 #define ICE_SID_LBL_RXPARSER_TMEM	0x80000018
333 #define ICE_SID_LBL_TXPARSER_TMEM	0x80000019
334 #define ICE_SID_LBL_RXPARSER_PG		0x8000001A
335 #define ICE_SID_LBL_TXPARSER_PG		0x8000001B
336 #define ICE_SID_LBL_RXPARSER_M_TCAM	0x8000001C
337 #define ICE_SID_LBL_TXPARSER_M_TCAM	0x8000001D
338 #define ICE_SID_LBL_SW_PROFID_TCAM	0x8000001E
339 #define ICE_SID_LBL_ACL_PROFID_TCAM	0x8000001F
340 #define ICE_SID_LBL_PE_PROFID_TCAM	0x80000020
341 #define ICE_SID_LBL_RSS_PROFID_TCAM	0x80000021
342 #define ICE_SID_LBL_FD_PROFID_TCAM	0x80000022
343 #define ICE_SID_LBL_FLAG		0x80000023
344 #define ICE_SID_LBL_REG			0x80000024
345 #define ICE_SID_LBL_SW_PTG		0x80000025
346 #define ICE_SID_LBL_ACL_PTG		0x80000026
347 #define ICE_SID_LBL_PE_PTG		0x80000027
348 #define ICE_SID_LBL_RSS_PTG		0x80000028
349 #define ICE_SID_LBL_FD_PTG		0x80000029
350 #define ICE_SID_LBL_SW_VSIG		0x8000002A
351 #define ICE_SID_LBL_ACL_VSIG		0x8000002B
352 #define ICE_SID_LBL_PE_VSIG		0x8000002C
353 #define ICE_SID_LBL_RSS_VSIG		0x8000002D
354 #define ICE_SID_LBL_FD_VSIG		0x8000002E
355 #define ICE_SID_LBL_PTYPE_META		0x8000002F
356 #define ICE_SID_LBL_SW_PROFID		0x80000030
357 #define ICE_SID_LBL_ACL_PROFID		0x80000031
358 #define ICE_SID_LBL_PE_PROFID		0x80000032
359 #define ICE_SID_LBL_RSS_PROFID		0x80000033
360 #define ICE_SID_LBL_FD_PROFID		0x80000034
361 #define ICE_SID_LBL_RXPARSER_MARKER_GRP	0x80000035
362 #define ICE_SID_LBL_TXPARSER_MARKER_GRP	0x80000036
363 #define ICE_SID_LBL_RXPARSER_PROTO	0x80000037
364 #define ICE_SID_LBL_TXPARSER_PROTO	0x80000038
365 /* The following define MUST be updated to reflect the last label section ID */
366 #define ICE_SID_LBL_LAST		0x80000038
367 
368 /* Label ICE runtime configuration section IDs */
369 #define ICE_SID_TX_5_LAYER_TOPO		0x10
370 
371 enum ice_block {
372 	ICE_BLK_SW = 0,
373 	ICE_BLK_ACL,
374 	ICE_BLK_FD,
375 	ICE_BLK_RSS,
376 	ICE_BLK_PE,
377 	ICE_BLK_COUNT
378 };
379 
380 enum ice_sect {
381 	ICE_XLT0 = 0,
382 	ICE_XLT_KB,
383 	ICE_XLT1,
384 	ICE_XLT2,
385 	ICE_PROF_TCAM,
386 	ICE_PROF_REDIR,
387 	ICE_VEC_TBL,
388 	ICE_CDID_KB,
389 	ICE_CDID_REDIR,
390 	ICE_SECT_COUNT
391 };
392 
393 /* package buffer building */
394 
395 struct ice_buf_build {
396 	struct ice_buf buf;
397 	u16 reserved_section_table_entries;
398 };
399 
400 struct ice_pkg_enum {
401 	struct ice_buf_table *buf_table;
402 	u32 buf_idx;
403 
404 	u32 type;
405 	struct ice_buf_hdr *buf;
406 	u32 sect_idx;
407 	void *sect;
408 	u32 sect_type;
409 
410 	u32 entry_idx;
411 	void *(*handler)(u32 sect_type, void *section, u32 index, u32 *offset);
412 };
413 
414 struct ice_hw;
415 
416 enum ice_status
417 ice_acquire_change_lock(struct ice_hw *hw, enum ice_aq_res_access_type access);
418 void ice_release_change_lock(struct ice_hw *hw);
419 
420 struct ice_buf_build *ice_pkg_buf_alloc(struct ice_hw *hw);
421 void *
422 ice_pkg_buf_alloc_section(struct ice_buf_build *bld, u32 type, u16 size);
423 enum ice_status
424 ice_pkg_buf_reserve_section(struct ice_buf_build *bld, u16 count);
425 enum ice_status
426 ice_get_sw_fv_list(struct ice_hw *hw, struct ice_prot_lkup_ext *lkups,
427 		   ice_bitmap_t *bm, struct LIST_HEAD_TYPE *fv_list);
428 enum ice_status
429 ice_pkg_buf_unreserve_section(struct ice_buf_build *bld, u16 count);
430 u16 ice_pkg_buf_get_free_space(struct ice_buf_build *bld);
431 u16 ice_pkg_buf_get_active_sections(struct ice_buf_build *bld);
432 
433 enum ice_status
434 ice_update_pkg(struct ice_hw *hw, struct ice_buf *bufs, u32 count);
435 enum ice_status
436 ice_update_pkg_no_lock(struct ice_hw *hw, struct ice_buf *bufs, u32 count);
437 void ice_release_global_cfg_lock(struct ice_hw *hw);
438 struct ice_generic_seg_hdr *
439 ice_find_seg_in_pkg(struct ice_hw *hw, u32 seg_type,
440 		    struct ice_pkg_hdr *pkg_hdr);
441 enum ice_ddp_state
442 ice_verify_pkg(struct ice_pkg_hdr *pkg, u32 len);
443 enum ice_ddp_state
444 ice_get_pkg_info(struct ice_hw *hw);
445 void ice_init_pkg_hints(struct ice_hw *hw, struct ice_seg *ice_seg);
446 struct ice_buf_table *ice_find_buf_table(struct ice_seg *ice_seg);
447 enum ice_status
448 ice_acquire_global_cfg_lock(struct ice_hw *hw,
449 			    enum ice_aq_res_access_type access);
450 
451 struct ice_buf_table *ice_find_buf_table(struct ice_seg *ice_seg);
452 struct ice_buf_hdr *
453 ice_pkg_enum_buf(struct ice_seg *ice_seg, struct ice_pkg_enum *state);
454 bool
455 ice_pkg_advance_sect(struct ice_seg *ice_seg, struct ice_pkg_enum *state);
456 void *
457 ice_pkg_enum_entry(struct ice_seg *ice_seg, struct ice_pkg_enum *state,
458 		   u32 sect_type, u32 *offset,
459 		   void *(*handler)(u32 sect_type, void *section,
460 				    u32 index, u32 *offset));
461 void *
462 ice_pkg_enum_section(struct ice_seg *ice_seg, struct ice_pkg_enum *state,
463 		     u32 sect_type);
464 enum ice_ddp_state ice_init_pkg(struct ice_hw *hw, u8 *buff, u32 len);
465 enum ice_ddp_state
466 ice_copy_and_init_pkg(struct ice_hw *hw, const u8 *buf, u32 len);
467 bool ice_is_init_pkg_successful(enum ice_ddp_state state);
468 void ice_free_seg(struct ice_hw *hw);
469 
470 struct ice_buf_build *
471 ice_pkg_buf_alloc_single_section(struct ice_hw *hw, u32 type, u16 size,
472 				 void **section);
473 struct ice_buf *ice_pkg_buf(struct ice_buf_build *bld);
474 void ice_pkg_buf_free(struct ice_hw *hw, struct ice_buf_build *bld);
475 
476 enum ice_status ice_cfg_tx_topo(struct ice_hw *hw, u8 *buf, u32 len);
477 
478 #endif /* _ICE_DDP_H_ */
479