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