1 // SPDX-License-Identifier: GPL-2.0-only
3 * Copyright (c) 2012-2014, The Linux Foundation. All rights reserved.
7 #include <linux/interrupt.h>
8 #include <linux/types.h>
9 #include <crypto/scatterwalk.h>
10 #include <crypto/sha.h>
18 #define QCE_SECTOR_SIZE 512
20 static inline u32
qce_read(struct qce_device
*qce
, u32 offset
)
22 return readl(qce
->base
+ offset
);
25 static inline void qce_write(struct qce_device
*qce
, u32 offset
, u32 val
)
27 writel(val
, qce
->base
+ offset
);
30 static inline void qce_write_array(struct qce_device
*qce
, u32 offset
,
31 const u32
*val
, unsigned int len
)
35 for (i
= 0; i
< len
; i
++)
36 qce_write(qce
, offset
+ i
* sizeof(u32
), val
[i
]);
40 qce_clear_array(struct qce_device
*qce
, u32 offset
, unsigned int len
)
44 for (i
= 0; i
< len
; i
++)
45 qce_write(qce
, offset
+ i
* sizeof(u32
), 0);
48 static u32
qce_config_reg(struct qce_device
*qce
, int little
)
50 u32 beats
= (qce
->burst_size
>> 3) - 1;
51 u32 pipe_pair
= qce
->pipe_pair_id
;
54 config
= (beats
<< REQ_SIZE_SHIFT
) & REQ_SIZE_MASK
;
55 config
|= BIT(MASK_DOUT_INTR_SHIFT
) | BIT(MASK_DIN_INTR_SHIFT
) |
56 BIT(MASK_OP_DONE_INTR_SHIFT
) | BIT(MASK_ERR_INTR_SHIFT
);
57 config
|= (pipe_pair
<< PIPE_SET_SELECT_SHIFT
) & PIPE_SET_SELECT_MASK
;
58 config
&= ~HIGH_SPD_EN_N_SHIFT
;
61 config
|= BIT(LITTLE_ENDIAN_MODE_SHIFT
);
66 void qce_cpu_to_be32p_array(__be32
*dst
, const u8
*src
, unsigned int len
)
72 n
= len
/ sizeof(u32
);
74 *d
= cpu_to_be32p((const __u32
*) s
);
80 static void qce_setup_config(struct qce_device
*qce
)
84 /* get big endianness */
85 config
= qce_config_reg(qce
, 0);
88 qce_write(qce
, REG_STATUS
, 0);
89 qce_write(qce
, REG_CONFIG
, config
);
92 static inline void qce_crypto_go(struct qce_device
*qce
)
94 qce_write(qce
, REG_GOPROC
, BIT(GO_SHIFT
) | BIT(RESULTS_DUMP_SHIFT
));
97 #ifdef CONFIG_CRYPTO_DEV_QCE_SHA
98 static u32
qce_auth_cfg(unsigned long flags
, u32 key_size
)
102 if (IS_AES(flags
) && (IS_CCM(flags
) || IS_CMAC(flags
)))
103 cfg
|= AUTH_ALG_AES
<< AUTH_ALG_SHIFT
;
105 cfg
|= AUTH_ALG_SHA
<< AUTH_ALG_SHIFT
;
107 if (IS_CCM(flags
) || IS_CMAC(flags
)) {
108 if (key_size
== AES_KEYSIZE_128
)
109 cfg
|= AUTH_KEY_SZ_AES128
<< AUTH_KEY_SIZE_SHIFT
;
110 else if (key_size
== AES_KEYSIZE_256
)
111 cfg
|= AUTH_KEY_SZ_AES256
<< AUTH_KEY_SIZE_SHIFT
;
114 if (IS_SHA1(flags
) || IS_SHA1_HMAC(flags
))
115 cfg
|= AUTH_SIZE_SHA1
<< AUTH_SIZE_SHIFT
;
116 else if (IS_SHA256(flags
) || IS_SHA256_HMAC(flags
))
117 cfg
|= AUTH_SIZE_SHA256
<< AUTH_SIZE_SHIFT
;
118 else if (IS_CMAC(flags
))
119 cfg
|= AUTH_SIZE_ENUM_16_BYTES
<< AUTH_SIZE_SHIFT
;
121 if (IS_SHA1(flags
) || IS_SHA256(flags
))
122 cfg
|= AUTH_MODE_HASH
<< AUTH_MODE_SHIFT
;
123 else if (IS_SHA1_HMAC(flags
) || IS_SHA256_HMAC(flags
) ||
124 IS_CBC(flags
) || IS_CTR(flags
))
125 cfg
|= AUTH_MODE_HMAC
<< AUTH_MODE_SHIFT
;
126 else if (IS_AES(flags
) && IS_CCM(flags
))
127 cfg
|= AUTH_MODE_CCM
<< AUTH_MODE_SHIFT
;
128 else if (IS_AES(flags
) && IS_CMAC(flags
))
129 cfg
|= AUTH_MODE_CMAC
<< AUTH_MODE_SHIFT
;
131 if (IS_SHA(flags
) || IS_SHA_HMAC(flags
))
132 cfg
|= AUTH_POS_BEFORE
<< AUTH_POS_SHIFT
;
135 cfg
|= QCE_MAX_NONCE_WORDS
<< AUTH_NONCE_NUM_WORDS_SHIFT
;
137 if (IS_CBC(flags
) || IS_CTR(flags
) || IS_CCM(flags
) ||
139 cfg
|= BIT(AUTH_LAST_SHIFT
) | BIT(AUTH_FIRST_SHIFT
);
144 static int qce_setup_regs_ahash(struct crypto_async_request
*async_req
,
145 u32 totallen
, u32 offset
)
147 struct ahash_request
*req
= ahash_request_cast(async_req
);
148 struct crypto_ahash
*ahash
= __crypto_ahash_cast(async_req
->tfm
);
149 struct qce_sha_reqctx
*rctx
= ahash_request_ctx(req
);
150 struct qce_alg_template
*tmpl
= to_ahash_tmpl(async_req
->tfm
);
151 struct qce_device
*qce
= tmpl
->qce
;
152 unsigned int digestsize
= crypto_ahash_digestsize(ahash
);
153 unsigned int blocksize
= crypto_tfm_alg_blocksize(async_req
->tfm
);
154 __be32 auth
[SHA256_DIGEST_SIZE
/ sizeof(__be32
)] = {0};
155 __be32 mackey
[QCE_SHA_HMAC_KEY_SIZE
/ sizeof(__be32
)] = {0};
156 u32 auth_cfg
= 0, config
;
157 unsigned int iv_words
;
159 /* if not the last, the size has to be on the block boundary */
160 if (!rctx
->last_blk
&& req
->nbytes
% blocksize
)
163 qce_setup_config(qce
);
165 if (IS_CMAC(rctx
->flags
)) {
166 qce_write(qce
, REG_AUTH_SEG_CFG
, 0);
167 qce_write(qce
, REG_ENCR_SEG_CFG
, 0);
168 qce_write(qce
, REG_ENCR_SEG_SIZE
, 0);
169 qce_clear_array(qce
, REG_AUTH_IV0
, 16);
170 qce_clear_array(qce
, REG_AUTH_KEY0
, 16);
171 qce_clear_array(qce
, REG_AUTH_BYTECNT0
, 4);
173 auth_cfg
= qce_auth_cfg(rctx
->flags
, rctx
->authklen
);
176 if (IS_SHA_HMAC(rctx
->flags
) || IS_CMAC(rctx
->flags
)) {
177 u32 authkey_words
= rctx
->authklen
/ sizeof(u32
);
179 qce_cpu_to_be32p_array(mackey
, rctx
->authkey
, rctx
->authklen
);
180 qce_write_array(qce
, REG_AUTH_KEY0
, (u32
*)mackey
,
184 if (IS_CMAC(rctx
->flags
))
188 memcpy(auth
, rctx
->digest
, digestsize
);
190 qce_cpu_to_be32p_array(auth
, rctx
->digest
, digestsize
);
192 iv_words
= (IS_SHA1(rctx
->flags
) || IS_SHA1_HMAC(rctx
->flags
)) ? 5 : 8;
193 qce_write_array(qce
, REG_AUTH_IV0
, (u32
*)auth
, iv_words
);
196 qce_clear_array(qce
, REG_AUTH_BYTECNT0
, 4);
198 qce_write_array(qce
, REG_AUTH_BYTECNT0
,
199 (u32
*)rctx
->byte_count
, 2);
201 auth_cfg
= qce_auth_cfg(rctx
->flags
, 0);
204 auth_cfg
|= BIT(AUTH_LAST_SHIFT
);
206 auth_cfg
&= ~BIT(AUTH_LAST_SHIFT
);
209 auth_cfg
|= BIT(AUTH_FIRST_SHIFT
);
211 auth_cfg
&= ~BIT(AUTH_FIRST_SHIFT
);
214 qce_write(qce
, REG_AUTH_SEG_CFG
, auth_cfg
);
215 qce_write(qce
, REG_AUTH_SEG_SIZE
, req
->nbytes
);
216 qce_write(qce
, REG_AUTH_SEG_START
, 0);
217 qce_write(qce
, REG_ENCR_SEG_CFG
, 0);
218 qce_write(qce
, REG_SEG_SIZE
, req
->nbytes
);
220 /* get little endianness */
221 config
= qce_config_reg(qce
, 1);
222 qce_write(qce
, REG_CONFIG
, config
);
230 #ifdef CONFIG_CRYPTO_DEV_QCE_SKCIPHER
231 static u32
qce_encr_cfg(unsigned long flags
, u32 aes_key_size
)
236 if (aes_key_size
== AES_KEYSIZE_128
)
237 cfg
|= ENCR_KEY_SZ_AES128
<< ENCR_KEY_SZ_SHIFT
;
238 else if (aes_key_size
== AES_KEYSIZE_256
)
239 cfg
|= ENCR_KEY_SZ_AES256
<< ENCR_KEY_SZ_SHIFT
;
243 cfg
|= ENCR_ALG_AES
<< ENCR_ALG_SHIFT
;
244 else if (IS_DES(flags
) || IS_3DES(flags
))
245 cfg
|= ENCR_ALG_DES
<< ENCR_ALG_SHIFT
;
248 cfg
|= ENCR_KEY_SZ_DES
<< ENCR_KEY_SZ_SHIFT
;
251 cfg
|= ENCR_KEY_SZ_3DES
<< ENCR_KEY_SZ_SHIFT
;
253 switch (flags
& QCE_MODE_MASK
) {
255 cfg
|= ENCR_MODE_ECB
<< ENCR_MODE_SHIFT
;
258 cfg
|= ENCR_MODE_CBC
<< ENCR_MODE_SHIFT
;
261 cfg
|= ENCR_MODE_CTR
<< ENCR_MODE_SHIFT
;
264 cfg
|= ENCR_MODE_XTS
<< ENCR_MODE_SHIFT
;
267 cfg
|= ENCR_MODE_CCM
<< ENCR_MODE_SHIFT
;
268 cfg
|= LAST_CCM_XFR
<< LAST_CCM_SHIFT
;
277 static void qce_xts_swapiv(__be32
*dst
, const u8
*src
, unsigned int ivsize
)
279 u8 swap
[QCE_AES_IV_LENGTH
];
282 if (ivsize
> QCE_AES_IV_LENGTH
)
285 memset(swap
, 0, QCE_AES_IV_LENGTH
);
287 for (i
= (QCE_AES_IV_LENGTH
- ivsize
), j
= ivsize
- 1;
288 i
< QCE_AES_IV_LENGTH
; i
++, j
--)
291 qce_cpu_to_be32p_array(dst
, swap
, QCE_AES_IV_LENGTH
);
294 static void qce_xtskey(struct qce_device
*qce
, const u8
*enckey
,
295 unsigned int enckeylen
, unsigned int cryptlen
)
297 u32 xtskey
[QCE_MAX_CIPHER_KEY_SIZE
/ sizeof(u32
)] = {0};
298 unsigned int xtsklen
= enckeylen
/ (2 * sizeof(u32
));
299 unsigned int xtsdusize
;
301 qce_cpu_to_be32p_array((__be32
*)xtskey
, enckey
+ enckeylen
/ 2,
303 qce_write_array(qce
, REG_ENCR_XTS_KEY0
, xtskey
, xtsklen
);
305 /* xts du size 512B */
306 xtsdusize
= min_t(u32
, QCE_SECTOR_SIZE
, cryptlen
);
307 qce_write(qce
, REG_ENCR_XTS_DU_SIZE
, xtsdusize
);
310 static int qce_setup_regs_skcipher(struct crypto_async_request
*async_req
,
311 u32 totallen
, u32 offset
)
313 struct skcipher_request
*req
= skcipher_request_cast(async_req
);
314 struct qce_cipher_reqctx
*rctx
= skcipher_request_ctx(req
);
315 struct qce_cipher_ctx
*ctx
= crypto_tfm_ctx(async_req
->tfm
);
316 struct qce_alg_template
*tmpl
= to_cipher_tmpl(crypto_skcipher_reqtfm(req
));
317 struct qce_device
*qce
= tmpl
->qce
;
318 __be32 enckey
[QCE_MAX_CIPHER_KEY_SIZE
/ sizeof(__be32
)] = {0};
319 __be32 enciv
[QCE_MAX_IV_SIZE
/ sizeof(__be32
)] = {0};
320 unsigned int enckey_words
, enciv_words
;
322 u32 encr_cfg
= 0, auth_cfg
= 0, config
;
323 unsigned int ivsize
= rctx
->ivsize
;
324 unsigned long flags
= rctx
->flags
;
326 qce_setup_config(qce
);
329 keylen
= ctx
->enc_keylen
/ 2;
331 keylen
= ctx
->enc_keylen
;
333 qce_cpu_to_be32p_array(enckey
, ctx
->enc_key
, keylen
);
334 enckey_words
= keylen
/ sizeof(u32
);
336 qce_write(qce
, REG_AUTH_SEG_CFG
, auth_cfg
);
338 encr_cfg
= qce_encr_cfg(flags
, keylen
);
343 } else if (IS_3DES(flags
)) {
346 } else if (IS_AES(flags
)) {
348 qce_xtskey(qce
, ctx
->enc_key
, ctx
->enc_keylen
,
355 qce_write_array(qce
, REG_ENCR_KEY0
, (u32
*)enckey
, enckey_words
);
357 if (!IS_ECB(flags
)) {
359 qce_xts_swapiv(enciv
, rctx
->iv
, ivsize
);
361 qce_cpu_to_be32p_array(enciv
, rctx
->iv
, ivsize
);
363 qce_write_array(qce
, REG_CNTR0_IV0
, (u32
*)enciv
, enciv_words
);
366 if (IS_ENCRYPT(flags
))
367 encr_cfg
|= BIT(ENCODE_SHIFT
);
369 qce_write(qce
, REG_ENCR_SEG_CFG
, encr_cfg
);
370 qce_write(qce
, REG_ENCR_SEG_SIZE
, rctx
->cryptlen
);
371 qce_write(qce
, REG_ENCR_SEG_START
, offset
& 0xffff);
374 qce_write(qce
, REG_CNTR_MASK
, ~0);
375 qce_write(qce
, REG_CNTR_MASK0
, ~0);
376 qce_write(qce
, REG_CNTR_MASK1
, ~0);
377 qce_write(qce
, REG_CNTR_MASK2
, ~0);
380 qce_write(qce
, REG_SEG_SIZE
, totallen
);
382 /* get little endianness */
383 config
= qce_config_reg(qce
, 1);
384 qce_write(qce
, REG_CONFIG
, config
);
392 int qce_start(struct crypto_async_request
*async_req
, u32 type
, u32 totallen
,
396 #ifdef CONFIG_CRYPTO_DEV_QCE_SKCIPHER
397 case CRYPTO_ALG_TYPE_SKCIPHER
:
398 return qce_setup_regs_skcipher(async_req
, totallen
, offset
);
400 #ifdef CONFIG_CRYPTO_DEV_QCE_SHA
401 case CRYPTO_ALG_TYPE_AHASH
:
402 return qce_setup_regs_ahash(async_req
, totallen
, offset
);
409 #define STATUS_ERRORS \
410 (BIT(SW_ERR_SHIFT) | BIT(AXI_ERR_SHIFT) | BIT(HSD_ERR_SHIFT))
412 int qce_check_status(struct qce_device
*qce
, u32
*status
)
416 *status
= qce_read(qce
, REG_STATUS
);
419 * Don't use result dump status. The operation may not be complete.
420 * Instead, use the status we just read from device. In case, we need to
421 * use result_status from result dump the result_status needs to be byte
422 * swapped, since we set the device to little endian.
424 if (*status
& STATUS_ERRORS
|| !(*status
& BIT(OPERATION_DONE_SHIFT
)))
430 void qce_get_version(struct qce_device
*qce
, u32
*major
, u32
*minor
, u32
*step
)
434 val
= qce_read(qce
, REG_VERSION
);
435 *major
= (val
& CORE_MAJOR_REV_MASK
) >> CORE_MAJOR_REV_SHIFT
;
436 *minor
= (val
& CORE_MINOR_REV_MASK
) >> CORE_MINOR_REV_SHIFT
;
437 *step
= (val
& CORE_STEP_REV_MASK
) >> CORE_STEP_REV_SHIFT
;