xref: /openbmc/linux/drivers/crypto/marvell/octeontx/otx_cptpf_ucode.h (revision 4b4193256c8d3bc3a5397b5cd9494c2ad386317d)
1d9110b0bSSrujanaChalla /* SPDX-License-Identifier: GPL-2.0
2d9110b0bSSrujanaChalla  * Marvell OcteonTX CPT driver
3d9110b0bSSrujanaChalla  *
4d9110b0bSSrujanaChalla  * Copyright (C) 2019 Marvell International Ltd.
5d9110b0bSSrujanaChalla  *
6d9110b0bSSrujanaChalla  * This program is free software; you can redistribute it and/or modify
7d9110b0bSSrujanaChalla  * it under the terms of the GNU General Public License version 2 as
8d9110b0bSSrujanaChalla  * published by the Free Software Foundation.
9d9110b0bSSrujanaChalla  */
10d9110b0bSSrujanaChalla 
11d9110b0bSSrujanaChalla #ifndef __OTX_CPTPF_UCODE_H
12d9110b0bSSrujanaChalla #define __OTX_CPTPF_UCODE_H
13d9110b0bSSrujanaChalla 
14d9110b0bSSrujanaChalla #include <linux/pci.h>
15d9110b0bSSrujanaChalla #include <linux/types.h>
16d9110b0bSSrujanaChalla #include <linux/module.h>
17d9110b0bSSrujanaChalla #include "otx_cpt_hw_types.h"
18d9110b0bSSrujanaChalla 
19d9110b0bSSrujanaChalla /* CPT ucode name maximum length */
20d9110b0bSSrujanaChalla #define OTX_CPT_UCODE_NAME_LENGTH	64
21d9110b0bSSrujanaChalla /*
22d9110b0bSSrujanaChalla  * On OcteonTX 83xx platform, only one type of engines is allowed to be
23d9110b0bSSrujanaChalla  * attached to an engine group.
24d9110b0bSSrujanaChalla  */
25d9110b0bSSrujanaChalla #define OTX_CPT_MAX_ETYPES_PER_GRP	1
26d9110b0bSSrujanaChalla 
27d9110b0bSSrujanaChalla /* Default tar archive file names */
28d9110b0bSSrujanaChalla #define OTX_CPT_UCODE_TAR_FILE_NAME	"cpt8x-mc.tar"
29d9110b0bSSrujanaChalla 
30d9110b0bSSrujanaChalla /* CPT ucode alignment */
31d9110b0bSSrujanaChalla #define OTX_CPT_UCODE_ALIGNMENT		128
32d9110b0bSSrujanaChalla 
33d9110b0bSSrujanaChalla /* CPT ucode signature size */
34d9110b0bSSrujanaChalla #define OTX_CPT_UCODE_SIGN_LEN		256
35d9110b0bSSrujanaChalla 
36d9110b0bSSrujanaChalla /* Microcode version string length */
37d9110b0bSSrujanaChalla #define OTX_CPT_UCODE_VER_STR_SZ	44
38d9110b0bSSrujanaChalla 
39d9110b0bSSrujanaChalla /* Maximum number of supported engines/cores on OcteonTX 83XX platform */
40d9110b0bSSrujanaChalla #define OTX_CPT_MAX_ENGINES		64
41d9110b0bSSrujanaChalla 
42d9110b0bSSrujanaChalla #define OTX_CPT_ENGS_BITMASK_LEN	(OTX_CPT_MAX_ENGINES/(BITS_PER_BYTE * \
43d9110b0bSSrujanaChalla 					 sizeof(unsigned long)))
44d9110b0bSSrujanaChalla 
45d9110b0bSSrujanaChalla /* Microcode types */
46d9110b0bSSrujanaChalla enum otx_cpt_ucode_type {
47d9110b0bSSrujanaChalla 	OTX_CPT_AE_UC_TYPE =	1,  /* AE-MAIN */
48d9110b0bSSrujanaChalla 	OTX_CPT_SE_UC_TYPE1 =	20, /* SE-MAIN - combination of 21 and 22 */
49d9110b0bSSrujanaChalla 	OTX_CPT_SE_UC_TYPE2 =	21, /* Fast Path IPSec + AirCrypto */
50d9110b0bSSrujanaChalla 	OTX_CPT_SE_UC_TYPE3 =	22, /*
51d9110b0bSSrujanaChalla 				     * Hash + HMAC + FlexiCrypto + RNG + Full
52d9110b0bSSrujanaChalla 				     * Feature IPSec + AirCrypto + Kasumi
53d9110b0bSSrujanaChalla 				     */
54d9110b0bSSrujanaChalla };
55d9110b0bSSrujanaChalla 
56d9110b0bSSrujanaChalla struct otx_cpt_bitmap {
57d9110b0bSSrujanaChalla 	unsigned long bits[OTX_CPT_ENGS_BITMASK_LEN];
58d9110b0bSSrujanaChalla 	int size;
59d9110b0bSSrujanaChalla };
60d9110b0bSSrujanaChalla 
61d9110b0bSSrujanaChalla struct otx_cpt_engines {
62d9110b0bSSrujanaChalla 	int type;
63d9110b0bSSrujanaChalla 	int count;
64d9110b0bSSrujanaChalla };
65d9110b0bSSrujanaChalla 
66d9110b0bSSrujanaChalla /* Microcode version number */
67d9110b0bSSrujanaChalla struct otx_cpt_ucode_ver_num {
68d9110b0bSSrujanaChalla 	u8 nn;
69d9110b0bSSrujanaChalla 	u8 xx;
70d9110b0bSSrujanaChalla 	u8 yy;
71d9110b0bSSrujanaChalla 	u8 zz;
72d9110b0bSSrujanaChalla };
73d9110b0bSSrujanaChalla 
74d9110b0bSSrujanaChalla struct otx_cpt_ucode_hdr {
75d9110b0bSSrujanaChalla 	struct otx_cpt_ucode_ver_num ver_num;
76d9110b0bSSrujanaChalla 	u8 ver_str[OTX_CPT_UCODE_VER_STR_SZ];
77*a05b1c15SHerbert Xu 	__be32 code_length;
78d9110b0bSSrujanaChalla 	u32 padding[3];
79d9110b0bSSrujanaChalla };
80d9110b0bSSrujanaChalla 
81d9110b0bSSrujanaChalla struct otx_cpt_ucode {
82d9110b0bSSrujanaChalla 	u8 ver_str[OTX_CPT_UCODE_VER_STR_SZ];/*
83d9110b0bSSrujanaChalla 					      * ucode version in readable format
84d9110b0bSSrujanaChalla 					      */
85d9110b0bSSrujanaChalla 	struct otx_cpt_ucode_ver_num ver_num;/* ucode version number */
86d9110b0bSSrujanaChalla 	char filename[OTX_CPT_UCODE_NAME_LENGTH];	 /* ucode filename */
87d9110b0bSSrujanaChalla 	dma_addr_t dma;		/* phys address of ucode image */
88d9110b0bSSrujanaChalla 	dma_addr_t align_dma;	/* aligned phys address of ucode image */
89d9110b0bSSrujanaChalla 	void *va;		/* virt address of ucode image */
90d9110b0bSSrujanaChalla 	void *align_va;		/* aligned virt address of ucode image */
91d9110b0bSSrujanaChalla 	u32 size;		/* ucode image size */
92d9110b0bSSrujanaChalla 	int type;		/* ucode image type SE or AE */
93d9110b0bSSrujanaChalla };
94d9110b0bSSrujanaChalla 
95d9110b0bSSrujanaChalla struct tar_ucode_info_t {
96d9110b0bSSrujanaChalla 	struct list_head list;
97d9110b0bSSrujanaChalla 	struct otx_cpt_ucode ucode;/* microcode information */
98d9110b0bSSrujanaChalla 	const u8 *ucode_ptr;	/* pointer to microcode in tar archive */
99d9110b0bSSrujanaChalla };
100d9110b0bSSrujanaChalla 
101d9110b0bSSrujanaChalla /* Maximum and current number of engines available for all engine groups */
102d9110b0bSSrujanaChalla struct otx_cpt_engs_available {
103d9110b0bSSrujanaChalla 	int max_se_cnt;
104d9110b0bSSrujanaChalla 	int max_ae_cnt;
105d9110b0bSSrujanaChalla 	int se_cnt;
106d9110b0bSSrujanaChalla 	int ae_cnt;
107d9110b0bSSrujanaChalla };
108d9110b0bSSrujanaChalla 
109d9110b0bSSrujanaChalla /* Engines reserved to an engine group */
110d9110b0bSSrujanaChalla struct otx_cpt_engs_rsvd {
111d9110b0bSSrujanaChalla 	int type;	/* engine type */
112d9110b0bSSrujanaChalla 	int count;	/* number of engines attached */
113d9110b0bSSrujanaChalla 	int offset;     /* constant offset of engine type in the bitmap */
114d9110b0bSSrujanaChalla 	unsigned long *bmap;		/* attached engines bitmap */
115d9110b0bSSrujanaChalla 	struct otx_cpt_ucode *ucode;	/* ucode used by these engines */
116d9110b0bSSrujanaChalla };
117d9110b0bSSrujanaChalla 
118d9110b0bSSrujanaChalla struct otx_cpt_mirror_info {
119d9110b0bSSrujanaChalla 	int is_ena;	/*
120d9110b0bSSrujanaChalla 			 * is mirroring enabled, it is set only for engine
121d9110b0bSSrujanaChalla 			 * group which mirrors another engine group
122d9110b0bSSrujanaChalla 			 */
123d9110b0bSSrujanaChalla 	int idx;	/*
124d9110b0bSSrujanaChalla 			 * index of engine group which is mirrored by this
125d9110b0bSSrujanaChalla 			 * group, set only for engine group which mirrors
126d9110b0bSSrujanaChalla 			 * another group
127d9110b0bSSrujanaChalla 			 */
128d9110b0bSSrujanaChalla 	int ref_count;	/*
129d9110b0bSSrujanaChalla 			 * number of times this engine group is mirrored by
130d9110b0bSSrujanaChalla 			 * other groups, this is set only for engine group
131d9110b0bSSrujanaChalla 			 * which is mirrored by other group(s)
132d9110b0bSSrujanaChalla 			 */
133d9110b0bSSrujanaChalla };
134d9110b0bSSrujanaChalla 
135d9110b0bSSrujanaChalla struct otx_cpt_eng_grp_info {
136d9110b0bSSrujanaChalla 	struct otx_cpt_eng_grps *g; /* pointer to engine_groups structure */
137d9110b0bSSrujanaChalla 	struct device_attribute info_attr; /* group info entry attr */
138d9110b0bSSrujanaChalla 	/* engines attached */
139d9110b0bSSrujanaChalla 	struct otx_cpt_engs_rsvd engs[OTX_CPT_MAX_ETYPES_PER_GRP];
140d9110b0bSSrujanaChalla 	/* Microcode information */
141d9110b0bSSrujanaChalla 	struct otx_cpt_ucode ucode[OTX_CPT_MAX_ETYPES_PER_GRP];
142d9110b0bSSrujanaChalla 	/* sysfs info entry name */
143d9110b0bSSrujanaChalla 	char sysfs_info_name[OTX_CPT_UCODE_NAME_LENGTH];
144d9110b0bSSrujanaChalla 	/* engine group mirroring information */
145d9110b0bSSrujanaChalla 	struct otx_cpt_mirror_info mirror;
146d9110b0bSSrujanaChalla 	int idx;	 /* engine group index */
147d9110b0bSSrujanaChalla 	bool is_enabled; /*
148d9110b0bSSrujanaChalla 			  * is engine group enabled, engine group is enabled
149d9110b0bSSrujanaChalla 			  * when it has engines attached and ucode loaded
150d9110b0bSSrujanaChalla 			  */
151d9110b0bSSrujanaChalla };
152d9110b0bSSrujanaChalla 
153d9110b0bSSrujanaChalla struct otx_cpt_eng_grps {
154d9110b0bSSrujanaChalla 	struct otx_cpt_eng_grp_info grp[OTX_CPT_MAX_ENGINE_GROUPS];
155d9110b0bSSrujanaChalla 	struct device_attribute ucode_load_attr;/* ucode load attr */
156d9110b0bSSrujanaChalla 	struct otx_cpt_engs_available avail;
157d9110b0bSSrujanaChalla 	struct mutex lock;
158d9110b0bSSrujanaChalla 	void *obj;
159d9110b0bSSrujanaChalla 	int engs_num;			/* total number of engines supported */
160d9110b0bSSrujanaChalla 	int eng_types_supported;	/* engine types supported SE, AE */
161d9110b0bSSrujanaChalla 	u8 eng_ref_cnt[OTX_CPT_MAX_ENGINES];/* engines reference count */
162d9110b0bSSrujanaChalla 	bool is_ucode_load_created;	/* is ucode_load sysfs entry created */
163d9110b0bSSrujanaChalla 	bool is_first_try; /* is this first try to create kcrypto engine grp */
164d9110b0bSSrujanaChalla 	bool is_rdonly;	/* do engine groups configuration can be modified */
165d9110b0bSSrujanaChalla };
166d9110b0bSSrujanaChalla 
167d9110b0bSSrujanaChalla int otx_cpt_init_eng_grps(struct pci_dev *pdev,
168d9110b0bSSrujanaChalla 			  struct otx_cpt_eng_grps *eng_grps, int pf_type);
169d9110b0bSSrujanaChalla void otx_cpt_cleanup_eng_grps(struct pci_dev *pdev,
170d9110b0bSSrujanaChalla 			      struct otx_cpt_eng_grps *eng_grps);
171d9110b0bSSrujanaChalla int otx_cpt_try_create_default_eng_grps(struct pci_dev *pdev,
172d9110b0bSSrujanaChalla 					struct otx_cpt_eng_grps *eng_grps,
173d9110b0bSSrujanaChalla 					int pf_type);
174d9110b0bSSrujanaChalla void otx_cpt_set_eng_grps_is_rdonly(struct otx_cpt_eng_grps *eng_grps,
175d9110b0bSSrujanaChalla 				    bool is_rdonly);
176d9110b0bSSrujanaChalla int otx_cpt_uc_supports_eng_type(struct otx_cpt_ucode *ucode, int eng_type);
177d9110b0bSSrujanaChalla int otx_cpt_eng_grp_has_eng_type(struct otx_cpt_eng_grp_info *eng_grp,
178d9110b0bSSrujanaChalla 				 int eng_type);
179d9110b0bSSrujanaChalla 
180d9110b0bSSrujanaChalla #endif /* __OTX_CPTPF_UCODE_H */
181