xref: /openbmc/linux/drivers/crypto/intel/qat/qat_common/icp_qat_uclo.h (revision c496daeb863093a046e0bb8db7265bf45d91775a)
1 /* SPDX-License-Identifier: (BSD-3-Clause OR GPL-2.0-only) */
2 /* Copyright(c) 2014 - 2020 Intel Corporation */
3 #ifndef __ICP_QAT_UCLO_H__
4 #define __ICP_QAT_UCLO_H__
5 
6 #define ICP_QAT_AC_895XCC_DEV_TYPE 0x00400000
7 #define ICP_QAT_AC_C62X_DEV_TYPE   0x01000000
8 #define ICP_QAT_AC_C3XXX_DEV_TYPE  0x02000000
9 #define ICP_QAT_AC_4XXX_A_DEV_TYPE 0x08000000
10 #define ICP_QAT_UCLO_MAX_AE       12
11 #define ICP_QAT_UCLO_MAX_CTX      8
12 #define ICP_QAT_UCLO_MAX_UIMAGE   (ICP_QAT_UCLO_MAX_AE * ICP_QAT_UCLO_MAX_CTX)
13 #define ICP_QAT_UCLO_MAX_USTORE   0x4000
14 #define ICP_QAT_UCLO_MAX_XFER_REG 128
15 #define ICP_QAT_UCLO_MAX_GPR_REG  128
16 #define ICP_QAT_UCLO_MAX_LMEM_REG 1024
17 #define ICP_QAT_UCLO_MAX_LMEM_REG_2X 1280
18 #define ICP_QAT_UCLO_AE_ALL_CTX   0xff
19 #define ICP_QAT_UOF_OBJID_LEN     8
20 #define ICP_QAT_UOF_FID 0xc6c2
21 #define ICP_QAT_UOF_MAJVER 0x4
22 #define ICP_QAT_UOF_MINVER 0x11
23 #define ICP_QAT_UOF_OBJS        "UOF_OBJS"
24 #define ICP_QAT_UOF_STRT        "UOF_STRT"
25 #define ICP_QAT_UOF_IMAG        "UOF_IMAG"
26 #define ICP_QAT_UOF_IMEM        "UOF_IMEM"
27 #define ICP_QAT_UOF_LOCAL_SCOPE     1
28 #define ICP_QAT_UOF_INIT_EXPR               0
29 #define ICP_QAT_UOF_INIT_REG                1
30 #define ICP_QAT_UOF_INIT_REG_CTX            2
31 #define ICP_QAT_UOF_INIT_EXPR_ENDIAN_SWAP   3
32 #define ICP_QAT_SUOF_OBJ_ID_LEN             8
33 #define ICP_QAT_SUOF_FID  0x53554f46
34 #define ICP_QAT_SUOF_MAJVER 0x0
35 #define ICP_QAT_SUOF_MINVER 0x1
36 #define ICP_QAT_SUOF_OBJ_NAME_LEN 128
37 #define ICP_QAT_MOF_OBJ_ID_LEN 8
38 #define ICP_QAT_MOF_OBJ_CHUNKID_LEN 8
39 #define ICP_QAT_MOF_FID 0x00666f6d
40 #define ICP_QAT_MOF_MAJVER 0x0
41 #define ICP_QAT_MOF_MINVER 0x1
42 #define ICP_QAT_MOF_SYM_OBJS "SYM_OBJS"
43 #define ICP_QAT_SUOF_OBJS "SUF_OBJS"
44 #define ICP_QAT_SUOF_IMAG "SUF_IMAG"
45 #define ICP_QAT_SIMG_AE_INIT_SEQ_LEN    (50 * sizeof(unsigned long long))
46 #define ICP_QAT_SIMG_AE_INSTS_LEN       (0x4000 * sizeof(unsigned long long))
47 
48 #define DSS_FWSK_MODULUS_LEN    384 /* RSA3K */
49 #define DSS_FWSK_EXPONENT_LEN   4
50 #define DSS_FWSK_PADDING_LEN    380
51 #define DSS_SIGNATURE_LEN       384 /* RSA3K */
52 
53 #define CSS_FWSK_MODULUS_LEN    256 /* RSA2K */
54 #define CSS_FWSK_EXPONENT_LEN   4
55 #define CSS_FWSK_PADDING_LEN    252
56 #define CSS_SIGNATURE_LEN       256 /* RSA2K */
57 
58 #define ICP_QAT_CSS_FWSK_MODULUS_LEN(handle)	((handle)->chip_info->css_3k ? \
59 						DSS_FWSK_MODULUS_LEN  : \
60 						CSS_FWSK_MODULUS_LEN)
61 
62 #define ICP_QAT_CSS_FWSK_EXPONENT_LEN(handle)	((handle)->chip_info->css_3k ? \
63 						DSS_FWSK_EXPONENT_LEN : \
64 						CSS_FWSK_EXPONENT_LEN)
65 
66 #define ICP_QAT_CSS_FWSK_PAD_LEN(handle)	((handle)->chip_info->css_3k ? \
67 						DSS_FWSK_PADDING_LEN : \
68 						CSS_FWSK_PADDING_LEN)
69 
70 #define ICP_QAT_CSS_FWSK_PUB_LEN(handle)	(ICP_QAT_CSS_FWSK_MODULUS_LEN(handle) + \
71 						ICP_QAT_CSS_FWSK_EXPONENT_LEN(handle) + \
72 						ICP_QAT_CSS_FWSK_PAD_LEN(handle))
73 
74 #define ICP_QAT_CSS_SIGNATURE_LEN(handle)	((handle)->chip_info->css_3k ? \
75 						DSS_SIGNATURE_LEN : \
76 						CSS_SIGNATURE_LEN)
77 
78 #define ICP_QAT_CSS_AE_IMG_LEN     (sizeof(struct icp_qat_simg_ae_mode) + \
79 				    ICP_QAT_SIMG_AE_INIT_SEQ_LEN +         \
80 				    ICP_QAT_SIMG_AE_INSTS_LEN)
81 #define ICP_QAT_CSS_AE_SIMG_LEN(handle) (sizeof(struct icp_qat_css_hdr) + \
82 					ICP_QAT_CSS_FWSK_PUB_LEN(handle) + \
83 					ICP_QAT_CSS_SIGNATURE_LEN(handle) + \
84 					ICP_QAT_CSS_AE_IMG_LEN)
85 #define ICP_QAT_AE_IMG_OFFSET(handle) (sizeof(struct icp_qat_css_hdr) + \
86 					ICP_QAT_CSS_FWSK_MODULUS_LEN(handle) + \
87 					ICP_QAT_CSS_FWSK_EXPONENT_LEN(handle) + \
88 					ICP_QAT_CSS_SIGNATURE_LEN(handle))
89 #define ICP_QAT_CSS_RSA4K_MAX_IMAGE_LEN    0x40000
90 #define ICP_QAT_CSS_RSA3K_MAX_IMAGE_LEN    0x30000
91 
92 #define ICP_QAT_CTX_MODE(ae_mode) ((ae_mode) & 0xf)
93 #define ICP_QAT_NN_MODE(ae_mode) (((ae_mode) >> 0x4) & 0xf)
94 #define ICP_QAT_SHARED_USTORE_MODE(ae_mode) (((ae_mode) >> 0xb) & 0x1)
95 #define RELOADABLE_CTX_SHARED_MODE(ae_mode) (((ae_mode) >> 0xc) & 0x1)
96 
97 #define ICP_QAT_LOC_MEM0_MODE(ae_mode) (((ae_mode) >> 0x8) & 0x1)
98 #define ICP_QAT_LOC_MEM1_MODE(ae_mode) (((ae_mode) >> 0x9) & 0x1)
99 #define ICP_QAT_LOC_MEM2_MODE(ae_mode) (((ae_mode) >> 0x6) & 0x1)
100 #define ICP_QAT_LOC_MEM3_MODE(ae_mode) (((ae_mode) >> 0x7) & 0x1)
101 #define ICP_QAT_LOC_TINDEX_MODE(ae_mode) (((ae_mode) >> 0xe) & 0x1)
102 
103 enum icp_qat_uof_mem_region {
104 	ICP_QAT_UOF_SRAM_REGION = 0x0,
105 	ICP_QAT_UOF_LMEM_REGION = 0x3,
106 	ICP_QAT_UOF_UMEM_REGION = 0x5
107 };
108 
109 enum icp_qat_uof_regtype {
110 	ICP_NO_DEST	= 0,
111 	ICP_GPA_REL	= 1,
112 	ICP_GPA_ABS	= 2,
113 	ICP_GPB_REL	= 3,
114 	ICP_GPB_ABS	= 4,
115 	ICP_SR_REL	= 5,
116 	ICP_SR_RD_REL	= 6,
117 	ICP_SR_WR_REL	= 7,
118 	ICP_SR_ABS	= 8,
119 	ICP_SR_RD_ABS	= 9,
120 	ICP_SR_WR_ABS	= 10,
121 	ICP_DR_REL	= 19,
122 	ICP_DR_RD_REL	= 20,
123 	ICP_DR_WR_REL	= 21,
124 	ICP_DR_ABS	= 22,
125 	ICP_DR_RD_ABS	= 23,
126 	ICP_DR_WR_ABS	= 24,
127 	ICP_LMEM	= 26,
128 	ICP_LMEM0	= 27,
129 	ICP_LMEM1	= 28,
130 	ICP_NEIGH_REL	= 31,
131 	ICP_LMEM2	= 61,
132 	ICP_LMEM3	= 62,
133 };
134 
135 enum icp_qat_css_fwtype {
136 	CSS_AE_FIRMWARE = 0,
137 	CSS_MMP_FIRMWARE = 1
138 };
139 
140 struct icp_qat_uclo_page {
141 	struct icp_qat_uclo_encap_page *encap_page;
142 	struct icp_qat_uclo_region *region;
143 	unsigned int flags;
144 };
145 
146 struct icp_qat_uclo_region {
147 	struct icp_qat_uclo_page *loaded;
148 	struct icp_qat_uclo_page *page;
149 };
150 
151 struct icp_qat_uclo_aeslice {
152 	struct icp_qat_uclo_region *region;
153 	struct icp_qat_uclo_page *page;
154 	struct icp_qat_uclo_page *cur_page[ICP_QAT_UCLO_MAX_CTX];
155 	struct icp_qat_uclo_encapme *encap_image;
156 	unsigned int ctx_mask_assigned;
157 	unsigned int new_uaddr[ICP_QAT_UCLO_MAX_CTX];
158 };
159 
160 struct icp_qat_uclo_aedata {
161 	unsigned int slice_num;
162 	unsigned int eff_ustore_size;
163 	struct icp_qat_uclo_aeslice ae_slices[ICP_QAT_UCLO_MAX_CTX];
164 };
165 
166 struct icp_qat_uof_encap_obj {
167 	char *beg_uof;
168 	struct icp_qat_uof_objhdr *obj_hdr;
169 	struct icp_qat_uof_chunkhdr *chunk_hdr;
170 	struct icp_qat_uof_varmem_seg *var_mem_seg;
171 };
172 
173 struct icp_qat_uclo_encap_uwblock {
174 	unsigned int start_addr;
175 	unsigned int words_num;
176 	u64 micro_words;
177 };
178 
179 struct icp_qat_uclo_encap_page {
180 	unsigned int def_page;
181 	unsigned int page_region;
182 	unsigned int beg_addr_v;
183 	unsigned int beg_addr_p;
184 	unsigned int micro_words_num;
185 	unsigned int uwblock_num;
186 	struct icp_qat_uclo_encap_uwblock *uwblock;
187 };
188 
189 struct icp_qat_uclo_encapme {
190 	struct icp_qat_uof_image *img_ptr;
191 	struct icp_qat_uclo_encap_page *page;
192 	unsigned int ae_reg_num;
193 	struct icp_qat_uof_ae_reg *ae_reg;
194 	unsigned int init_regsym_num;
195 	struct icp_qat_uof_init_regsym *init_regsym;
196 	unsigned int sbreak_num;
197 	struct icp_qat_uof_sbreak *sbreak;
198 	unsigned int uwords_num;
199 };
200 
201 struct icp_qat_uclo_init_mem_table {
202 	unsigned int entry_num;
203 	struct icp_qat_uof_initmem *init_mem;
204 };
205 
206 struct icp_qat_uclo_objhdr {
207 	char *file_buff;
208 	unsigned int checksum;
209 	unsigned int size;
210 };
211 
212 struct icp_qat_uof_strtable {
213 	unsigned int table_len;
214 	unsigned int reserved;
215 	u64 strings;
216 };
217 
218 struct icp_qat_uclo_objhandle {
219 	unsigned int prod_type;
220 	unsigned int prod_rev;
221 	struct icp_qat_uclo_objhdr *obj_hdr;
222 	struct icp_qat_uof_encap_obj encap_uof_obj;
223 	struct icp_qat_uof_strtable str_table;
224 	struct icp_qat_uclo_encapme ae_uimage[ICP_QAT_UCLO_MAX_UIMAGE];
225 	struct icp_qat_uclo_aedata ae_data[ICP_QAT_UCLO_MAX_AE];
226 	struct icp_qat_uclo_init_mem_table init_mem_tab;
227 	struct icp_qat_uof_batch_init *lm_init_tab[ICP_QAT_UCLO_MAX_AE];
228 	struct icp_qat_uof_batch_init *umem_init_tab[ICP_QAT_UCLO_MAX_AE];
229 	int uimage_num;
230 	int uword_in_bytes;
231 	int global_inited;
232 	unsigned int ae_num;
233 	unsigned int ustore_phy_size;
234 	void *obj_buf;
235 	u64 *uword_buf;
236 };
237 
238 struct icp_qat_uof_uword_block {
239 	unsigned int start_addr;
240 	unsigned int words_num;
241 	unsigned int uword_offset;
242 	unsigned int reserved;
243 };
244 
245 struct icp_qat_uof_filehdr {
246 	unsigned short file_id;
247 	unsigned short reserved1;
248 	char min_ver;
249 	char maj_ver;
250 	unsigned short reserved2;
251 	unsigned short max_chunks;
252 	unsigned short num_chunks;
253 };
254 
255 struct icp_qat_uof_filechunkhdr {
256 	char chunk_id[ICP_QAT_UOF_OBJID_LEN];
257 	unsigned int checksum;
258 	unsigned int offset;
259 	unsigned int size;
260 };
261 
262 struct icp_qat_uof_objhdr {
263 	unsigned int ac_dev_type;
264 	unsigned short min_cpu_ver;
265 	unsigned short max_cpu_ver;
266 	short max_chunks;
267 	short num_chunks;
268 	unsigned int reserved1;
269 	unsigned int reserved2;
270 };
271 
272 struct icp_qat_uof_chunkhdr {
273 	char chunk_id[ICP_QAT_UOF_OBJID_LEN];
274 	unsigned int offset;
275 	unsigned int size;
276 };
277 
278 struct icp_qat_uof_memvar_attr {
279 	unsigned int offset_in_byte;
280 	unsigned int value;
281 };
282 
283 struct icp_qat_uof_initmem {
284 	unsigned int sym_name;
285 	char region;
286 	char scope;
287 	unsigned short reserved1;
288 	unsigned int addr;
289 	unsigned int num_in_bytes;
290 	unsigned int val_attr_num;
291 };
292 
293 struct icp_qat_uof_init_regsym {
294 	unsigned int sym_name;
295 	char init_type;
296 	char value_type;
297 	char reg_type;
298 	unsigned char ctx;
299 	unsigned int reg_addr;
300 	unsigned int value;
301 };
302 
303 struct icp_qat_uof_varmem_seg {
304 	unsigned int sram_base;
305 	unsigned int sram_size;
306 	unsigned int sram_alignment;
307 	unsigned int sdram_base;
308 	unsigned int sdram_size;
309 	unsigned int sdram_alignment;
310 	unsigned int sdram1_base;
311 	unsigned int sdram1_size;
312 	unsigned int sdram1_alignment;
313 	unsigned int scratch_base;
314 	unsigned int scratch_size;
315 	unsigned int scratch_alignment;
316 };
317 
318 struct icp_qat_uof_gtid {
319 	char tool_id[ICP_QAT_UOF_OBJID_LEN];
320 	int tool_ver;
321 	unsigned int reserved1;
322 	unsigned int reserved2;
323 };
324 
325 struct icp_qat_uof_sbreak {
326 	unsigned int page_num;
327 	unsigned int virt_uaddr;
328 	unsigned char sbreak_type;
329 	unsigned char reg_type;
330 	unsigned short reserved1;
331 	unsigned int addr_offset;
332 	unsigned int reg_addr;
333 };
334 
335 struct icp_qat_uof_code_page {
336 	unsigned int page_region;
337 	unsigned int page_num;
338 	unsigned char def_page;
339 	unsigned char reserved2;
340 	unsigned short reserved1;
341 	unsigned int beg_addr_v;
342 	unsigned int beg_addr_p;
343 	unsigned int neigh_reg_tab_offset;
344 	unsigned int uc_var_tab_offset;
345 	unsigned int imp_var_tab_offset;
346 	unsigned int imp_expr_tab_offset;
347 	unsigned int code_area_offset;
348 };
349 
350 struct icp_qat_uof_image {
351 	unsigned int img_name;
352 	unsigned int ae_assigned;
353 	unsigned int ctx_assigned;
354 	unsigned int ac_dev_type;
355 	unsigned int entry_address;
356 	unsigned int fill_pattern[2];
357 	unsigned int reloadable_size;
358 	unsigned char sensitivity;
359 	unsigned char reserved;
360 	unsigned short ae_mode;
361 	unsigned short max_ver;
362 	unsigned short min_ver;
363 	unsigned short image_attrib;
364 	unsigned short reserved2;
365 	unsigned short page_region_num;
366 	unsigned short numpages;
367 	unsigned int reg_tab_offset;
368 	unsigned int init_reg_sym_tab;
369 	unsigned int sbreak_tab;
370 	unsigned int app_metadata;
371 };
372 
373 struct icp_qat_uof_objtable {
374 	unsigned int entry_num;
375 };
376 
377 struct icp_qat_uof_ae_reg {
378 	unsigned int name;
379 	unsigned int vis_name;
380 	unsigned short type;
381 	unsigned short addr;
382 	unsigned short access_mode;
383 	unsigned char visible;
384 	unsigned char reserved1;
385 	unsigned short ref_count;
386 	unsigned short reserved2;
387 	unsigned int xo_id;
388 };
389 
390 struct icp_qat_uof_code_area {
391 	unsigned int micro_words_num;
392 	unsigned int uword_block_tab;
393 };
394 
395 struct icp_qat_uof_batch_init {
396 	unsigned int ae;
397 	unsigned int addr;
398 	unsigned int *value;
399 	unsigned int size;
400 	struct icp_qat_uof_batch_init *next;
401 };
402 
403 struct icp_qat_suof_img_hdr {
404 	char          *simg_buf;
405 	unsigned long simg_len;
406 	char          *css_header;
407 	char          *css_key;
408 	char          *css_signature;
409 	char          *css_simg;
410 	unsigned long simg_size;
411 	unsigned int  ae_num;
412 	unsigned int  ae_mask;
413 	unsigned int  fw_type;
414 	unsigned long simg_name;
415 	unsigned long appmeta_data;
416 };
417 
418 struct icp_qat_suof_img_tbl {
419 	unsigned int num_simgs;
420 	struct icp_qat_suof_img_hdr *simg_hdr;
421 };
422 
423 struct icp_qat_suof_handle {
424 	unsigned int  file_id;
425 	unsigned int  check_sum;
426 	char          min_ver;
427 	char          maj_ver;
428 	char          fw_type;
429 	char          *suof_buf;
430 	unsigned int  suof_size;
431 	char          *sym_str;
432 	unsigned int  sym_size;
433 	struct icp_qat_suof_img_tbl img_table;
434 };
435 
436 struct icp_qat_fw_auth_desc {
437 	unsigned int   img_len;
438 	unsigned int   ae_mask;
439 	unsigned int   css_hdr_high;
440 	unsigned int   css_hdr_low;
441 	unsigned int   img_high;
442 	unsigned int   img_low;
443 	unsigned int   signature_high;
444 	unsigned int   signature_low;
445 	unsigned int   fwsk_pub_high;
446 	unsigned int   fwsk_pub_low;
447 	unsigned int   img_ae_mode_data_high;
448 	unsigned int   img_ae_mode_data_low;
449 	unsigned int   img_ae_init_data_high;
450 	unsigned int   img_ae_init_data_low;
451 	unsigned int   img_ae_insts_high;
452 	unsigned int   img_ae_insts_low;
453 };
454 
455 struct icp_qat_auth_chunk {
456 	struct icp_qat_fw_auth_desc fw_auth_desc;
457 	u64 chunk_size;
458 	u64 chunk_bus_addr;
459 };
460 
461 struct icp_qat_css_hdr {
462 	unsigned int module_type;
463 	unsigned int header_len;
464 	unsigned int header_ver;
465 	unsigned int module_id;
466 	unsigned int module_vendor;
467 	unsigned int date;
468 	unsigned int size;
469 	unsigned int key_size;
470 	unsigned int module_size;
471 	unsigned int exponent_size;
472 	unsigned int fw_type;
473 	unsigned int reserved[21];
474 };
475 
476 struct icp_qat_simg_ae_mode {
477 	unsigned int     file_id;
478 	unsigned short   maj_ver;
479 	unsigned short   min_ver;
480 	unsigned int     dev_type;
481 	unsigned short   devmax_ver;
482 	unsigned short   devmin_ver;
483 	unsigned int     ae_mask;
484 	unsigned int     ctx_enables;
485 	char             fw_type;
486 	char             ctx_mode;
487 	char             nn_mode;
488 	char             lm0_mode;
489 	char             lm1_mode;
490 	char             scs_mode;
491 	char             lm2_mode;
492 	char             lm3_mode;
493 	char             tindex_mode;
494 	unsigned char    reserved[7];
495 	char             simg_name[256];
496 	char             appmeta_data[256];
497 };
498 
499 struct icp_qat_suof_filehdr {
500 	unsigned int     file_id;
501 	unsigned int     check_sum;
502 	char             min_ver;
503 	char             maj_ver;
504 	char             fw_type;
505 	char             reserved;
506 	unsigned short   max_chunks;
507 	unsigned short   num_chunks;
508 };
509 
510 struct icp_qat_suof_chunk_hdr {
511 	char chunk_id[ICP_QAT_SUOF_OBJ_ID_LEN];
512 	u64 offset;
513 	u64 size;
514 };
515 
516 struct icp_qat_suof_strtable {
517 	unsigned int tab_length;
518 	unsigned int strings;
519 };
520 
521 struct icp_qat_suof_objhdr {
522 	unsigned int img_length;
523 	unsigned int reserved;
524 };
525 
526 struct icp_qat_mof_file_hdr {
527 	unsigned int file_id;
528 	unsigned int checksum;
529 	char min_ver;
530 	char maj_ver;
531 	unsigned short reserved;
532 	unsigned short max_chunks;
533 	unsigned short num_chunks;
534 };
535 
536 struct icp_qat_mof_chunkhdr {
537 	char chunk_id[ICP_QAT_MOF_OBJ_ID_LEN];
538 	u64 offset;
539 	u64 size;
540 };
541 
542 struct icp_qat_mof_str_table {
543 	unsigned int tab_len;
544 	unsigned int strings;
545 };
546 
547 struct icp_qat_mof_obj_hdr {
548 	unsigned short max_chunks;
549 	unsigned short num_chunks;
550 	unsigned int reserved;
551 };
552 
553 struct icp_qat_mof_obj_chunkhdr {
554 	char chunk_id[ICP_QAT_MOF_OBJ_CHUNKID_LEN];
555 	u64 offset;
556 	u64 size;
557 	unsigned int name;
558 	unsigned int reserved;
559 };
560 
561 struct icp_qat_mof_objhdr {
562 	char *obj_name;
563 	char *obj_buf;
564 	unsigned int obj_size;
565 };
566 
567 struct icp_qat_mof_table {
568 	unsigned int num_objs;
569 	struct icp_qat_mof_objhdr *obj_hdr;
570 };
571 
572 struct icp_qat_mof_handle {
573 	unsigned int file_id;
574 	unsigned int checksum;
575 	char min_ver;
576 	char maj_ver;
577 	char *mof_buf;
578 	u32 mof_size;
579 	char *sym_str;
580 	unsigned int sym_size;
581 	char *uobjs_hdr;
582 	char *sobjs_hdr;
583 	struct icp_qat_mof_table obj_table;
584 };
585 #endif
586