Back to home page

OSCL-LXR

 
 

    


0001 /* SPDX-License-Identifier: GPL-2.0 */
0002 /*
0003  * Copyright (C) 2017 Marvell
0004  *
0005  * Antoine Tenart <antoine.tenart@free-electrons.com>
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 /* EIP197 HIA OPTIONS ENCODING */
0037 #define EIP197_HIA_OPT_HAS_PE_ARB       BIT(29)
0038 
0039 /* EIP206 OPTIONS ENCODING */
0040 #define EIP206_OPT_ICE_TYPE(n)          ((n>>8)&3)
0041 #define EIP206_OPT_OCE_TYPE(n)          ((n>>10)&3)
0042 
0043 /* EIP197 OPTIONS ENCODING */
0044 #define EIP197_OPT_HAS_TRC          BIT(31)
0045 
0046 /* Static configuration */
0047 #define EIP197_DEFAULT_RING_SIZE        400
0048 #define EIP197_EMB_TOKENS           4 /* Pad CD to 16 dwords */
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 /* Custom on-stack requests (for invalidation) */
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 /* Xilinx dev board base offsets */
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 /* Helper defines for probe function */
0088 #define EIP197_IRQ_NUMBER(i, is_pci)    (i + is_pci)
0089 
0090 /* Register base offsets */
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 /* EIP197 base offsets */
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 /* EIP97 base offsets */
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 /* CDR/RDR register offsets */
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 /* register offsets */
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 /* EIP197-specific registers, no indirection */
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 /* EIP197_HIA_xDR_DESC_SIZE */
0219 #define EIP197_xDR_DESC_MODE_64BIT      BIT(31)
0220 #define EIP197_CDR_DESC_MODE_ADCP       BIT(30)
0221 
0222 /* EIP197_HIA_xDR_DMA_CFG */
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 /* EIP197_HIA_CDR_THRESH */
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) /* x256 clk cycles */
0234 
0235 /* EIP197_HIA_RDR_THRESH */
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) /* x256 clk cycles */
0239 
0240 /* EIP197_HIA_xDR_PREP_COUNT */
0241 #define EIP197_xDR_PREP_CLR_COUNT       BIT(31)
0242 
0243 /* EIP197_HIA_xDR_PROC_COUNT */
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 /* EIP197_HIA_xDR_STAT */
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 /* EIP197_HIA_OPTIONS */
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 /* EIP197_HIA_AIC_R_ENABLE_CTRL */
0280 #define EIP197_CDR_IRQ(n)           BIT((n) * 2)
0281 #define EIP197_RDR_IRQ(n)           BIT((n) * 2 + 1)
0282 
0283 /* EIP197_HIA_DFE/DSE_CFG */
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 /* EIP197_HIA_DFE/DSE_THR_CTRL */
0296 #define EIP197_DxE_THR_CTRL_EN          BIT(30)
0297 #define EIP197_DxE_THR_CTRL_RESET_PE        BIT(31)
0298 
0299 /* EIP197_PE_ICE_PUE/FPP_CTRL */
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 /* EIP197_HIA_AIC_G_ENABLED_STAT */
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 /* EIP197_HIA_MST_CTRL */
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 /* EIP197_PE_IN_DBUF/TBUF_THRES */
0323 #define EIP197_PE_IN_xBUF_THRES_MIN(n)      ((n) << 8)
0324 #define EIP197_PE_IN_xBUF_THRES_MAX(n)      ((n) << 12)
0325 
0326 /* EIP197_PE_OUT_DBUF_THRES */
0327 #define EIP197_PE_OUT_DBUF_THRES_MIN(n)     ((n) << 0)
0328 #define EIP197_PE_OUT_DBUF_THRES_MAX(n)     ((n) << 4)
0329 
0330 /* EIP197_PE_ICE_SCRATCH_CTRL */
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 /* EIP197_PE_ICE_SCRATCH_RAM */
0337 #define EIP197_NUM_OF_SCRATCH_BLOCKS        32
0338 
0339 /* EIP197_PE_ICE_PUE/FPP_CTRL */
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 /* EIP197_PE_ICE_RAM_CTRL */
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 /* EIP197_PE_EIP96_TOKEN_CTRL */
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 /* EIP197_PE_EIP96_FUNCTION_EN */
0354 #define EIP197_FUNCTION_ALL         0xffffffff
0355 
0356 /* EIP197_PE_EIP96_CONTEXT_CTRL */
0357 #define EIP197_CONTEXT_SIZE(n)          (n)
0358 #define EIP197_ADDRESS_MODE         BIT(8)
0359 #define EIP197_CONTROL_MODE         BIT(9)
0360 
0361 /* EIP197_PE_EIP96_TOKEN_CTRL2 */
0362 #define EIP197_PE_EIP96_TOKEN_CTRL2_CTX_DONE    BIT(3)
0363 
0364 /* EIP197_PE_DEBUG */
0365 #define EIP197_DEBUG_OCE_BYPASS         BIT(1)
0366 
0367 /* EIP197_STRC_CONFIG */
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 /* EIP197_FLUE_CONFIG */
0373 #define EIP197_FLUE_CONFIG_MAGIC        0xc7000004
0374 
0375 /* Context Control */
0376 struct safexcel_context_record {
0377     __le32 control0;
0378     __le32 control1;
0379 
0380     __le32 data[40];
0381 } __packed;
0382 
0383 /* control0 */
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 /* control1 */
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 /* The hash counter given to the engine in the context has a granularity of
0459  * 64 bits.
0460  */
0461 #define EIP197_COUNTER_BLOCK_SIZE       64
0462 
0463 /* EIP197_CS_RAM_CTRL */
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 /* EIP197_TRC_PARAMS */
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 /* EIP197_TRC_FREECHAIN */
0479 #define EIP197_TRC_FREECHAIN_HEAD_PTR(p)    (p)
0480 #define EIP197_TRC_FREECHAIN_TAIL_PTR(p)    ((p) << 16)
0481 
0482 /* EIP197_TRC_PARAMS2 */
0483 #define EIP197_TRC_PARAMS2_HTABLE_PTR(p)    (p)
0484 #define EIP197_TRC_PARAMS2_RC_SZ_SMALL(n)   ((n) << 18)
0485 
0486 /* Cache helpers */
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 /* Result data */
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 /* Basic Result Descriptor format */
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  * The EIP(1)97 only needs to fetch the descriptor part of
0535  * the result descriptor, not the result token part!
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 /* Instructions */
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 /* Processing Engine Control Data  */
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 /* Basic Command Descriptor format */
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  * Internal structures & functions
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     /* write and read pointers */
0660     void *write;
0661     void *shwrite;
0662     void *read;
0663 
0664     /* descriptor element offset */
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     /* command/result rings */
0701     struct safexcel_desc_ring cdr;
0702     struct safexcel_desc_ring rdr;
0703 
0704     /* result ring crypto API request */
0705     struct crypto_async_request **rdr_req;
0706 
0707     /* queue */
0708     struct crypto_queue queue;
0709     spinlock_t queue_lock;
0710 
0711     /* Number of requests in the engine. */
0712     int requests;
0713 
0714     /* The ring is currently handling at least one request */
0715     bool busy;
0716 
0717     /* Store for current requests when bailing out of the dequeueing
0718      * function when no enough resources are available.
0719      */
0720     struct crypto_async_request *req;
0721     struct crypto_async_request *backlog;
0722 
0723     /* irq of this ring */
0724     int irq;
0725 };
0726 
0727 /* EIP integration context flags */
0728 enum safexcel_eip_version {
0729     /* Platform (EIP integration context) specifier */
0730     EIP97IES_MRVL,
0731     EIP197B_MRVL,
0732     EIP197D_MRVL,
0733     EIP197_DEVBRD
0734 };
0735 
0736 /* Priority we use for advertising our algorithms */
0737 #define SAFEXCEL_CRA_PRIORITY       300
0738 
0739 /* SM3 digest result for zero length message */
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 /* EIP algorithm presence flags */
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     /* context DMA pool */
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  * Template structure to describe the algorithms in order to register them.
0867  * It also has the purpose to contain our private structure and is actually
0868  * the only way I know in this framework to avoid having global pointers...
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 /* available algorithms */
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