0001
0002
0003
0004
0005
0006
0007
0008 #ifndef __SAFEXCEL_H__
0009 #define __SAFEXCEL_H__
0010
0011 #include <crypto/aead.h>
0012 #include <crypto/algapi.h>
0013 #include <crypto/internal/hash.h>
0014 #include <crypto/sha1.h>
0015 #include <crypto/sha2.h>
0016 #include <crypto/sha3.h>
0017 #include <crypto/skcipher.h>
0018 #include <linux/types.h>
0019
0020 #define EIP197_HIA_VERSION_BE 0xca35
0021 #define EIP197_HIA_VERSION_LE 0x35ca
0022 #define EIP97_VERSION_LE 0x9e61
0023 #define EIP196_VERSION_LE 0x3bc4
0024 #define EIP197_VERSION_LE 0x3ac5
0025 #define EIP96_VERSION_LE 0x9f60
0026 #define EIP201_VERSION_LE 0x36c9
0027 #define EIP206_VERSION_LE 0x31ce
0028 #define EIP207_VERSION_LE 0x30cf
0029 #define EIP197_REG_LO16(reg) (reg & 0xffff)
0030 #define EIP197_REG_HI16(reg) ((reg >> 16) & 0xffff)
0031 #define EIP197_VERSION_MASK(reg) ((reg >> 16) & 0xfff)
0032 #define EIP197_VERSION_SWAP(reg) (((reg & 0xf0) << 4) | \
0033 ((reg >> 4) & 0xf0) | \
0034 ((reg >> 12) & 0xf))
0035
0036
0037 #define EIP197_HIA_OPT_HAS_PE_ARB BIT(29)
0038
0039
0040 #define EIP206_OPT_ICE_TYPE(n) ((n>>8)&3)
0041 #define EIP206_OPT_OCE_TYPE(n) ((n>>10)&3)
0042
0043
0044 #define EIP197_OPT_HAS_TRC BIT(31)
0045
0046
0047 #define EIP197_DEFAULT_RING_SIZE 400
0048 #define EIP197_EMB_TOKENS 4
0049 #define EIP197_MAX_TOKENS 16
0050 #define EIP197_MAX_RINGS 4
0051 #define EIP197_FETCH_DEPTH 2
0052 #define EIP197_MAX_BATCH_SZ 64
0053 #define EIP197_MAX_RING_AIC 14
0054
0055 #define EIP197_GFP_FLAGS(base) ((base).flags & CRYPTO_TFM_REQ_MAY_SLEEP ? \
0056 GFP_KERNEL : GFP_ATOMIC)
0057
0058
0059 #define EIP197_SKCIPHER_REQ_SIZE sizeof(struct skcipher_request) + \
0060 sizeof(struct safexcel_cipher_req)
0061 #define EIP197_AHASH_REQ_SIZE sizeof(struct ahash_request) + \
0062 sizeof(struct safexcel_ahash_req)
0063 #define EIP197_AEAD_REQ_SIZE sizeof(struct aead_request) + \
0064 sizeof(struct safexcel_cipher_req)
0065 #define EIP197_REQUEST_ON_STACK(name, type, size) \
0066 char __##name##_desc[size] CRYPTO_MINALIGN_ATTR; \
0067 struct type##_request *name = (void *)__##name##_desc
0068
0069
0070 #define EIP197_XLX_GPIO_BASE 0x200000
0071 #define EIP197_XLX_IRQ_BLOCK_ID_ADDR 0x2000
0072 #define EIP197_XLX_IRQ_BLOCK_ID_VALUE 0x1fc2
0073 #define EIP197_XLX_USER_INT_ENB_MSK 0x2004
0074 #define EIP197_XLX_USER_INT_ENB_SET 0x2008
0075 #define EIP197_XLX_USER_INT_ENB_CLEAR 0x200c
0076 #define EIP197_XLX_USER_INT_BLOCK 0x2040
0077 #define EIP197_XLX_USER_INT_PEND 0x2048
0078 #define EIP197_XLX_USER_VECT_LUT0_ADDR 0x2080
0079 #define EIP197_XLX_USER_VECT_LUT0_IDENT 0x03020100
0080 #define EIP197_XLX_USER_VECT_LUT1_ADDR 0x2084
0081 #define EIP197_XLX_USER_VECT_LUT1_IDENT 0x07060504
0082 #define EIP197_XLX_USER_VECT_LUT2_ADDR 0x2088
0083 #define EIP197_XLX_USER_VECT_LUT2_IDENT 0x0b0a0908
0084 #define EIP197_XLX_USER_VECT_LUT3_ADDR 0x208c
0085 #define EIP197_XLX_USER_VECT_LUT3_IDENT 0x0f0e0d0c
0086
0087
0088 #define EIP197_IRQ_NUMBER(i, is_pci) (i + is_pci)
0089
0090
0091 #define EIP197_HIA_AIC(priv) ((priv)->base + (priv)->offsets.hia_aic)
0092 #define EIP197_HIA_AIC_G(priv) ((priv)->base + (priv)->offsets.hia_aic_g)
0093 #define EIP197_HIA_AIC_R(priv) ((priv)->base + (priv)->offsets.hia_aic_r)
0094 #define EIP197_HIA_AIC_xDR(priv) ((priv)->base + (priv)->offsets.hia_aic_xdr)
0095 #define EIP197_HIA_DFE(priv) ((priv)->base + (priv)->offsets.hia_dfe)
0096 #define EIP197_HIA_DFE_THR(priv) ((priv)->base + (priv)->offsets.hia_dfe_thr)
0097 #define EIP197_HIA_DSE(priv) ((priv)->base + (priv)->offsets.hia_dse)
0098 #define EIP197_HIA_DSE_THR(priv) ((priv)->base + (priv)->offsets.hia_dse_thr)
0099 #define EIP197_HIA_GEN_CFG(priv) ((priv)->base + (priv)->offsets.hia_gen_cfg)
0100 #define EIP197_PE(priv) ((priv)->base + (priv)->offsets.pe)
0101 #define EIP197_GLOBAL(priv) ((priv)->base + (priv)->offsets.global)
0102
0103
0104 #define EIP197_HIA_AIC_BASE 0x90000
0105 #define EIP197_HIA_AIC_G_BASE 0x90000
0106 #define EIP197_HIA_AIC_R_BASE 0x90800
0107 #define EIP197_HIA_AIC_xDR_BASE 0x80000
0108 #define EIP197_HIA_DFE_BASE 0x8c000
0109 #define EIP197_HIA_DFE_THR_BASE 0x8c040
0110 #define EIP197_HIA_DSE_BASE 0x8d000
0111 #define EIP197_HIA_DSE_THR_BASE 0x8d040
0112 #define EIP197_HIA_GEN_CFG_BASE 0xf0000
0113 #define EIP197_PE_BASE 0xa0000
0114 #define EIP197_GLOBAL_BASE 0xf0000
0115
0116
0117 #define EIP97_HIA_AIC_BASE 0x0
0118 #define EIP97_HIA_AIC_G_BASE 0x0
0119 #define EIP97_HIA_AIC_R_BASE 0x0
0120 #define EIP97_HIA_AIC_xDR_BASE 0x0
0121 #define EIP97_HIA_DFE_BASE 0xf000
0122 #define EIP97_HIA_DFE_THR_BASE 0xf200
0123 #define EIP97_HIA_DSE_BASE 0xf400
0124 #define EIP97_HIA_DSE_THR_BASE 0xf600
0125 #define EIP97_HIA_GEN_CFG_BASE 0x10000
0126 #define EIP97_PE_BASE 0x10000
0127 #define EIP97_GLOBAL_BASE 0x10000
0128
0129
0130 #define EIP197_HIA_xDR_OFF(priv, r) (EIP197_HIA_AIC_xDR(priv) + (r) * 0x1000)
0131 #define EIP197_HIA_CDR(priv, r) (EIP197_HIA_xDR_OFF(priv, r))
0132 #define EIP197_HIA_RDR(priv, r) (EIP197_HIA_xDR_OFF(priv, r) + 0x800)
0133 #define EIP197_HIA_xDR_RING_BASE_ADDR_LO 0x0000
0134 #define EIP197_HIA_xDR_RING_BASE_ADDR_HI 0x0004
0135 #define EIP197_HIA_xDR_RING_SIZE 0x0018
0136 #define EIP197_HIA_xDR_DESC_SIZE 0x001c
0137 #define EIP197_HIA_xDR_CFG 0x0020
0138 #define EIP197_HIA_xDR_DMA_CFG 0x0024
0139 #define EIP197_HIA_xDR_THRESH 0x0028
0140 #define EIP197_HIA_xDR_PREP_COUNT 0x002c
0141 #define EIP197_HIA_xDR_PROC_COUNT 0x0030
0142 #define EIP197_HIA_xDR_PREP_PNTR 0x0034
0143 #define EIP197_HIA_xDR_PROC_PNTR 0x0038
0144 #define EIP197_HIA_xDR_STAT 0x003c
0145
0146
0147 #define EIP197_HIA_DFE_CFG(n) (0x0000 + (128 * (n)))
0148 #define EIP197_HIA_DFE_THR_CTRL(n) (0x0000 + (128 * (n)))
0149 #define EIP197_HIA_DFE_THR_STAT(n) (0x0004 + (128 * (n)))
0150 #define EIP197_HIA_DSE_CFG(n) (0x0000 + (128 * (n)))
0151 #define EIP197_HIA_DSE_THR_CTRL(n) (0x0000 + (128 * (n)))
0152 #define EIP197_HIA_DSE_THR_STAT(n) (0x0004 + (128 * (n)))
0153 #define EIP197_HIA_RA_PE_CTRL(n) (0x0010 + (8 * (n)))
0154 #define EIP197_HIA_RA_PE_STAT 0x0014
0155 #define EIP197_HIA_AIC_R_OFF(r) ((r) * 0x1000)
0156 #define EIP197_HIA_AIC_R_ENABLE_CTRL(r) (0xe008 - EIP197_HIA_AIC_R_OFF(r))
0157 #define EIP197_HIA_AIC_R_ENABLED_STAT(r) (0xe010 - EIP197_HIA_AIC_R_OFF(r))
0158 #define EIP197_HIA_AIC_R_ACK(r) (0xe010 - EIP197_HIA_AIC_R_OFF(r))
0159 #define EIP197_HIA_AIC_R_ENABLE_CLR(r) (0xe014 - EIP197_HIA_AIC_R_OFF(r))
0160 #define EIP197_HIA_AIC_R_VERSION(r) (0xe01c - EIP197_HIA_AIC_R_OFF(r))
0161 #define EIP197_HIA_AIC_G_ENABLE_CTRL 0xf808
0162 #define EIP197_HIA_AIC_G_ENABLED_STAT 0xf810
0163 #define EIP197_HIA_AIC_G_ACK 0xf810
0164 #define EIP197_HIA_MST_CTRL 0xfff4
0165 #define EIP197_HIA_OPTIONS 0xfff8
0166 #define EIP197_HIA_VERSION 0xfffc
0167 #define EIP197_PE_IN_DBUF_THRES(n) (0x0000 + (0x2000 * (n)))
0168 #define EIP197_PE_IN_TBUF_THRES(n) (0x0100 + (0x2000 * (n)))
0169 #define EIP197_PE_ICE_SCRATCH_RAM(n) (0x0800 + (0x2000 * (n)))
0170 #define EIP197_PE_ICE_PUE_CTRL(n) (0x0c80 + (0x2000 * (n)))
0171 #define EIP197_PE_ICE_PUTF_CTRL(n) (0x0d00 + (0x2000 * (n)))
0172 #define EIP197_PE_ICE_SCRATCH_CTRL(n) (0x0d04 + (0x2000 * (n)))
0173 #define EIP197_PE_ICE_FPP_CTRL(n) (0x0d80 + (0x2000 * (n)))
0174 #define EIP197_PE_ICE_PPTF_CTRL(n) (0x0e00 + (0x2000 * (n)))
0175 #define EIP197_PE_ICE_RAM_CTRL(n) (0x0ff0 + (0x2000 * (n)))
0176 #define EIP197_PE_ICE_VERSION(n) (0x0ffc + (0x2000 * (n)))
0177 #define EIP197_PE_EIP96_TOKEN_CTRL(n) (0x1000 + (0x2000 * (n)))
0178 #define EIP197_PE_EIP96_FUNCTION_EN(n) (0x1004 + (0x2000 * (n)))
0179 #define EIP197_PE_EIP96_CONTEXT_CTRL(n) (0x1008 + (0x2000 * (n)))
0180 #define EIP197_PE_EIP96_CONTEXT_STAT(n) (0x100c + (0x2000 * (n)))
0181 #define EIP197_PE_EIP96_TOKEN_CTRL2(n) (0x102c + (0x2000 * (n)))
0182 #define EIP197_PE_EIP96_FUNCTION2_EN(n) (0x1030 + (0x2000 * (n)))
0183 #define EIP197_PE_EIP96_OPTIONS(n) (0x13f8 + (0x2000 * (n)))
0184 #define EIP197_PE_EIP96_VERSION(n) (0x13fc + (0x2000 * (n)))
0185 #define EIP197_PE_OCE_VERSION(n) (0x1bfc + (0x2000 * (n)))
0186 #define EIP197_PE_OUT_DBUF_THRES(n) (0x1c00 + (0x2000 * (n)))
0187 #define EIP197_PE_OUT_TBUF_THRES(n) (0x1d00 + (0x2000 * (n)))
0188 #define EIP197_PE_PSE_VERSION(n) (0x1efc + (0x2000 * (n)))
0189 #define EIP197_PE_DEBUG(n) (0x1ff4 + (0x2000 * (n)))
0190 #define EIP197_PE_OPTIONS(n) (0x1ff8 + (0x2000 * (n)))
0191 #define EIP197_PE_VERSION(n) (0x1ffc + (0x2000 * (n)))
0192 #define EIP197_MST_CTRL 0xfff4
0193 #define EIP197_OPTIONS 0xfff8
0194 #define EIP197_VERSION 0xfffc
0195
0196
0197 #define EIP197_CLASSIFICATION_RAMS 0xe0000
0198 #define EIP197_TRC_CTRL 0xf0800
0199 #define EIP197_TRC_LASTRES 0xf0804
0200 #define EIP197_TRC_REGINDEX 0xf0808
0201 #define EIP197_TRC_PARAMS 0xf0820
0202 #define EIP197_TRC_FREECHAIN 0xf0824
0203 #define EIP197_TRC_PARAMS2 0xf0828
0204 #define EIP197_TRC_ECCCTRL 0xf0830
0205 #define EIP197_TRC_ECCSTAT 0xf0834
0206 #define EIP197_TRC_ECCADMINSTAT 0xf0838
0207 #define EIP197_TRC_ECCDATASTAT 0xf083c
0208 #define EIP197_TRC_ECCDATA 0xf0840
0209 #define EIP197_STRC_CONFIG 0xf43f0
0210 #define EIP197_FLUE_CACHEBASE_LO(n) (0xf6000 + (32 * (n)))
0211 #define EIP197_FLUE_CACHEBASE_HI(n) (0xf6004 + (32 * (n)))
0212 #define EIP197_FLUE_CONFIG(n) (0xf6010 + (32 * (n)))
0213 #define EIP197_FLUE_OFFSETS 0xf6808
0214 #define EIP197_FLUE_ARC4_OFFSET 0xf680c
0215 #define EIP197_FLUE_IFC_LUT(n) (0xf6820 + (4 * (n)))
0216 #define EIP197_CS_RAM_CTRL 0xf7ff0
0217
0218
0219 #define EIP197_xDR_DESC_MODE_64BIT BIT(31)
0220 #define EIP197_CDR_DESC_MODE_ADCP BIT(30)
0221
0222
0223 #define EIP197_HIA_xDR_WR_RES_BUF BIT(22)
0224 #define EIP197_HIA_xDR_WR_CTRL_BUF BIT(23)
0225 #define EIP197_HIA_xDR_WR_OWN_BUF BIT(24)
0226 #define EIP197_HIA_xDR_CFG_WR_CACHE(n) (((n) & 0x7) << 25)
0227 #define EIP197_HIA_xDR_CFG_RD_CACHE(n) (((n) & 0x7) << 29)
0228
0229
0230 #define EIP197_HIA_CDR_THRESH_PROC_PKT(n) (n)
0231 #define EIP197_HIA_CDR_THRESH_PROC_MODE BIT(22)
0232 #define EIP197_HIA_CDR_THRESH_PKT_MODE BIT(23)
0233 #define EIP197_HIA_CDR_THRESH_TIMEOUT(n) ((n) << 24)
0234
0235
0236 #define EIP197_HIA_RDR_THRESH_PROC_PKT(n) (n)
0237 #define EIP197_HIA_RDR_THRESH_PKT_MODE BIT(23)
0238 #define EIP197_HIA_RDR_THRESH_TIMEOUT(n) ((n) << 24)
0239
0240
0241 #define EIP197_xDR_PREP_CLR_COUNT BIT(31)
0242
0243
0244 #define EIP197_xDR_PROC_xD_PKT_OFFSET 24
0245 #define EIP197_xDR_PROC_xD_PKT_MASK GENMASK(6, 0)
0246 #define EIP197_xDR_PROC_xD_PKT(n) ((n) << 24)
0247 #define EIP197_xDR_PROC_CLR_COUNT BIT(31)
0248
0249
0250 #define EIP197_xDR_DMA_ERR BIT(0)
0251 #define EIP197_xDR_PREP_CMD_THRES BIT(1)
0252 #define EIP197_xDR_ERR BIT(2)
0253 #define EIP197_xDR_THRESH BIT(4)
0254 #define EIP197_xDR_TIMEOUT BIT(5)
0255
0256 #define EIP197_HIA_RA_PE_CTRL_RESET BIT(31)
0257 #define EIP197_HIA_RA_PE_CTRL_EN BIT(30)
0258
0259
0260 #define EIP197_N_RINGS_OFFSET 0
0261 #define EIP197_N_RINGS_MASK GENMASK(3, 0)
0262 #define EIP197_N_PES_OFFSET 4
0263 #define EIP197_N_PES_MASK GENMASK(4, 0)
0264 #define EIP97_N_PES_MASK GENMASK(2, 0)
0265 #define EIP197_HWDATAW_OFFSET 25
0266 #define EIP197_HWDATAW_MASK GENMASK(3, 0)
0267 #define EIP97_HWDATAW_MASK GENMASK(2, 0)
0268 #define EIP197_CFSIZE_OFFSET 9
0269 #define EIP197_CFSIZE_ADJUST 4
0270 #define EIP97_CFSIZE_OFFSET 8
0271 #define EIP197_CFSIZE_MASK GENMASK(2, 0)
0272 #define EIP97_CFSIZE_MASK GENMASK(3, 0)
0273 #define EIP197_RFSIZE_OFFSET 12
0274 #define EIP197_RFSIZE_ADJUST 4
0275 #define EIP97_RFSIZE_OFFSET 12
0276 #define EIP197_RFSIZE_MASK GENMASK(2, 0)
0277 #define EIP97_RFSIZE_MASK GENMASK(3, 0)
0278
0279
0280 #define EIP197_CDR_IRQ(n) BIT((n) * 2)
0281 #define EIP197_RDR_IRQ(n) BIT((n) * 2 + 1)
0282
0283
0284 #define EIP197_HIA_DxE_CFG_MIN_DATA_SIZE(n) ((n) << 0)
0285 #define EIP197_HIA_DxE_CFG_DATA_CACHE_CTRL(n) (((n) & 0x7) << 4)
0286 #define EIP197_HIA_DxE_CFG_MAX_DATA_SIZE(n) ((n) << 8)
0287 #define EIP197_HIA_DSE_CFG_ALWAYS_BUFFERABLE GENMASK(15, 14)
0288 #define EIP197_HIA_DxE_CFG_MIN_CTRL_SIZE(n) ((n) << 16)
0289 #define EIP197_HIA_DxE_CFG_CTRL_CACHE_CTRL(n) (((n) & 0x7) << 20)
0290 #define EIP197_HIA_DxE_CFG_MAX_CTRL_SIZE(n) ((n) << 24)
0291 #define EIP197_HIA_DFE_CFG_DIS_DEBUG GENMASK(31, 29)
0292 #define EIP197_HIA_DSE_CFG_EN_SINGLE_WR BIT(29)
0293 #define EIP197_HIA_DSE_CFG_DIS_DEBUG GENMASK(31, 30)
0294
0295
0296 #define EIP197_DxE_THR_CTRL_EN BIT(30)
0297 #define EIP197_DxE_THR_CTRL_RESET_PE BIT(31)
0298
0299
0300 #define EIP197_PE_ICE_UENG_START_OFFSET(n) ((n) << 16)
0301 #define EIP197_PE_ICE_UENG_INIT_ALIGN_MASK 0x7ff0
0302 #define EIP197_PE_ICE_UENG_DEBUG_RESET BIT(3)
0303
0304
0305 #define EIP197_G_IRQ_DFE(n) BIT((n) << 1)
0306 #define EIP197_G_IRQ_DSE(n) BIT(((n) << 1) + 1)
0307 #define EIP197_G_IRQ_RING BIT(16)
0308 #define EIP197_G_IRQ_PE(n) BIT((n) + 20)
0309
0310
0311 #define RD_CACHE_3BITS 0x5
0312 #define WR_CACHE_3BITS 0x3
0313 #define RD_CACHE_4BITS (RD_CACHE_3BITS << 1 | BIT(0))
0314 #define WR_CACHE_4BITS (WR_CACHE_3BITS << 1 | BIT(0))
0315 #define EIP197_MST_CTRL_RD_CACHE(n) (((n) & 0xf) << 0)
0316 #define EIP197_MST_CTRL_WD_CACHE(n) (((n) & 0xf) << 4)
0317 #define EIP197_MST_CTRL_TX_MAX_CMD(n) (((n) & 0xf) << 20)
0318 #define EIP197_MST_CTRL_BYTE_SWAP BIT(24)
0319 #define EIP197_MST_CTRL_NO_BYTE_SWAP BIT(25)
0320 #define EIP197_MST_CTRL_BYTE_SWAP_BITS GENMASK(25, 24)
0321
0322
0323 #define EIP197_PE_IN_xBUF_THRES_MIN(n) ((n) << 8)
0324 #define EIP197_PE_IN_xBUF_THRES_MAX(n) ((n) << 12)
0325
0326
0327 #define EIP197_PE_OUT_DBUF_THRES_MIN(n) ((n) << 0)
0328 #define EIP197_PE_OUT_DBUF_THRES_MAX(n) ((n) << 4)
0329
0330
0331 #define EIP197_PE_ICE_SCRATCH_CTRL_CHANGE_TIMER BIT(2)
0332 #define EIP197_PE_ICE_SCRATCH_CTRL_TIMER_EN BIT(3)
0333 #define EIP197_PE_ICE_SCRATCH_CTRL_CHANGE_ACCESS BIT(24)
0334 #define EIP197_PE_ICE_SCRATCH_CTRL_SCRATCH_ACCESS BIT(25)
0335
0336
0337 #define EIP197_NUM_OF_SCRATCH_BLOCKS 32
0338
0339
0340 #define EIP197_PE_ICE_x_CTRL_SW_RESET BIT(0)
0341 #define EIP197_PE_ICE_x_CTRL_CLR_ECC_NON_CORR BIT(14)
0342 #define EIP197_PE_ICE_x_CTRL_CLR_ECC_CORR BIT(15)
0343
0344
0345 #define EIP197_PE_ICE_RAM_CTRL_PUE_PROG_EN BIT(0)
0346 #define EIP197_PE_ICE_RAM_CTRL_FPP_PROG_EN BIT(1)
0347
0348
0349 #define EIP197_PE_EIP96_TOKEN_CTRL_CTX_UPDATES BIT(16)
0350 #define EIP197_PE_EIP96_TOKEN_CTRL_NO_TOKEN_WAIT BIT(17)
0351 #define EIP197_PE_EIP96_TOKEN_CTRL_ENABLE_TIMEOUT BIT(22)
0352
0353
0354 #define EIP197_FUNCTION_ALL 0xffffffff
0355
0356
0357 #define EIP197_CONTEXT_SIZE(n) (n)
0358 #define EIP197_ADDRESS_MODE BIT(8)
0359 #define EIP197_CONTROL_MODE BIT(9)
0360
0361
0362 #define EIP197_PE_EIP96_TOKEN_CTRL2_CTX_DONE BIT(3)
0363
0364
0365 #define EIP197_DEBUG_OCE_BYPASS BIT(1)
0366
0367
0368 #define EIP197_STRC_CONFIG_INIT BIT(31)
0369 #define EIP197_STRC_CONFIG_LARGE_REC(s) (s<<8)
0370 #define EIP197_STRC_CONFIG_SMALL_REC(s) (s<<0)
0371
0372
0373 #define EIP197_FLUE_CONFIG_MAGIC 0xc7000004
0374
0375
0376 struct safexcel_context_record {
0377 __le32 control0;
0378 __le32 control1;
0379
0380 __le32 data[40];
0381 } __packed;
0382
0383
0384 #define CONTEXT_CONTROL_TYPE_NULL_OUT 0x0
0385 #define CONTEXT_CONTROL_TYPE_NULL_IN 0x1
0386 #define CONTEXT_CONTROL_TYPE_HASH_OUT 0x2
0387 #define CONTEXT_CONTROL_TYPE_HASH_IN 0x3
0388 #define CONTEXT_CONTROL_TYPE_CRYPTO_OUT 0x4
0389 #define CONTEXT_CONTROL_TYPE_CRYPTO_IN 0x5
0390 #define CONTEXT_CONTROL_TYPE_ENCRYPT_HASH_OUT 0x6
0391 #define CONTEXT_CONTROL_TYPE_DECRYPT_HASH_IN 0x7
0392 #define CONTEXT_CONTROL_TYPE_HASH_ENCRYPT_OUT 0xe
0393 #define CONTEXT_CONTROL_TYPE_HASH_DECRYPT_IN 0xf
0394 #define CONTEXT_CONTROL_RESTART_HASH BIT(4)
0395 #define CONTEXT_CONTROL_NO_FINISH_HASH BIT(5)
0396 #define CONTEXT_CONTROL_SIZE(n) ((n) << 8)
0397 #define CONTEXT_CONTROL_KEY_EN BIT(16)
0398 #define CONTEXT_CONTROL_CRYPTO_ALG_DES (0x0 << 17)
0399 #define CONTEXT_CONTROL_CRYPTO_ALG_3DES (0x2 << 17)
0400 #define CONTEXT_CONTROL_CRYPTO_ALG_AES128 (0x5 << 17)
0401 #define CONTEXT_CONTROL_CRYPTO_ALG_AES192 (0x6 << 17)
0402 #define CONTEXT_CONTROL_CRYPTO_ALG_AES256 (0x7 << 17)
0403 #define CONTEXT_CONTROL_CRYPTO_ALG_CHACHA20 (0x8 << 17)
0404 #define CONTEXT_CONTROL_CRYPTO_ALG_SM4 (0xd << 17)
0405 #define CONTEXT_CONTROL_DIGEST_INITIAL (0x0 << 21)
0406 #define CONTEXT_CONTROL_DIGEST_PRECOMPUTED (0x1 << 21)
0407 #define CONTEXT_CONTROL_DIGEST_XCM (0x2 << 21)
0408 #define CONTEXT_CONTROL_DIGEST_HMAC (0x3 << 21)
0409 #define CONTEXT_CONTROL_CRYPTO_ALG_MD5 (0x0 << 23)
0410 #define CONTEXT_CONTROL_CRYPTO_ALG_CRC32 (0x0 << 23)
0411 #define CONTEXT_CONTROL_CRYPTO_ALG_SHA1 (0x2 << 23)
0412 #define CONTEXT_CONTROL_CRYPTO_ALG_SHA224 (0x4 << 23)
0413 #define CONTEXT_CONTROL_CRYPTO_ALG_SHA256 (0x3 << 23)
0414 #define CONTEXT_CONTROL_CRYPTO_ALG_SHA384 (0x6 << 23)
0415 #define CONTEXT_CONTROL_CRYPTO_ALG_SHA512 (0x5 << 23)
0416 #define CONTEXT_CONTROL_CRYPTO_ALG_GHASH (0x4 << 23)
0417 #define CONTEXT_CONTROL_CRYPTO_ALG_XCBC128 (0x1 << 23)
0418 #define CONTEXT_CONTROL_CRYPTO_ALG_XCBC192 (0x2 << 23)
0419 #define CONTEXT_CONTROL_CRYPTO_ALG_XCBC256 (0x3 << 23)
0420 #define CONTEXT_CONTROL_CRYPTO_ALG_SM3 (0x7 << 23)
0421 #define CONTEXT_CONTROL_CRYPTO_ALG_SHA3_256 (0xb << 23)
0422 #define CONTEXT_CONTROL_CRYPTO_ALG_SHA3_224 (0xc << 23)
0423 #define CONTEXT_CONTROL_CRYPTO_ALG_SHA3_512 (0xd << 23)
0424 #define CONTEXT_CONTROL_CRYPTO_ALG_SHA3_384 (0xe << 23)
0425 #define CONTEXT_CONTROL_CRYPTO_ALG_POLY1305 (0xf << 23)
0426 #define CONTEXT_CONTROL_INV_FR (0x5 << 24)
0427 #define CONTEXT_CONTROL_INV_TR (0x6 << 24)
0428
0429
0430 #define CONTEXT_CONTROL_CRYPTO_MODE_ECB (0 << 0)
0431 #define CONTEXT_CONTROL_CRYPTO_MODE_CBC (1 << 0)
0432 #define CONTEXT_CONTROL_CHACHA20_MODE_256_32 (2 << 0)
0433 #define CONTEXT_CONTROL_CRYPTO_MODE_OFB (4 << 0)
0434 #define CONTEXT_CONTROL_CRYPTO_MODE_CFB (5 << 0)
0435 #define CONTEXT_CONTROL_CRYPTO_MODE_CTR_LOAD (6 << 0)
0436 #define CONTEXT_CONTROL_CRYPTO_MODE_XTS (7 << 0)
0437 #define CONTEXT_CONTROL_CRYPTO_MODE_XCM ((6 << 0) | BIT(17))
0438 #define CONTEXT_CONTROL_CHACHA20_MODE_CALC_OTK (12 << 0)
0439 #define CONTEXT_CONTROL_IV0 BIT(5)
0440 #define CONTEXT_CONTROL_IV1 BIT(6)
0441 #define CONTEXT_CONTROL_IV2 BIT(7)
0442 #define CONTEXT_CONTROL_IV3 BIT(8)
0443 #define CONTEXT_CONTROL_DIGEST_CNT BIT(9)
0444 #define CONTEXT_CONTROL_COUNTER_MODE BIT(10)
0445 #define CONTEXT_CONTROL_CRYPTO_STORE BIT(12)
0446 #define CONTEXT_CONTROL_HASH_STORE BIT(19)
0447
0448 #define EIP197_XCM_MODE_GCM 1
0449 #define EIP197_XCM_MODE_CCM 2
0450
0451 #define EIP197_AEAD_TYPE_IPSEC_ESP 2
0452 #define EIP197_AEAD_TYPE_IPSEC_ESP_GMAC 3
0453 #define EIP197_AEAD_IPSEC_IV_SIZE 8
0454 #define EIP197_AEAD_IPSEC_NONCE_SIZE 4
0455 #define EIP197_AEAD_IPSEC_COUNTER_SIZE 4
0456 #define EIP197_AEAD_IPSEC_CCM_NONCE_SIZE 3
0457
0458
0459
0460
0461 #define EIP197_COUNTER_BLOCK_SIZE 64
0462
0463
0464 #define EIP197_TRC_ENABLE_0 BIT(4)
0465 #define EIP197_TRC_ENABLE_1 BIT(5)
0466 #define EIP197_TRC_ENABLE_2 BIT(6)
0467 #define EIP197_TRC_ENABLE_MASK GENMASK(6, 4)
0468 #define EIP197_CS_BANKSEL_MASK GENMASK(14, 12)
0469 #define EIP197_CS_BANKSEL_OFS 12
0470
0471
0472 #define EIP197_TRC_PARAMS_SW_RESET BIT(0)
0473 #define EIP197_TRC_PARAMS_DATA_ACCESS BIT(2)
0474 #define EIP197_TRC_PARAMS_HTABLE_SZ(x) ((x) << 4)
0475 #define EIP197_TRC_PARAMS_BLK_TIMER_SPEED(x) ((x) << 10)
0476 #define EIP197_TRC_PARAMS_RC_SZ_LARGE(n) ((n) << 18)
0477
0478
0479 #define EIP197_TRC_FREECHAIN_HEAD_PTR(p) (p)
0480 #define EIP197_TRC_FREECHAIN_TAIL_PTR(p) ((p) << 16)
0481
0482
0483 #define EIP197_TRC_PARAMS2_HTABLE_PTR(p) (p)
0484 #define EIP197_TRC_PARAMS2_RC_SZ_SMALL(n) ((n) << 18)
0485
0486
0487 #define EIP197_MIN_DSIZE 1024
0488 #define EIP197_MIN_ASIZE 8
0489 #define EIP197_CS_TRC_REC_WC 64
0490 #define EIP197_CS_RC_SIZE (4 * sizeof(u32))
0491 #define EIP197_CS_RC_NEXT(x) (x)
0492 #define EIP197_CS_RC_PREV(x) ((x) << 10)
0493 #define EIP197_RC_NULL 0x3ff
0494
0495
0496 struct result_data_desc {
0497 u32 packet_length:17;
0498 u32 error_code:15;
0499
0500 u32 bypass_length:4;
0501 u32 e15:1;
0502 u32 rsvd0:16;
0503 u32 hash_bytes:1;
0504 u32 hash_length:6;
0505 u32 generic_bytes:1;
0506 u32 checksum:1;
0507 u32 next_header:1;
0508 u32 length:1;
0509
0510 u16 application_id;
0511 u16 rsvd1;
0512
0513 u32 rsvd2[5];
0514 } __packed;
0515
0516
0517
0518 struct safexcel_result_desc {
0519 u32 particle_size:17;
0520 u8 rsvd0:3;
0521 u8 descriptor_overflow:1;
0522 u8 buffer_overflow:1;
0523 u8 last_seg:1;
0524 u8 first_seg:1;
0525 u16 result_size:8;
0526
0527 u32 rsvd1;
0528
0529 u32 data_lo;
0530 u32 data_hi;
0531 } __packed;
0532
0533
0534
0535
0536
0537 #define EIP197_RD64_FETCH_SIZE (sizeof(struct safexcel_result_desc) /\
0538 sizeof(u32))
0539 #define EIP197_RD64_RESULT_SIZE (sizeof(struct result_data_desc) /\
0540 sizeof(u32))
0541
0542 struct safexcel_token {
0543 u32 packet_length:17;
0544 u8 stat:2;
0545 u16 instructions:9;
0546 u8 opcode:4;
0547 } __packed;
0548
0549 #define EIP197_TOKEN_HASH_RESULT_VERIFY BIT(16)
0550
0551 #define EIP197_TOKEN_CTX_OFFSET(x) (x)
0552 #define EIP197_TOKEN_DIRECTION_EXTERNAL BIT(11)
0553 #define EIP197_TOKEN_EXEC_IF_SUCCESSFUL (0x1 << 12)
0554
0555 #define EIP197_TOKEN_STAT_LAST_HASH BIT(0)
0556 #define EIP197_TOKEN_STAT_LAST_PACKET BIT(1)
0557 #define EIP197_TOKEN_OPCODE_DIRECTION 0x0
0558 #define EIP197_TOKEN_OPCODE_INSERT 0x2
0559 #define EIP197_TOKEN_OPCODE_NOOP EIP197_TOKEN_OPCODE_INSERT
0560 #define EIP197_TOKEN_OPCODE_RETRIEVE 0x4
0561 #define EIP197_TOKEN_OPCODE_INSERT_REMRES 0xa
0562 #define EIP197_TOKEN_OPCODE_VERIFY 0xd
0563 #define EIP197_TOKEN_OPCODE_CTX_ACCESS 0xe
0564 #define EIP197_TOKEN_OPCODE_BYPASS GENMASK(3, 0)
0565
0566 static inline void eip197_noop_token(struct safexcel_token *token)
0567 {
0568 token->opcode = EIP197_TOKEN_OPCODE_NOOP;
0569 token->packet_length = BIT(2);
0570 token->stat = 0;
0571 token->instructions = 0;
0572 }
0573
0574
0575 #define EIP197_TOKEN_INS_INSERT_HASH_DIGEST 0x1c
0576 #define EIP197_TOKEN_INS_ORIGIN_IV0 0x14
0577 #define EIP197_TOKEN_INS_ORIGIN_TOKEN 0x1b
0578 #define EIP197_TOKEN_INS_ORIGIN_LEN(x) ((x) << 5)
0579 #define EIP197_TOKEN_INS_TYPE_OUTPUT BIT(5)
0580 #define EIP197_TOKEN_INS_TYPE_HASH BIT(6)
0581 #define EIP197_TOKEN_INS_TYPE_CRYPTO BIT(7)
0582 #define EIP197_TOKEN_INS_LAST BIT(8)
0583
0584
0585 struct safexcel_control_data_desc {
0586 u32 packet_length:17;
0587 u16 options:13;
0588 u8 type:2;
0589
0590 u16 application_id;
0591 u16 rsvd;
0592
0593 u32 context_lo;
0594 u32 context_hi;
0595
0596 u32 control0;
0597 u32 control1;
0598
0599 u32 token[EIP197_EMB_TOKENS];
0600 } __packed;
0601
0602 #define EIP197_OPTION_MAGIC_VALUE BIT(0)
0603 #define EIP197_OPTION_64BIT_CTX BIT(1)
0604 #define EIP197_OPTION_RC_AUTO (0x2 << 3)
0605 #define EIP197_OPTION_CTX_CTRL_IN_CMD BIT(8)
0606 #define EIP197_OPTION_2_TOKEN_IV_CMD GENMASK(11, 10)
0607 #define EIP197_OPTION_4_TOKEN_IV_CMD GENMASK(11, 9)
0608
0609 #define EIP197_TYPE_BCLA 0x0
0610 #define EIP197_TYPE_EXTENDED 0x3
0611 #define EIP197_CONTEXT_SMALL 0x2
0612 #define EIP197_CONTEXT_SIZE_MASK 0x3
0613
0614
0615 struct safexcel_command_desc {
0616 u32 particle_size:17;
0617 u8 rsvd0:5;
0618 u8 last_seg:1;
0619 u8 first_seg:1;
0620 u8 additional_cdata_size:8;
0621
0622 u32 rsvd1;
0623
0624 u32 data_lo;
0625 u32 data_hi;
0626
0627 u32 atok_lo;
0628 u32 atok_hi;
0629
0630 struct safexcel_control_data_desc control_data;
0631 } __packed;
0632
0633 #define EIP197_CD64_FETCH_SIZE (sizeof(struct safexcel_command_desc) /\
0634 sizeof(u32))
0635
0636
0637
0638
0639
0640 #define EIP197_FW_TERMINAL_NOPS 2
0641 #define EIP197_FW_START_POLLCNT 16
0642 #define EIP197_FW_PUE_READY 0x14
0643 #define EIP197_FW_FPP_READY 0x18
0644
0645 enum eip197_fw {
0646 FW_IFPP = 0,
0647 FW_IPUE,
0648 FW_NB
0649 };
0650
0651 struct safexcel_desc_ring {
0652 void *base;
0653 void *shbase;
0654 void *base_end;
0655 void *shbase_end;
0656 dma_addr_t base_dma;
0657 dma_addr_t shbase_dma;
0658
0659
0660 void *write;
0661 void *shwrite;
0662 void *read;
0663
0664
0665 unsigned int offset;
0666 unsigned int shoffset;
0667 };
0668
0669 enum safexcel_alg_type {
0670 SAFEXCEL_ALG_TYPE_SKCIPHER,
0671 SAFEXCEL_ALG_TYPE_AEAD,
0672 SAFEXCEL_ALG_TYPE_AHASH,
0673 };
0674
0675 struct safexcel_config {
0676 u32 pes;
0677 u32 rings;
0678
0679 u32 cd_size;
0680 u32 cd_offset;
0681 u32 cdsh_offset;
0682
0683 u32 rd_size;
0684 u32 rd_offset;
0685 u32 res_offset;
0686 };
0687
0688 struct safexcel_work_data {
0689 struct work_struct work;
0690 struct safexcel_crypto_priv *priv;
0691 int ring;
0692 };
0693
0694 struct safexcel_ring {
0695 spinlock_t lock;
0696
0697 struct workqueue_struct *workqueue;
0698 struct safexcel_work_data work_data;
0699
0700
0701 struct safexcel_desc_ring cdr;
0702 struct safexcel_desc_ring rdr;
0703
0704
0705 struct crypto_async_request **rdr_req;
0706
0707
0708 struct crypto_queue queue;
0709 spinlock_t queue_lock;
0710
0711
0712 int requests;
0713
0714
0715 bool busy;
0716
0717
0718
0719
0720 struct crypto_async_request *req;
0721 struct crypto_async_request *backlog;
0722
0723
0724 int irq;
0725 };
0726
0727
0728 enum safexcel_eip_version {
0729
0730 EIP97IES_MRVL,
0731 EIP197B_MRVL,
0732 EIP197D_MRVL,
0733 EIP197_DEVBRD
0734 };
0735
0736
0737 #define SAFEXCEL_CRA_PRIORITY 300
0738
0739
0740 #define EIP197_SM3_ZEROM_HASH "\x1A\xB2\x1D\x83\x55\xCF\xA1\x7F" \
0741 "\x8E\x61\x19\x48\x31\xE8\x1A\x8F" \
0742 "\x22\xBE\xC8\xC7\x28\xFE\xFB\x74" \
0743 "\x7E\xD0\x35\xEB\x50\x82\xAA\x2B"
0744
0745
0746 enum safexcel_eip_algorithms {
0747 SAFEXCEL_ALG_BC0 = BIT(5),
0748 SAFEXCEL_ALG_SM4 = BIT(6),
0749 SAFEXCEL_ALG_SM3 = BIT(7),
0750 SAFEXCEL_ALG_CHACHA20 = BIT(8),
0751 SAFEXCEL_ALG_POLY1305 = BIT(9),
0752 SAFEXCEL_SEQMASK_256 = BIT(10),
0753 SAFEXCEL_SEQMASK_384 = BIT(11),
0754 SAFEXCEL_ALG_AES = BIT(12),
0755 SAFEXCEL_ALG_AES_XFB = BIT(13),
0756 SAFEXCEL_ALG_DES = BIT(15),
0757 SAFEXCEL_ALG_DES_XFB = BIT(16),
0758 SAFEXCEL_ALG_ARC4 = BIT(18),
0759 SAFEXCEL_ALG_AES_XTS = BIT(20),
0760 SAFEXCEL_ALG_WIRELESS = BIT(21),
0761 SAFEXCEL_ALG_MD5 = BIT(22),
0762 SAFEXCEL_ALG_SHA1 = BIT(23),
0763 SAFEXCEL_ALG_SHA2_256 = BIT(25),
0764 SAFEXCEL_ALG_SHA2_512 = BIT(26),
0765 SAFEXCEL_ALG_XCBC_MAC = BIT(27),
0766 SAFEXCEL_ALG_CBC_MAC_ALL = BIT(29),
0767 SAFEXCEL_ALG_GHASH = BIT(30),
0768 SAFEXCEL_ALG_SHA3 = BIT(31),
0769 };
0770
0771 struct safexcel_register_offsets {
0772 u32 hia_aic;
0773 u32 hia_aic_g;
0774 u32 hia_aic_r;
0775 u32 hia_aic_xdr;
0776 u32 hia_dfe;
0777 u32 hia_dfe_thr;
0778 u32 hia_dse;
0779 u32 hia_dse_thr;
0780 u32 hia_gen_cfg;
0781 u32 pe;
0782 u32 global;
0783 };
0784
0785 enum safexcel_flags {
0786 EIP197_TRC_CACHE = BIT(0),
0787 SAFEXCEL_HW_EIP197 = BIT(1),
0788 EIP197_PE_ARB = BIT(2),
0789 EIP197_ICE = BIT(3),
0790 EIP197_SIMPLE_TRC = BIT(4),
0791 EIP197_OCE = BIT(5),
0792 };
0793
0794 struct safexcel_hwconfig {
0795 enum safexcel_eip_algorithms algo_flags;
0796 int hwver;
0797 int hiaver;
0798 int ppver;
0799 int icever;
0800 int pever;
0801 int ocever;
0802 int psever;
0803 int hwdataw;
0804 int hwcfsize;
0805 int hwrfsize;
0806 int hwnumpes;
0807 int hwnumrings;
0808 int hwnumraic;
0809 };
0810
0811 struct safexcel_crypto_priv {
0812 void __iomem *base;
0813 struct device *dev;
0814 struct clk *clk;
0815 struct clk *reg_clk;
0816 struct safexcel_config config;
0817
0818 enum safexcel_eip_version version;
0819 struct safexcel_register_offsets offsets;
0820 struct safexcel_hwconfig hwconfig;
0821 u32 flags;
0822
0823
0824 struct dma_pool *context_pool;
0825
0826 atomic_t ring_used;
0827
0828 struct safexcel_ring *ring;
0829 };
0830
0831 struct safexcel_context {
0832 int (*send)(struct crypto_async_request *req, int ring,
0833 int *commands, int *results);
0834 int (*handle_result)(struct safexcel_crypto_priv *priv, int ring,
0835 struct crypto_async_request *req, bool *complete,
0836 int *ret);
0837 struct safexcel_context_record *ctxr;
0838 struct safexcel_crypto_priv *priv;
0839 dma_addr_t ctxr_dma;
0840
0841 union {
0842 __le32 le[SHA3_512_BLOCK_SIZE / 4];
0843 __be32 be[SHA3_512_BLOCK_SIZE / 4];
0844 u32 word[SHA3_512_BLOCK_SIZE / 4];
0845 u8 byte[SHA3_512_BLOCK_SIZE];
0846 } ipad, opad;
0847
0848 int ring;
0849 bool needs_inv;
0850 bool exit_inv;
0851 };
0852
0853 #define HASH_CACHE_SIZE SHA512_BLOCK_SIZE
0854
0855 struct safexcel_ahash_export_state {
0856 u64 len;
0857 u64 processed;
0858
0859 u32 digest;
0860
0861 u32 state[SHA512_DIGEST_SIZE / sizeof(u32)];
0862 u8 cache[HASH_CACHE_SIZE];
0863 };
0864
0865
0866
0867
0868
0869
0870 struct safexcel_alg_template {
0871 struct safexcel_crypto_priv *priv;
0872 enum safexcel_alg_type type;
0873 enum safexcel_eip_algorithms algo_mask;
0874 union {
0875 struct skcipher_alg skcipher;
0876 struct aead_alg aead;
0877 struct ahash_alg ahash;
0878 } alg;
0879 };
0880
0881 struct safexcel_inv_result {
0882 struct completion completion;
0883 int error;
0884 };
0885
0886 void safexcel_dequeue(struct safexcel_crypto_priv *priv, int ring);
0887 int safexcel_rdesc_check_errors(struct safexcel_crypto_priv *priv,
0888 void *rdp);
0889 void safexcel_complete(struct safexcel_crypto_priv *priv, int ring);
0890 int safexcel_invalidate_cache(struct crypto_async_request *async,
0891 struct safexcel_crypto_priv *priv,
0892 dma_addr_t ctxr_dma, int ring);
0893 int safexcel_init_ring_descriptors(struct safexcel_crypto_priv *priv,
0894 struct safexcel_desc_ring *cdr,
0895 struct safexcel_desc_ring *rdr);
0896 int safexcel_select_ring(struct safexcel_crypto_priv *priv);
0897 void *safexcel_ring_next_rptr(struct safexcel_crypto_priv *priv,
0898 struct safexcel_desc_ring *ring);
0899 void *safexcel_ring_first_rptr(struct safexcel_crypto_priv *priv, int ring);
0900 void safexcel_ring_rollback_wptr(struct safexcel_crypto_priv *priv,
0901 struct safexcel_desc_ring *ring);
0902 struct safexcel_command_desc *safexcel_add_cdesc(struct safexcel_crypto_priv *priv,
0903 int ring_id,
0904 bool first, bool last,
0905 dma_addr_t data, u32 len,
0906 u32 full_data_len,
0907 dma_addr_t context,
0908 struct safexcel_token **atoken);
0909 struct safexcel_result_desc *safexcel_add_rdesc(struct safexcel_crypto_priv *priv,
0910 int ring_id,
0911 bool first, bool last,
0912 dma_addr_t data, u32 len);
0913 int safexcel_ring_first_rdr_index(struct safexcel_crypto_priv *priv,
0914 int ring);
0915 int safexcel_ring_rdr_rdesc_index(struct safexcel_crypto_priv *priv,
0916 int ring,
0917 struct safexcel_result_desc *rdesc);
0918 void safexcel_rdr_req_set(struct safexcel_crypto_priv *priv,
0919 int ring,
0920 struct safexcel_result_desc *rdesc,
0921 struct crypto_async_request *req);
0922 inline struct crypto_async_request *
0923 safexcel_rdr_req_get(struct safexcel_crypto_priv *priv, int ring);
0924 void safexcel_inv_complete(struct crypto_async_request *req, int error);
0925 int safexcel_hmac_setkey(struct safexcel_context *base, const u8 *key,
0926 unsigned int keylen, const char *alg,
0927 unsigned int state_sz);
0928
0929
0930 extern struct safexcel_alg_template safexcel_alg_ecb_des;
0931 extern struct safexcel_alg_template safexcel_alg_cbc_des;
0932 extern struct safexcel_alg_template safexcel_alg_ecb_des3_ede;
0933 extern struct safexcel_alg_template safexcel_alg_cbc_des3_ede;
0934 extern struct safexcel_alg_template safexcel_alg_ecb_aes;
0935 extern struct safexcel_alg_template safexcel_alg_cbc_aes;
0936 extern struct safexcel_alg_template safexcel_alg_cfb_aes;
0937 extern struct safexcel_alg_template safexcel_alg_ofb_aes;
0938 extern struct safexcel_alg_template safexcel_alg_ctr_aes;
0939 extern struct safexcel_alg_template safexcel_alg_md5;
0940 extern struct safexcel_alg_template safexcel_alg_sha1;
0941 extern struct safexcel_alg_template safexcel_alg_sha224;
0942 extern struct safexcel_alg_template safexcel_alg_sha256;
0943 extern struct safexcel_alg_template safexcel_alg_sha384;
0944 extern struct safexcel_alg_template safexcel_alg_sha512;
0945 extern struct safexcel_alg_template safexcel_alg_hmac_md5;
0946 extern struct safexcel_alg_template safexcel_alg_hmac_sha1;
0947 extern struct safexcel_alg_template safexcel_alg_hmac_sha224;
0948 extern struct safexcel_alg_template safexcel_alg_hmac_sha256;
0949 extern struct safexcel_alg_template safexcel_alg_hmac_sha384;
0950 extern struct safexcel_alg_template safexcel_alg_hmac_sha512;
0951 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha1_cbc_aes;
0952 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha224_cbc_aes;
0953 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha256_cbc_aes;
0954 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha384_cbc_aes;
0955 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha512_cbc_aes;
0956 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha1_cbc_des3_ede;
0957 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha1_ctr_aes;
0958 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha224_ctr_aes;
0959 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha256_ctr_aes;
0960 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha384_ctr_aes;
0961 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha512_ctr_aes;
0962 extern struct safexcel_alg_template safexcel_alg_xts_aes;
0963 extern struct safexcel_alg_template safexcel_alg_gcm;
0964 extern struct safexcel_alg_template safexcel_alg_ccm;
0965 extern struct safexcel_alg_template safexcel_alg_crc32;
0966 extern struct safexcel_alg_template safexcel_alg_cbcmac;
0967 extern struct safexcel_alg_template safexcel_alg_xcbcmac;
0968 extern struct safexcel_alg_template safexcel_alg_cmac;
0969 extern struct safexcel_alg_template safexcel_alg_chacha20;
0970 extern struct safexcel_alg_template safexcel_alg_chachapoly;
0971 extern struct safexcel_alg_template safexcel_alg_chachapoly_esp;
0972 extern struct safexcel_alg_template safexcel_alg_sm3;
0973 extern struct safexcel_alg_template safexcel_alg_hmac_sm3;
0974 extern struct safexcel_alg_template safexcel_alg_ecb_sm4;
0975 extern struct safexcel_alg_template safexcel_alg_cbc_sm4;
0976 extern struct safexcel_alg_template safexcel_alg_ofb_sm4;
0977 extern struct safexcel_alg_template safexcel_alg_cfb_sm4;
0978 extern struct safexcel_alg_template safexcel_alg_ctr_sm4;
0979 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha1_cbc_sm4;
0980 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sm3_cbc_sm4;
0981 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha1_ctr_sm4;
0982 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sm3_ctr_sm4;
0983 extern struct safexcel_alg_template safexcel_alg_sha3_224;
0984 extern struct safexcel_alg_template safexcel_alg_sha3_256;
0985 extern struct safexcel_alg_template safexcel_alg_sha3_384;
0986 extern struct safexcel_alg_template safexcel_alg_sha3_512;
0987 extern struct safexcel_alg_template safexcel_alg_hmac_sha3_224;
0988 extern struct safexcel_alg_template safexcel_alg_hmac_sha3_256;
0989 extern struct safexcel_alg_template safexcel_alg_hmac_sha3_384;
0990 extern struct safexcel_alg_template safexcel_alg_hmac_sha3_512;
0991 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha1_cbc_des;
0992 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha256_cbc_des3_ede;
0993 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha224_cbc_des3_ede;
0994 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha512_cbc_des3_ede;
0995 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha384_cbc_des3_ede;
0996 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha256_cbc_des;
0997 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha224_cbc_des;
0998 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha512_cbc_des;
0999 extern struct safexcel_alg_template safexcel_alg_authenc_hmac_sha384_cbc_des;
1000 extern struct safexcel_alg_template safexcel_alg_rfc4106_gcm;
1001 extern struct safexcel_alg_template safexcel_alg_rfc4543_gcm;
1002 extern struct safexcel_alg_template safexcel_alg_rfc4309_ccm;
1003
1004 #endif