/* SPDX-License-Identifier: GPL-2.0-only * Copyright (C) 2020 Marvell. */ #ifndef __OTX2_CPTPF_UCODE_H #define __OTX2_CPTPF_UCODE_H #include <linux/pci.h> #include <linux/types.h> #include <linux/module.h> #include "otx2_cpt_hw_types.h" #include "otx2_cpt_common.h" /* * On OcteonTX2 platform IPSec ucode can use both IE and SE engines therefore * IE and SE engines can be attached to the same engine group. */ #define OTX2_CPT_MAX_ETYPES_PER_GRP 2 /* CPT ucode signature size */ #define OTX2_CPT_UCODE_SIGN_LEN 256 /* Microcode version string length */ #define OTX2_CPT_UCODE_VER_STR_SZ 44 /* Maximum number of supported engines/cores on OcteonTX2/CN10K platform */ #define OTX2_CPT_MAX_ENGINES 144 #define OTX2_CPT_ENGS_BITMASK_LEN BITS_TO_LONGS(OTX2_CPT_MAX_ENGINES) #define OTX2_CPT_UCODE_SZ (64 * 1024) /* Microcode types */ enum otx2_cpt_ucode_type { OTX2_CPT_AE_UC_TYPE = 1, /* AE-MAIN */ OTX2_CPT_SE_UC_TYPE1 = 20,/* SE-MAIN - combination of 21 and 22 */ OTX2_CPT_SE_UC_TYPE2 = 21,/* Fast Path IPSec + AirCrypto */ OTX2_CPT_SE_UC_TYPE3 = 22,/* * Hash + HMAC + FlexiCrypto + RNG + * Full Feature IPSec + AirCrypto + Kasumi */ OTX2_CPT_IE_UC_TYPE1 = 30, /* IE-MAIN - combination of 31 and 32 */ OTX2_CPT_IE_UC_TYPE2 = 31, /* Fast Path IPSec */ OTX2_CPT_IE_UC_TYPE3 = 32, /* * Hash + HMAC + FlexiCrypto + RNG + * Full Future IPSec */ }; struct otx2_cpt_bitmap { unsigned long bits[OTX2_CPT_ENGS_BITMASK_LEN]; int size; }; struct otx2_cpt_engines { int type; int count; }; /* Microcode version number */ struct otx2_cpt_ucode_ver_num { u8 nn; u8 xx; u8 yy; u8 zz; }; struct otx2_cpt_ucode_hdr { struct otx2_cpt_ucode_ver_num ver_num; u8 ver_str[OTX2_CPT_UCODE_VER_STR_SZ]; __be32 code_length; u32 padding[3]; }; struct otx2_cpt_ucode { u8 ver_str[OTX2_CPT_UCODE_VER_STR_SZ + 1];/* * ucode version in readable * format */ struct otx2_cpt_ucode_ver_num ver_num;/* ucode version number */ char filename[OTX2_CPT_NAME_LENGTH];/* ucode filename */ dma_addr_t dma; /* phys address of ucode image */ void *va; /* virt address of ucode image */ u32 size; /* ucode image size */ int type; /* ucode image type SE, IE, AE or SE+IE */ }; struct otx2_cpt_uc_info_t { struct list_head list; struct otx2_cpt_ucode ucode;/* microcode information */ const struct firmware *fw; }; /* Maximum and current number of engines available for all engine groups */ struct otx2_cpt_engs_available { int max_se_cnt; int max_ie_cnt; int max_ae_cnt; int se_cnt; int ie_cnt; int ae_cnt; }; /* Engines reserved to an engine group */ struct otx2_cpt_engs_rsvd { int type; /* engine type */ int count; /* number of engines attached */ int offset; /* constant offset of engine type in the bitmap */ unsigned long *bmap; /* attached engines bitmap */ struct otx2_cpt_ucode *ucode; /* ucode used by these engines */ }; struct otx2_cpt_mirror_info { int is_ena; /* * is mirroring enabled, it is set only for engine * group which mirrors another engine group */ int idx; /* * index of engine group which is mirrored by this * group, set only for engine group which mirrors * another group */ int ref_count; /* * number of times this engine group is mirrored by * other groups, this is set only for engine group * which is mirrored by other group(s) */ }; struct otx2_cpt_eng_grp_info { struct otx2_cpt_eng_grps *g; /* pointer to engine_groups structure */ /* engines attached */ struct otx2_cpt_engs_rsvd engs[OTX2_CPT_MAX_ETYPES_PER_GRP]; /* ucodes information */ struct otx2_cpt_ucode ucode[OTX2_CPT_MAX_ETYPES_PER_GRP]; /* engine group mirroring information */ struct otx2_cpt_mirror_info mirror; int idx; /* engine group index */ bool is_enabled; /* * is engine group enabled, engine group is enabled * when it has engines attached and ucode loaded */ }; struct otx2_cpt_eng_grps { struct mutex lock; struct otx2_cpt_eng_grp_info grp[OTX2_CPT_MAX_ENGINE_GROUPS]; struct otx2_cpt_engs_available avail; void *obj; /* device specific data */ int engs_num; /* total number of engines supported */ u8 eng_ref_cnt[OTX2_CPT_MAX_ENGINES];/* engines reference count */ bool is_grps_created; /* Is the engine groups are already created */ u16 rid; }; struct otx2_cptpf_dev; int otx2_cpt_init_eng_grps(struct pci_dev *pdev, struct otx2_cpt_eng_grps *eng_grps); void otx2_cpt_cleanup_eng_grps(struct pci_dev *pdev, struct otx2_cpt_eng_grps *eng_grps); int otx2_cpt_create_eng_grps(struct otx2_cptpf_dev *cptpf, struct otx2_cpt_eng_grps *eng_grps); int otx2_cpt_disable_all_cores(struct otx2_cptpf_dev *cptpf); int otx2_cpt_get_eng_grp(struct otx2_cpt_eng_grps *eng_grps, int eng_type); int otx2_cpt_discover_eng_capabilities(struct otx2_cptpf_dev *cptpf); int otx2_cpt_dl_custom_egrp_create(struct otx2_cptpf_dev *cptpf, struct devlink_param_gset_ctx *ctx); int otx2_cpt_dl_custom_egrp_delete(struct otx2_cptpf_dev *cptpf, struct devlink_param_gset_ctx *ctx); void otx2_cpt_print_uc_dbg_info(struct otx2_cptpf_dev *cptpf); struct otx2_cpt_engs_rsvd *find_engines_by_type( struct otx2_cpt_eng_grp_info *eng_grp, int eng_type); #endif /* __OTX2_CPTPF_UCODE_H */