1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright (C) 2017 Marvell
8 #include <asm/unaligned.h>
9 #include <linux/device.h>
10 #include <linux/dma-mapping.h>
11 #include <linux/dmapool.h>
12 #include <crypto/aead.h>
13 #include <crypto/aes.h>
14 #include <crypto/authenc.h>
15 #include <crypto/chacha.h>
16 #include <crypto/ctr.h>
17 #include <crypto/internal/des.h>
18 #include <crypto/gcm.h>
19 #include <crypto/ghash.h>
20 #include <crypto/poly1305.h>
21 #include <crypto/sha1.h>
22 #include <crypto/sha2.h>
23 #include <crypto/sm3.h>
24 #include <crypto/sm4.h>
25 #include <crypto/xts.h>
26 #include <crypto/skcipher.h>
27 #include <crypto/internal/aead.h>
28 #include <crypto/internal/skcipher.h>
32 enum safexcel_cipher_direction {
37 enum safexcel_cipher_alg {
45 struct safexcel_cipher_ctx {
46 struct safexcel_context base;
47 struct safexcel_crypto_priv *priv;
50 enum safexcel_cipher_alg alg;
51 u8 aead; /* !=0=AEAD, 2=IPSec ESP AEAD, 3=IPsec ESP GMAC */
52 u8 xcm; /* 0=authenc, 1=GCM, 2 reserved for CCM */
60 unsigned int key_len, xts;
62 /* All the below is AEAD specific */
66 struct crypto_aead *fback;
69 struct safexcel_cipher_req {
70 enum safexcel_cipher_direction direction;
71 /* Number of result descriptors associated to the request */
77 static int safexcel_skcipher_iv(struct safexcel_cipher_ctx *ctx, u8 *iv,
78 struct safexcel_command_desc *cdesc)
80 if (ctx->mode == CONTEXT_CONTROL_CRYPTO_MODE_CTR_LOAD) {
81 cdesc->control_data.options |= EIP197_OPTION_4_TOKEN_IV_CMD;
83 cdesc->control_data.token[0] = ctx->nonce;
85 memcpy(&cdesc->control_data.token[1], iv, 8);
86 /* 32 bit counter, start at 0 or 1 (big endian!) */
87 cdesc->control_data.token[3] =
88 (__force u32)cpu_to_be32(ctx->ctrinit);
91 if (ctx->alg == SAFEXCEL_CHACHA20) {
92 cdesc->control_data.options |= EIP197_OPTION_4_TOKEN_IV_CMD;
93 /* 96 bit nonce part */
94 memcpy(&cdesc->control_data.token[0], &iv[4], 12);
96 cdesc->control_data.token[3] = *(u32 *)iv;
100 cdesc->control_data.options |= ctx->ivmask;
101 memcpy(cdesc->control_data.token, iv, ctx->blocksz);
102 return ctx->blocksz / sizeof(u32);
105 static void safexcel_skcipher_token(struct safexcel_cipher_ctx *ctx, u8 *iv,
106 struct safexcel_command_desc *cdesc,
107 struct safexcel_token *atoken,
110 struct safexcel_token *token;
113 ivlen = safexcel_skcipher_iv(ctx, iv, cdesc);
115 /* No space in cdesc, instruction moves to atoken */
116 cdesc->additional_cdata_size = 1;
119 /* Everything fits in cdesc */
120 token = (struct safexcel_token *)(cdesc->control_data.token + 2);
121 /* Need to pad with NOP */
122 eip197_noop_token(&token[1]);
125 token->opcode = EIP197_TOKEN_OPCODE_DIRECTION;
126 token->packet_length = length;
127 token->stat = EIP197_TOKEN_STAT_LAST_PACKET |
128 EIP197_TOKEN_STAT_LAST_HASH;
129 token->instructions = EIP197_TOKEN_INS_LAST |
130 EIP197_TOKEN_INS_TYPE_CRYPTO |
131 EIP197_TOKEN_INS_TYPE_OUTPUT;
134 static void safexcel_aead_iv(struct safexcel_cipher_ctx *ctx, u8 *iv,
135 struct safexcel_command_desc *cdesc)
137 if (ctx->mode == CONTEXT_CONTROL_CRYPTO_MODE_CTR_LOAD ||
138 ctx->aead & EIP197_AEAD_TYPE_IPSEC_ESP) { /* _ESP and _ESP_GMAC */
140 cdesc->control_data.token[0] = ctx->nonce;
142 memcpy(&cdesc->control_data.token[1], iv, 8);
143 /* 32 bit counter, start at 0 or 1 (big endian!) */
144 cdesc->control_data.token[3] =
145 (__force u32)cpu_to_be32(ctx->ctrinit);
148 if (ctx->xcm == EIP197_XCM_MODE_GCM || ctx->alg == SAFEXCEL_CHACHA20) {
150 memcpy(&cdesc->control_data.token[0], iv, 12);
151 /* 32 bit counter, start at 0 or 1 (big endian!) */
152 cdesc->control_data.token[3] =
153 (__force u32)cpu_to_be32(ctx->ctrinit);
157 memcpy(cdesc->control_data.token, iv, ctx->blocksz);
160 static void safexcel_aead_token(struct safexcel_cipher_ctx *ctx, u8 *iv,
161 struct safexcel_command_desc *cdesc,
162 struct safexcel_token *atoken,
163 enum safexcel_cipher_direction direction,
164 u32 cryptlen, u32 assoclen, u32 digestsize)
166 struct safexcel_token *aadref;
167 int atoksize = 2; /* Start with minimum size */
168 int assocadj = assoclen - ctx->aadskip, aadalign;
170 /* Always 4 dwords of embedded IV for AEAD modes */
171 cdesc->control_data.options |= EIP197_OPTION_4_TOKEN_IV_CMD;
173 if (direction == SAFEXCEL_DECRYPT)
174 cryptlen -= digestsize;
176 if (unlikely(ctx->xcm == EIP197_XCM_MODE_CCM)) {
177 /* Construct IV block B0 for the CBC-MAC */
178 u8 *final_iv = (u8 *)cdesc->control_data.token;
179 u8 *cbcmaciv = (u8 *)&atoken[1];
180 __le32 *aadlen = (__le32 *)&atoken[5];
182 if (ctx->aead == EIP197_AEAD_TYPE_IPSEC_ESP) {
184 cdesc->control_data.token[0] = ctx->nonce;
185 /* Fixup flags byte */
186 *(__le32 *)cbcmaciv =
187 cpu_to_le32(ctx->nonce |
188 ((assocadj > 0) << 6) |
189 ((digestsize - 2) << 2));
191 memcpy(&cdesc->control_data.token[1], iv, 8);
192 memcpy(cbcmaciv + 4, iv, 8);
193 /* Start counter at 0 */
194 cdesc->control_data.token[3] = 0;
196 *(__be32 *)(cbcmaciv + 12) = cpu_to_be32(cryptlen);
198 /* Variable length IV part */
199 memcpy(final_iv, iv, 15 - iv[0]);
200 memcpy(cbcmaciv, iv, 15 - iv[0]);
201 /* Start variable length counter at 0 */
202 memset(final_iv + 15 - iv[0], 0, iv[0] + 1);
203 memset(cbcmaciv + 15 - iv[0], 0, iv[0] - 1);
204 /* fixup flags byte */
205 cbcmaciv[0] |= ((assocadj > 0) << 6) |
206 ((digestsize - 2) << 2);
207 /* insert lower 2 bytes of message length */
208 cbcmaciv[14] = cryptlen >> 8;
209 cbcmaciv[15] = cryptlen & 255;
212 atoken->opcode = EIP197_TOKEN_OPCODE_INSERT;
213 atoken->packet_length = AES_BLOCK_SIZE +
214 ((assocadj > 0) << 1);
216 atoken->instructions = EIP197_TOKEN_INS_ORIGIN_TOKEN |
217 EIP197_TOKEN_INS_TYPE_HASH;
219 if (likely(assocadj)) {
220 *aadlen = cpu_to_le32((assocadj >> 8) |
221 (assocadj & 255) << 8);
229 /* Process AAD data */
231 atoken->opcode = EIP197_TOKEN_OPCODE_DIRECTION;
232 atoken->packet_length = assocadj;
234 atoken->instructions = EIP197_TOKEN_INS_TYPE_HASH;
237 /* For CCM only, align AAD data towards hash engine */
238 atoken->opcode = EIP197_TOKEN_OPCODE_INSERT;
239 aadalign = (assocadj + 2) & 15;
240 atoken->packet_length = assocadj && aadalign ?
243 if (likely(cryptlen)) {
245 atoken->instructions = EIP197_TOKEN_INS_TYPE_HASH;
247 atoken->stat = EIP197_TOKEN_STAT_LAST_HASH;
248 atoken->instructions = EIP197_TOKEN_INS_LAST |
249 EIP197_TOKEN_INS_TYPE_HASH;
252 safexcel_aead_iv(ctx, iv, cdesc);
254 /* Process AAD data */
256 atoken->opcode = EIP197_TOKEN_OPCODE_DIRECTION;
257 atoken->packet_length = assocadj;
258 atoken->stat = EIP197_TOKEN_STAT_LAST_HASH;
259 atoken->instructions = EIP197_TOKEN_INS_LAST |
260 EIP197_TOKEN_INS_TYPE_HASH;
264 if (ctx->aead == EIP197_AEAD_TYPE_IPSEC_ESP) {
265 /* For ESP mode (and not GMAC), skip over the IV */
266 atoken->opcode = EIP197_TOKEN_OPCODE_DIRECTION;
267 atoken->packet_length = EIP197_AEAD_IPSEC_IV_SIZE;
269 atoken->instructions = 0;
272 } else if (unlikely(ctx->alg == SAFEXCEL_CHACHA20 &&
273 direction == SAFEXCEL_DECRYPT)) {
274 /* Poly-chacha decryption needs a dummy NOP here ... */
275 atoken->opcode = EIP197_TOKEN_OPCODE_INSERT;
276 atoken->packet_length = 16; /* According to Op Manual */
278 atoken->instructions = 0;
284 /* For GCM and CCM, obtain enc(Y0) */
285 atoken->opcode = EIP197_TOKEN_OPCODE_INSERT_REMRES;
286 atoken->packet_length = 0;
288 atoken->instructions = AES_BLOCK_SIZE;
291 atoken->opcode = EIP197_TOKEN_OPCODE_INSERT;
292 atoken->packet_length = AES_BLOCK_SIZE;
294 atoken->instructions = EIP197_TOKEN_INS_TYPE_OUTPUT |
295 EIP197_TOKEN_INS_TYPE_CRYPTO;
300 if (likely(cryptlen || ctx->alg == SAFEXCEL_CHACHA20)) {
301 /* Fixup stat field for AAD direction instruction */
304 /* Process crypto data */
305 atoken->opcode = EIP197_TOKEN_OPCODE_DIRECTION;
306 atoken->packet_length = cryptlen;
308 if (unlikely(ctx->aead == EIP197_AEAD_TYPE_IPSEC_ESP_GMAC)) {
309 /* Fixup instruction field for AAD dir instruction */
310 aadref->instructions = EIP197_TOKEN_INS_TYPE_HASH;
312 /* Do not send to crypt engine in case of GMAC */
313 atoken->instructions = EIP197_TOKEN_INS_LAST |
314 EIP197_TOKEN_INS_TYPE_HASH |
315 EIP197_TOKEN_INS_TYPE_OUTPUT;
317 atoken->instructions = EIP197_TOKEN_INS_LAST |
318 EIP197_TOKEN_INS_TYPE_CRYPTO |
319 EIP197_TOKEN_INS_TYPE_HASH |
320 EIP197_TOKEN_INS_TYPE_OUTPUT;
324 if (unlikely(ctx->xcm == EIP197_XCM_MODE_CCM && cryptlen)) {
326 /* For CCM only, pad crypto data to the hash engine */
329 atoken->opcode = EIP197_TOKEN_OPCODE_INSERT;
330 atoken->packet_length = 16 - cryptlen;
331 atoken->stat = EIP197_TOKEN_STAT_LAST_HASH;
332 atoken->instructions = EIP197_TOKEN_INS_TYPE_HASH;
334 atoken->stat = EIP197_TOKEN_STAT_LAST_HASH;
340 if (direction == SAFEXCEL_ENCRYPT) {
342 atoken->opcode = EIP197_TOKEN_OPCODE_INSERT;
343 atoken->packet_length = digestsize;
344 atoken->stat = EIP197_TOKEN_STAT_LAST_HASH |
345 EIP197_TOKEN_STAT_LAST_PACKET;
346 atoken->instructions = EIP197_TOKEN_INS_TYPE_OUTPUT |
347 EIP197_TOKEN_INS_INSERT_HASH_DIGEST;
350 atoken->opcode = EIP197_TOKEN_OPCODE_RETRIEVE;
351 atoken->packet_length = digestsize;
352 atoken->stat = EIP197_TOKEN_STAT_LAST_HASH |
353 EIP197_TOKEN_STAT_LAST_PACKET;
354 atoken->instructions = EIP197_TOKEN_INS_INSERT_HASH_DIGEST;
359 atoken->opcode = EIP197_TOKEN_OPCODE_VERIFY;
360 atoken->packet_length = digestsize |
361 EIP197_TOKEN_HASH_RESULT_VERIFY;
362 atoken->stat = EIP197_TOKEN_STAT_LAST_HASH |
363 EIP197_TOKEN_STAT_LAST_PACKET;
364 atoken->instructions = EIP197_TOKEN_INS_TYPE_OUTPUT;
367 /* Fixup length of the token in the command descriptor */
368 cdesc->additional_cdata_size = atoksize;
371 static int safexcel_skcipher_aes_setkey(struct crypto_skcipher *ctfm,
372 const u8 *key, unsigned int len)
374 struct crypto_tfm *tfm = crypto_skcipher_tfm(ctfm);
375 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
376 struct safexcel_crypto_priv *priv = ctx->base.priv;
377 struct crypto_aes_ctx aes;
380 ret = aes_expandkey(&aes, key, len);
384 if (priv->flags & EIP197_TRC_CACHE && ctx->base.ctxr_dma) {
385 for (i = 0; i < len / sizeof(u32); i++) {
386 if (le32_to_cpu(ctx->key[i]) != aes.key_enc[i]) {
387 ctx->base.needs_inv = true;
393 for (i = 0; i < len / sizeof(u32); i++)
394 ctx->key[i] = cpu_to_le32(aes.key_enc[i]);
398 memzero_explicit(&aes, sizeof(aes));
402 static int safexcel_aead_setkey(struct crypto_aead *ctfm, const u8 *key,
405 struct crypto_tfm *tfm = crypto_aead_tfm(ctfm);
406 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
407 struct safexcel_crypto_priv *priv = ctx->base.priv;
408 struct crypto_authenc_keys keys;
409 struct crypto_aes_ctx aes;
410 int err = -EINVAL, i;
413 if (unlikely(crypto_authenc_extractkeys(&keys, key, len)))
416 if (ctx->mode == CONTEXT_CONTROL_CRYPTO_MODE_CTR_LOAD) {
417 /* Must have at least space for the nonce here */
418 if (unlikely(keys.enckeylen < CTR_RFC3686_NONCE_SIZE))
420 /* last 4 bytes of key are the nonce! */
421 ctx->nonce = *(u32 *)(keys.enckey + keys.enckeylen -
422 CTR_RFC3686_NONCE_SIZE);
423 /* exclude the nonce here */
424 keys.enckeylen -= CTR_RFC3686_NONCE_SIZE;
430 err = verify_aead_des_key(ctfm, keys.enckey, keys.enckeylen);
435 err = verify_aead_des3_key(ctfm, keys.enckey, keys.enckeylen);
440 err = aes_expandkey(&aes, keys.enckey, keys.enckeylen);
445 if (unlikely(keys.enckeylen != SM4_KEY_SIZE))
449 dev_err(priv->dev, "aead: unsupported cipher algorithm\n");
453 if (priv->flags & EIP197_TRC_CACHE && ctx->base.ctxr_dma) {
454 for (i = 0; i < keys.enckeylen / sizeof(u32); i++) {
455 if (le32_to_cpu(ctx->key[i]) !=
456 ((u32 *)keys.enckey)[i]) {
457 ctx->base.needs_inv = true;
464 switch (ctx->hash_alg) {
465 case CONTEXT_CONTROL_CRYPTO_ALG_SHA1:
466 alg = "safexcel-sha1";
468 case CONTEXT_CONTROL_CRYPTO_ALG_SHA224:
469 alg = "safexcel-sha224";
471 case CONTEXT_CONTROL_CRYPTO_ALG_SHA256:
472 alg = "safexcel-sha256";
474 case CONTEXT_CONTROL_CRYPTO_ALG_SHA384:
475 alg = "safexcel-sha384";
477 case CONTEXT_CONTROL_CRYPTO_ALG_SHA512:
478 alg = "safexcel-sha512";
480 case CONTEXT_CONTROL_CRYPTO_ALG_SM3:
481 alg = "safexcel-sm3";
484 dev_err(priv->dev, "aead: unsupported hash algorithm\n");
488 if (safexcel_hmac_setkey(&ctx->base, keys.authkey, keys.authkeylen,
492 /* Now copy the keys into the context */
493 for (i = 0; i < keys.enckeylen / sizeof(u32); i++)
494 ctx->key[i] = cpu_to_le32(((u32 *)keys.enckey)[i]);
495 ctx->key_len = keys.enckeylen;
497 memzero_explicit(&keys, sizeof(keys));
501 memzero_explicit(&keys, sizeof(keys));
505 static int safexcel_context_control(struct safexcel_cipher_ctx *ctx,
506 struct crypto_async_request *async,
507 struct safexcel_cipher_req *sreq,
508 struct safexcel_command_desc *cdesc)
510 struct safexcel_crypto_priv *priv = ctx->base.priv;
511 int ctrl_size = ctx->key_len / sizeof(u32);
513 cdesc->control_data.control1 = ctx->mode;
516 /* Take in account the ipad+opad digests */
518 ctrl_size += ctx->state_sz / sizeof(u32);
519 cdesc->control_data.control0 =
520 CONTEXT_CONTROL_KEY_EN |
521 CONTEXT_CONTROL_DIGEST_XCM |
523 CONTEXT_CONTROL_SIZE(ctrl_size);
524 } else if (ctx->alg == SAFEXCEL_CHACHA20) {
525 /* Chacha20-Poly1305 */
526 cdesc->control_data.control0 =
527 CONTEXT_CONTROL_KEY_EN |
528 CONTEXT_CONTROL_CRYPTO_ALG_CHACHA20 |
529 (sreq->direction == SAFEXCEL_ENCRYPT ?
530 CONTEXT_CONTROL_TYPE_ENCRYPT_HASH_OUT :
531 CONTEXT_CONTROL_TYPE_HASH_DECRYPT_IN) |
533 CONTEXT_CONTROL_SIZE(ctrl_size);
536 ctrl_size += ctx->state_sz / sizeof(u32) * 2;
537 cdesc->control_data.control0 =
538 CONTEXT_CONTROL_KEY_EN |
539 CONTEXT_CONTROL_DIGEST_HMAC |
541 CONTEXT_CONTROL_SIZE(ctrl_size);
544 if (sreq->direction == SAFEXCEL_ENCRYPT &&
545 (ctx->xcm == EIP197_XCM_MODE_CCM ||
546 ctx->aead == EIP197_AEAD_TYPE_IPSEC_ESP_GMAC))
547 cdesc->control_data.control0 |=
548 CONTEXT_CONTROL_TYPE_HASH_ENCRYPT_OUT;
549 else if (sreq->direction == SAFEXCEL_ENCRYPT)
550 cdesc->control_data.control0 |=
551 CONTEXT_CONTROL_TYPE_ENCRYPT_HASH_OUT;
552 else if (ctx->xcm == EIP197_XCM_MODE_CCM)
553 cdesc->control_data.control0 |=
554 CONTEXT_CONTROL_TYPE_DECRYPT_HASH_IN;
556 cdesc->control_data.control0 |=
557 CONTEXT_CONTROL_TYPE_HASH_DECRYPT_IN;
559 if (sreq->direction == SAFEXCEL_ENCRYPT)
560 cdesc->control_data.control0 =
561 CONTEXT_CONTROL_TYPE_CRYPTO_OUT |
562 CONTEXT_CONTROL_KEY_EN |
563 CONTEXT_CONTROL_SIZE(ctrl_size);
565 cdesc->control_data.control0 =
566 CONTEXT_CONTROL_TYPE_CRYPTO_IN |
567 CONTEXT_CONTROL_KEY_EN |
568 CONTEXT_CONTROL_SIZE(ctrl_size);
571 if (ctx->alg == SAFEXCEL_DES) {
572 cdesc->control_data.control0 |=
573 CONTEXT_CONTROL_CRYPTO_ALG_DES;
574 } else if (ctx->alg == SAFEXCEL_3DES) {
575 cdesc->control_data.control0 |=
576 CONTEXT_CONTROL_CRYPTO_ALG_3DES;
577 } else if (ctx->alg == SAFEXCEL_AES) {
578 switch (ctx->key_len >> ctx->xts) {
579 case AES_KEYSIZE_128:
580 cdesc->control_data.control0 |=
581 CONTEXT_CONTROL_CRYPTO_ALG_AES128;
583 case AES_KEYSIZE_192:
584 cdesc->control_data.control0 |=
585 CONTEXT_CONTROL_CRYPTO_ALG_AES192;
587 case AES_KEYSIZE_256:
588 cdesc->control_data.control0 |=
589 CONTEXT_CONTROL_CRYPTO_ALG_AES256;
592 dev_err(priv->dev, "aes keysize not supported: %u\n",
593 ctx->key_len >> ctx->xts);
596 } else if (ctx->alg == SAFEXCEL_CHACHA20) {
597 cdesc->control_data.control0 |=
598 CONTEXT_CONTROL_CRYPTO_ALG_CHACHA20;
599 } else if (ctx->alg == SAFEXCEL_SM4) {
600 cdesc->control_data.control0 |=
601 CONTEXT_CONTROL_CRYPTO_ALG_SM4;
607 static int safexcel_handle_req_result(struct safexcel_crypto_priv *priv, int ring,
608 struct crypto_async_request *async,
609 struct scatterlist *src,
610 struct scatterlist *dst,
611 unsigned int cryptlen,
612 struct safexcel_cipher_req *sreq,
613 bool *should_complete, int *ret)
615 struct skcipher_request *areq = skcipher_request_cast(async);
616 struct crypto_skcipher *skcipher = crypto_skcipher_reqtfm(areq);
617 struct safexcel_cipher_ctx *ctx = crypto_skcipher_ctx(skcipher);
618 struct safexcel_result_desc *rdesc;
623 if (unlikely(!sreq->rdescs))
626 while (sreq->rdescs--) {
627 rdesc = safexcel_ring_next_rptr(priv, &priv->ring[ring].rdr);
630 "cipher: result: could not retrieve the result descriptor\n");
631 *ret = PTR_ERR(rdesc);
636 *ret = safexcel_rdesc_check_errors(priv, rdesc);
641 safexcel_complete(priv, ring);
644 if (sreq->nr_src > 0)
645 dma_unmap_sg(priv->dev, src, sreq->nr_src,
648 if (sreq->nr_src > 0)
649 dma_unmap_sg(priv->dev, src, sreq->nr_src,
651 if (sreq->nr_dst > 0)
652 dma_unmap_sg(priv->dev, dst, sreq->nr_dst,
657 * Update IV in req from last crypto output word for CBC modes
659 if ((!ctx->aead) && (ctx->mode == CONTEXT_CONTROL_CRYPTO_MODE_CBC) &&
660 (sreq->direction == SAFEXCEL_ENCRYPT)) {
661 /* For encrypt take the last output word */
662 sg_pcopy_to_buffer(dst, sreq->nr_dst, areq->iv,
663 crypto_skcipher_ivsize(skcipher),
665 crypto_skcipher_ivsize(skcipher)));
668 *should_complete = true;
673 static int safexcel_send_req(struct crypto_async_request *base, int ring,
674 struct safexcel_cipher_req *sreq,
675 struct scatterlist *src, struct scatterlist *dst,
676 unsigned int cryptlen, unsigned int assoclen,
677 unsigned int digestsize, u8 *iv, int *commands,
680 struct skcipher_request *areq = skcipher_request_cast(base);
681 struct crypto_skcipher *skcipher = crypto_skcipher_reqtfm(areq);
682 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(base->tfm);
683 struct safexcel_crypto_priv *priv = ctx->base.priv;
684 struct safexcel_command_desc *cdesc;
685 struct safexcel_command_desc *first_cdesc = NULL;
686 struct safexcel_result_desc *rdesc, *first_rdesc = NULL;
687 struct scatterlist *sg;
689 unsigned int totlen_src = cryptlen + assoclen;
690 unsigned int totlen_dst = totlen_src;
691 struct safexcel_token *atoken;
692 int n_cdesc = 0, n_rdesc = 0;
693 int queued, i, ret = 0;
696 sreq->nr_src = sg_nents_for_len(src, totlen_src);
700 * AEAD has auth tag appended to output for encrypt and
701 * removed from the output for decrypt!
703 if (sreq->direction == SAFEXCEL_DECRYPT)
704 totlen_dst -= digestsize;
706 totlen_dst += digestsize;
708 memcpy(ctx->base.ctxr->data + ctx->key_len / sizeof(u32),
709 &ctx->base.ipad, ctx->state_sz);
711 memcpy(ctx->base.ctxr->data + (ctx->key_len +
712 ctx->state_sz) / sizeof(u32), &ctx->base.opad,
714 } else if ((ctx->mode == CONTEXT_CONTROL_CRYPTO_MODE_CBC) &&
715 (sreq->direction == SAFEXCEL_DECRYPT)) {
717 * Save IV from last crypto input word for CBC modes in decrypt
718 * direction. Need to do this first in case of inplace operation
719 * as it will be overwritten.
721 sg_pcopy_to_buffer(src, sreq->nr_src, areq->iv,
722 crypto_skcipher_ivsize(skcipher),
724 crypto_skcipher_ivsize(skcipher)));
727 sreq->nr_dst = sg_nents_for_len(dst, totlen_dst);
730 * Remember actual input length, source buffer length may be
731 * updated in case of inline operation below.
737 sreq->nr_src = max(sreq->nr_src, sreq->nr_dst);
738 sreq->nr_dst = sreq->nr_src;
739 if (unlikely((totlen_src || totlen_dst) &&
740 (sreq->nr_src <= 0))) {
741 dev_err(priv->dev, "In-place buffer not large enough (need %d bytes)!",
742 max(totlen_src, totlen_dst));
745 if (sreq->nr_src > 0)
746 dma_map_sg(priv->dev, src, sreq->nr_src,
749 if (unlikely(totlen_src && (sreq->nr_src <= 0))) {
750 dev_err(priv->dev, "Source buffer not large enough (need %d bytes)!",
755 if (sreq->nr_src > 0)
756 dma_map_sg(priv->dev, src, sreq->nr_src, DMA_TO_DEVICE);
758 if (unlikely(totlen_dst && (sreq->nr_dst <= 0))) {
759 dev_err(priv->dev, "Dest buffer not large enough (need %d bytes)!",
765 if (sreq->nr_dst > 0)
766 dma_map_sg(priv->dev, dst, sreq->nr_dst,
770 memcpy(ctx->base.ctxr->data, ctx->key, ctx->key_len);
774 * The EIP97 cannot deal with zero length input packets!
775 * So stuff a dummy command descriptor indicating a 1 byte
776 * (dummy) input packet, using the context record as source.
778 first_cdesc = safexcel_add_cdesc(priv, ring,
779 1, 1, ctx->base.ctxr_dma,
780 1, 1, ctx->base.ctxr_dma,
782 if (IS_ERR(first_cdesc)) {
783 /* No space left in the command descriptor ring */
784 ret = PTR_ERR(first_cdesc);
791 /* command descriptors */
792 for_each_sg(src, sg, sreq->nr_src, i) {
793 int len = sg_dma_len(sg);
795 /* Do not overflow the request */
799 cdesc = safexcel_add_cdesc(priv, ring, !n_cdesc,
801 sg_dma_address(sg), len, totlen,
802 ctx->base.ctxr_dma, &atoken);
804 /* No space left in the command descriptor ring */
805 ret = PTR_ERR(cdesc);
818 /* Add context control words and token to first command descriptor */
819 safexcel_context_control(ctx, base, sreq, first_cdesc);
821 safexcel_aead_token(ctx, iv, first_cdesc, atoken,
822 sreq->direction, cryptlen,
823 assoclen, digestsize);
825 safexcel_skcipher_token(ctx, iv, first_cdesc, atoken,
828 /* result descriptors */
829 for_each_sg(dst, sg, sreq->nr_dst, i) {
830 bool last = (i == sreq->nr_dst - 1);
831 u32 len = sg_dma_len(sg);
833 /* only allow the part of the buffer we know we need */
834 if (len > totlen_dst)
840 /* skip over AAD space in buffer - not written */
842 if (assoclen >= len) {
846 rdesc = safexcel_add_rdesc(priv, ring, first, last,
852 rdesc = safexcel_add_rdesc(priv, ring, first, last,
857 /* No space left in the result descriptor ring */
858 ret = PTR_ERR(rdesc);
868 if (unlikely(first)) {
870 * Special case: AEAD decrypt with only AAD data.
871 * In this case there is NO output data from the engine,
872 * but the engine still needs a result descriptor!
873 * Create a dummy one just for catching the result token.
875 rdesc = safexcel_add_rdesc(priv, ring, true, true, 0, 0);
877 /* No space left in the result descriptor ring */
878 ret = PTR_ERR(rdesc);
885 safexcel_rdr_req_set(priv, ring, first_rdesc, base);
892 for (i = 0; i < n_rdesc; i++)
893 safexcel_ring_rollback_wptr(priv, &priv->ring[ring].rdr);
895 for (i = 0; i < n_cdesc; i++)
896 safexcel_ring_rollback_wptr(priv, &priv->ring[ring].cdr);
899 if (sreq->nr_src > 0)
900 dma_unmap_sg(priv->dev, src, sreq->nr_src,
903 if (sreq->nr_src > 0)
904 dma_unmap_sg(priv->dev, src, sreq->nr_src,
906 if (sreq->nr_dst > 0)
907 dma_unmap_sg(priv->dev, dst, sreq->nr_dst,
914 static int safexcel_handle_inv_result(struct safexcel_crypto_priv *priv,
916 struct crypto_async_request *base,
917 struct safexcel_cipher_req *sreq,
918 bool *should_complete, int *ret)
920 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(base->tfm);
921 struct safexcel_result_desc *rdesc;
922 int ndesc = 0, enq_ret;
926 if (unlikely(!sreq->rdescs))
929 while (sreq->rdescs--) {
930 rdesc = safexcel_ring_next_rptr(priv, &priv->ring[ring].rdr);
933 "cipher: invalidate: could not retrieve the result descriptor\n");
934 *ret = PTR_ERR(rdesc);
939 *ret = safexcel_rdesc_check_errors(priv, rdesc);
944 safexcel_complete(priv, ring);
946 if (ctx->base.exit_inv) {
947 dma_pool_free(priv->context_pool, ctx->base.ctxr,
950 *should_complete = true;
955 ring = safexcel_select_ring(priv);
956 ctx->base.ring = ring;
958 spin_lock_bh(&priv->ring[ring].queue_lock);
959 enq_ret = crypto_enqueue_request(&priv->ring[ring].queue, base);
960 spin_unlock_bh(&priv->ring[ring].queue_lock);
962 if (enq_ret != -EINPROGRESS)
965 queue_work(priv->ring[ring].workqueue,
966 &priv->ring[ring].work_data.work);
968 *should_complete = false;
973 static int safexcel_skcipher_handle_result(struct safexcel_crypto_priv *priv,
975 struct crypto_async_request *async,
976 bool *should_complete, int *ret)
978 struct skcipher_request *req = skcipher_request_cast(async);
979 struct safexcel_cipher_req *sreq = skcipher_request_ctx(req);
982 if (sreq->needs_inv) {
983 sreq->needs_inv = false;
984 err = safexcel_handle_inv_result(priv, ring, async, sreq,
985 should_complete, ret);
987 err = safexcel_handle_req_result(priv, ring, async, req->src,
988 req->dst, req->cryptlen, sreq,
989 should_complete, ret);
995 static int safexcel_aead_handle_result(struct safexcel_crypto_priv *priv,
997 struct crypto_async_request *async,
998 bool *should_complete, int *ret)
1000 struct aead_request *req = aead_request_cast(async);
1001 struct crypto_aead *tfm = crypto_aead_reqtfm(req);
1002 struct safexcel_cipher_req *sreq = aead_request_ctx(req);
1005 if (sreq->needs_inv) {
1006 sreq->needs_inv = false;
1007 err = safexcel_handle_inv_result(priv, ring, async, sreq,
1008 should_complete, ret);
1010 err = safexcel_handle_req_result(priv, ring, async, req->src,
1012 req->cryptlen + crypto_aead_authsize(tfm),
1013 sreq, should_complete, ret);
1019 static int safexcel_cipher_send_inv(struct crypto_async_request *base,
1020 int ring, int *commands, int *results)
1022 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(base->tfm);
1023 struct safexcel_crypto_priv *priv = ctx->base.priv;
1026 ret = safexcel_invalidate_cache(base, priv, ctx->base.ctxr_dma, ring);
1036 static int safexcel_skcipher_send(struct crypto_async_request *async, int ring,
1037 int *commands, int *results)
1039 struct skcipher_request *req = skcipher_request_cast(async);
1040 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(req->base.tfm);
1041 struct safexcel_cipher_req *sreq = skcipher_request_ctx(req);
1042 struct safexcel_crypto_priv *priv = ctx->base.priv;
1045 BUG_ON(!(priv->flags & EIP197_TRC_CACHE) && sreq->needs_inv);
1047 if (sreq->needs_inv) {
1048 ret = safexcel_cipher_send_inv(async, ring, commands, results);
1050 struct crypto_skcipher *skcipher = crypto_skcipher_reqtfm(req);
1051 u8 input_iv[AES_BLOCK_SIZE];
1054 * Save input IV in case of CBC decrypt mode
1055 * Will be overwritten with output IV prior to use!
1057 memcpy(input_iv, req->iv, crypto_skcipher_ivsize(skcipher));
1059 ret = safexcel_send_req(async, ring, sreq, req->src,
1060 req->dst, req->cryptlen, 0, 0, input_iv,
1064 sreq->rdescs = *results;
1068 static int safexcel_aead_send(struct crypto_async_request *async, int ring,
1069 int *commands, int *results)
1071 struct aead_request *req = aead_request_cast(async);
1072 struct crypto_aead *tfm = crypto_aead_reqtfm(req);
1073 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(req->base.tfm);
1074 struct safexcel_cipher_req *sreq = aead_request_ctx(req);
1075 struct safexcel_crypto_priv *priv = ctx->base.priv;
1078 BUG_ON(!(priv->flags & EIP197_TRC_CACHE) && sreq->needs_inv);
1080 if (sreq->needs_inv)
1081 ret = safexcel_cipher_send_inv(async, ring, commands, results);
1083 ret = safexcel_send_req(async, ring, sreq, req->src, req->dst,
1084 req->cryptlen, req->assoclen,
1085 crypto_aead_authsize(tfm), req->iv,
1087 sreq->rdescs = *results;
1091 static int safexcel_cipher_exit_inv(struct crypto_tfm *tfm,
1092 struct crypto_async_request *base,
1093 struct safexcel_cipher_req *sreq,
1094 struct crypto_wait *result)
1096 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1097 struct safexcel_crypto_priv *priv = ctx->base.priv;
1098 int ring = ctx->base.ring;
1101 ctx = crypto_tfm_ctx(base->tfm);
1102 ctx->base.exit_inv = true;
1103 sreq->needs_inv = true;
1105 spin_lock_bh(&priv->ring[ring].queue_lock);
1106 crypto_enqueue_request(&priv->ring[ring].queue, base);
1107 spin_unlock_bh(&priv->ring[ring].queue_lock);
1109 queue_work(priv->ring[ring].workqueue,
1110 &priv->ring[ring].work_data.work);
1112 err = crypto_wait_req(-EINPROGRESS, result);
1116 "cipher: sync: invalidate: completion error %d\n",
1124 static int safexcel_skcipher_exit_inv(struct crypto_tfm *tfm)
1126 EIP197_REQUEST_ON_STACK(req, skcipher, EIP197_SKCIPHER_REQ_SIZE);
1127 struct safexcel_cipher_req *sreq = skcipher_request_ctx(req);
1128 DECLARE_CRYPTO_WAIT(result);
1130 memset(req, 0, sizeof(struct skcipher_request));
1132 skcipher_request_set_callback(req, CRYPTO_TFM_REQ_MAY_BACKLOG,
1133 crypto_req_done, &result);
1134 skcipher_request_set_tfm(req, __crypto_skcipher_cast(tfm));
1136 return safexcel_cipher_exit_inv(tfm, &req->base, sreq, &result);
1139 static int safexcel_aead_exit_inv(struct crypto_tfm *tfm)
1141 EIP197_REQUEST_ON_STACK(req, aead, EIP197_AEAD_REQ_SIZE);
1142 struct safexcel_cipher_req *sreq = aead_request_ctx(req);
1143 DECLARE_CRYPTO_WAIT(result);
1145 memset(req, 0, sizeof(struct aead_request));
1147 aead_request_set_callback(req, CRYPTO_TFM_REQ_MAY_BACKLOG,
1148 crypto_req_done, &result);
1149 aead_request_set_tfm(req, __crypto_aead_cast(tfm));
1151 return safexcel_cipher_exit_inv(tfm, &req->base, sreq, &result);
1154 static int safexcel_queue_req(struct crypto_async_request *base,
1155 struct safexcel_cipher_req *sreq,
1156 enum safexcel_cipher_direction dir)
1158 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(base->tfm);
1159 struct safexcel_crypto_priv *priv = ctx->base.priv;
1162 sreq->needs_inv = false;
1163 sreq->direction = dir;
1165 if (ctx->base.ctxr) {
1166 if (priv->flags & EIP197_TRC_CACHE && ctx->base.needs_inv) {
1167 sreq->needs_inv = true;
1168 ctx->base.needs_inv = false;
1171 ctx->base.ring = safexcel_select_ring(priv);
1172 ctx->base.ctxr = dma_pool_zalloc(priv->context_pool,
1173 EIP197_GFP_FLAGS(*base),
1174 &ctx->base.ctxr_dma);
1175 if (!ctx->base.ctxr)
1179 ring = ctx->base.ring;
1181 spin_lock_bh(&priv->ring[ring].queue_lock);
1182 ret = crypto_enqueue_request(&priv->ring[ring].queue, base);
1183 spin_unlock_bh(&priv->ring[ring].queue_lock);
1185 queue_work(priv->ring[ring].workqueue,
1186 &priv->ring[ring].work_data.work);
1191 static int safexcel_encrypt(struct skcipher_request *req)
1193 return safexcel_queue_req(&req->base, skcipher_request_ctx(req),
1197 static int safexcel_decrypt(struct skcipher_request *req)
1199 return safexcel_queue_req(&req->base, skcipher_request_ctx(req),
1203 static int safexcel_skcipher_cra_init(struct crypto_tfm *tfm)
1205 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1206 struct safexcel_alg_template *tmpl =
1207 container_of(tfm->__crt_alg, struct safexcel_alg_template,
1210 crypto_skcipher_set_reqsize(__crypto_skcipher_cast(tfm),
1211 sizeof(struct safexcel_cipher_req));
1213 ctx->base.priv = tmpl->priv;
1215 ctx->base.send = safexcel_skcipher_send;
1216 ctx->base.handle_result = safexcel_skcipher_handle_result;
1217 ctx->ivmask = EIP197_OPTION_4_TOKEN_IV_CMD;
1222 static int safexcel_cipher_cra_exit(struct crypto_tfm *tfm)
1224 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1226 memzero_explicit(ctx->key, sizeof(ctx->key));
1228 /* context not allocated, skip invalidation */
1229 if (!ctx->base.ctxr)
1232 memzero_explicit(ctx->base.ctxr->data, sizeof(ctx->base.ctxr->data));
1236 static void safexcel_skcipher_cra_exit(struct crypto_tfm *tfm)
1238 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1239 struct safexcel_crypto_priv *priv = ctx->base.priv;
1242 if (safexcel_cipher_cra_exit(tfm))
1245 if (priv->flags & EIP197_TRC_CACHE) {
1246 ret = safexcel_skcipher_exit_inv(tfm);
1248 dev_warn(priv->dev, "skcipher: invalidation error %d\n",
1251 dma_pool_free(priv->context_pool, ctx->base.ctxr,
1252 ctx->base.ctxr_dma);
1256 static void safexcel_aead_cra_exit(struct crypto_tfm *tfm)
1258 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1259 struct safexcel_crypto_priv *priv = ctx->base.priv;
1262 if (safexcel_cipher_cra_exit(tfm))
1265 if (priv->flags & EIP197_TRC_CACHE) {
1266 ret = safexcel_aead_exit_inv(tfm);
1268 dev_warn(priv->dev, "aead: invalidation error %d\n",
1271 dma_pool_free(priv->context_pool, ctx->base.ctxr,
1272 ctx->base.ctxr_dma);
1276 static int safexcel_skcipher_aes_ecb_cra_init(struct crypto_tfm *tfm)
1278 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1280 safexcel_skcipher_cra_init(tfm);
1281 ctx->alg = SAFEXCEL_AES;
1282 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_ECB;
1284 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
1288 struct safexcel_alg_template safexcel_alg_ecb_aes = {
1289 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
1290 .algo_mask = SAFEXCEL_ALG_AES,
1292 .setkey = safexcel_skcipher_aes_setkey,
1293 .encrypt = safexcel_encrypt,
1294 .decrypt = safexcel_decrypt,
1295 .min_keysize = AES_MIN_KEY_SIZE,
1296 .max_keysize = AES_MAX_KEY_SIZE,
1298 .cra_name = "ecb(aes)",
1299 .cra_driver_name = "safexcel-ecb-aes",
1300 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1301 .cra_flags = CRYPTO_ALG_ASYNC |
1302 CRYPTO_ALG_ALLOCATES_MEMORY |
1303 CRYPTO_ALG_KERN_DRIVER_ONLY,
1304 .cra_blocksize = AES_BLOCK_SIZE,
1305 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1307 .cra_init = safexcel_skcipher_aes_ecb_cra_init,
1308 .cra_exit = safexcel_skcipher_cra_exit,
1309 .cra_module = THIS_MODULE,
1314 static int safexcel_skcipher_aes_cbc_cra_init(struct crypto_tfm *tfm)
1316 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1318 safexcel_skcipher_cra_init(tfm);
1319 ctx->alg = SAFEXCEL_AES;
1320 ctx->blocksz = AES_BLOCK_SIZE;
1321 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CBC;
1325 struct safexcel_alg_template safexcel_alg_cbc_aes = {
1326 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
1327 .algo_mask = SAFEXCEL_ALG_AES,
1329 .setkey = safexcel_skcipher_aes_setkey,
1330 .encrypt = safexcel_encrypt,
1331 .decrypt = safexcel_decrypt,
1332 .min_keysize = AES_MIN_KEY_SIZE,
1333 .max_keysize = AES_MAX_KEY_SIZE,
1334 .ivsize = AES_BLOCK_SIZE,
1336 .cra_name = "cbc(aes)",
1337 .cra_driver_name = "safexcel-cbc-aes",
1338 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1339 .cra_flags = CRYPTO_ALG_ASYNC |
1340 CRYPTO_ALG_ALLOCATES_MEMORY |
1341 CRYPTO_ALG_KERN_DRIVER_ONLY,
1342 .cra_blocksize = AES_BLOCK_SIZE,
1343 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1345 .cra_init = safexcel_skcipher_aes_cbc_cra_init,
1346 .cra_exit = safexcel_skcipher_cra_exit,
1347 .cra_module = THIS_MODULE,
1352 static int safexcel_skcipher_aes_cfb_cra_init(struct crypto_tfm *tfm)
1354 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1356 safexcel_skcipher_cra_init(tfm);
1357 ctx->alg = SAFEXCEL_AES;
1358 ctx->blocksz = AES_BLOCK_SIZE;
1359 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CFB;
1363 struct safexcel_alg_template safexcel_alg_cfb_aes = {
1364 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
1365 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_AES_XFB,
1367 .setkey = safexcel_skcipher_aes_setkey,
1368 .encrypt = safexcel_encrypt,
1369 .decrypt = safexcel_decrypt,
1370 .min_keysize = AES_MIN_KEY_SIZE,
1371 .max_keysize = AES_MAX_KEY_SIZE,
1372 .ivsize = AES_BLOCK_SIZE,
1374 .cra_name = "cfb(aes)",
1375 .cra_driver_name = "safexcel-cfb-aes",
1376 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1377 .cra_flags = CRYPTO_ALG_ASYNC |
1378 CRYPTO_ALG_ALLOCATES_MEMORY |
1379 CRYPTO_ALG_KERN_DRIVER_ONLY,
1381 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1383 .cra_init = safexcel_skcipher_aes_cfb_cra_init,
1384 .cra_exit = safexcel_skcipher_cra_exit,
1385 .cra_module = THIS_MODULE,
1390 static int safexcel_skcipher_aes_ofb_cra_init(struct crypto_tfm *tfm)
1392 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1394 safexcel_skcipher_cra_init(tfm);
1395 ctx->alg = SAFEXCEL_AES;
1396 ctx->blocksz = AES_BLOCK_SIZE;
1397 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_OFB;
1401 struct safexcel_alg_template safexcel_alg_ofb_aes = {
1402 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
1403 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_AES_XFB,
1405 .setkey = safexcel_skcipher_aes_setkey,
1406 .encrypt = safexcel_encrypt,
1407 .decrypt = safexcel_decrypt,
1408 .min_keysize = AES_MIN_KEY_SIZE,
1409 .max_keysize = AES_MAX_KEY_SIZE,
1410 .ivsize = AES_BLOCK_SIZE,
1412 .cra_name = "ofb(aes)",
1413 .cra_driver_name = "safexcel-ofb-aes",
1414 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1415 .cra_flags = CRYPTO_ALG_ASYNC |
1416 CRYPTO_ALG_ALLOCATES_MEMORY |
1417 CRYPTO_ALG_KERN_DRIVER_ONLY,
1419 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1421 .cra_init = safexcel_skcipher_aes_ofb_cra_init,
1422 .cra_exit = safexcel_skcipher_cra_exit,
1423 .cra_module = THIS_MODULE,
1428 static int safexcel_skcipher_aesctr_setkey(struct crypto_skcipher *ctfm,
1429 const u8 *key, unsigned int len)
1431 struct crypto_tfm *tfm = crypto_skcipher_tfm(ctfm);
1432 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1433 struct safexcel_crypto_priv *priv = ctx->base.priv;
1434 struct crypto_aes_ctx aes;
1436 unsigned int keylen;
1438 /* last 4 bytes of key are the nonce! */
1439 ctx->nonce = *(u32 *)(key + len - CTR_RFC3686_NONCE_SIZE);
1440 /* exclude the nonce here */
1441 keylen = len - CTR_RFC3686_NONCE_SIZE;
1442 ret = aes_expandkey(&aes, key, keylen);
1446 if (priv->flags & EIP197_TRC_CACHE && ctx->base.ctxr_dma) {
1447 for (i = 0; i < keylen / sizeof(u32); i++) {
1448 if (le32_to_cpu(ctx->key[i]) != aes.key_enc[i]) {
1449 ctx->base.needs_inv = true;
1455 for (i = 0; i < keylen / sizeof(u32); i++)
1456 ctx->key[i] = cpu_to_le32(aes.key_enc[i]);
1458 ctx->key_len = keylen;
1460 memzero_explicit(&aes, sizeof(aes));
1464 static int safexcel_skcipher_aes_ctr_cra_init(struct crypto_tfm *tfm)
1466 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1468 safexcel_skcipher_cra_init(tfm);
1469 ctx->alg = SAFEXCEL_AES;
1470 ctx->blocksz = AES_BLOCK_SIZE;
1471 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CTR_LOAD;
1475 struct safexcel_alg_template safexcel_alg_ctr_aes = {
1476 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
1477 .algo_mask = SAFEXCEL_ALG_AES,
1479 .setkey = safexcel_skcipher_aesctr_setkey,
1480 .encrypt = safexcel_encrypt,
1481 .decrypt = safexcel_decrypt,
1482 /* Add nonce size */
1483 .min_keysize = AES_MIN_KEY_SIZE + CTR_RFC3686_NONCE_SIZE,
1484 .max_keysize = AES_MAX_KEY_SIZE + CTR_RFC3686_NONCE_SIZE,
1485 .ivsize = CTR_RFC3686_IV_SIZE,
1487 .cra_name = "rfc3686(ctr(aes))",
1488 .cra_driver_name = "safexcel-ctr-aes",
1489 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1490 .cra_flags = CRYPTO_ALG_ASYNC |
1491 CRYPTO_ALG_ALLOCATES_MEMORY |
1492 CRYPTO_ALG_KERN_DRIVER_ONLY,
1494 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1496 .cra_init = safexcel_skcipher_aes_ctr_cra_init,
1497 .cra_exit = safexcel_skcipher_cra_exit,
1498 .cra_module = THIS_MODULE,
1503 static int safexcel_des_setkey(struct crypto_skcipher *ctfm, const u8 *key,
1506 struct safexcel_cipher_ctx *ctx = crypto_skcipher_ctx(ctfm);
1507 struct safexcel_crypto_priv *priv = ctx->base.priv;
1510 ret = verify_skcipher_des_key(ctfm, key);
1514 /* if context exits and key changed, need to invalidate it */
1515 if (priv->flags & EIP197_TRC_CACHE && ctx->base.ctxr_dma)
1516 if (memcmp(ctx->key, key, len))
1517 ctx->base.needs_inv = true;
1519 memcpy(ctx->key, key, len);
1525 static int safexcel_skcipher_des_cbc_cra_init(struct crypto_tfm *tfm)
1527 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1529 safexcel_skcipher_cra_init(tfm);
1530 ctx->alg = SAFEXCEL_DES;
1531 ctx->blocksz = DES_BLOCK_SIZE;
1532 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
1533 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CBC;
1537 struct safexcel_alg_template safexcel_alg_cbc_des = {
1538 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
1539 .algo_mask = SAFEXCEL_ALG_DES,
1541 .setkey = safexcel_des_setkey,
1542 .encrypt = safexcel_encrypt,
1543 .decrypt = safexcel_decrypt,
1544 .min_keysize = DES_KEY_SIZE,
1545 .max_keysize = DES_KEY_SIZE,
1546 .ivsize = DES_BLOCK_SIZE,
1548 .cra_name = "cbc(des)",
1549 .cra_driver_name = "safexcel-cbc-des",
1550 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1551 .cra_flags = CRYPTO_ALG_ASYNC |
1552 CRYPTO_ALG_ALLOCATES_MEMORY |
1553 CRYPTO_ALG_KERN_DRIVER_ONLY,
1554 .cra_blocksize = DES_BLOCK_SIZE,
1555 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1557 .cra_init = safexcel_skcipher_des_cbc_cra_init,
1558 .cra_exit = safexcel_skcipher_cra_exit,
1559 .cra_module = THIS_MODULE,
1564 static int safexcel_skcipher_des_ecb_cra_init(struct crypto_tfm *tfm)
1566 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1568 safexcel_skcipher_cra_init(tfm);
1569 ctx->alg = SAFEXCEL_DES;
1570 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_ECB;
1572 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
1576 struct safexcel_alg_template safexcel_alg_ecb_des = {
1577 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
1578 .algo_mask = SAFEXCEL_ALG_DES,
1580 .setkey = safexcel_des_setkey,
1581 .encrypt = safexcel_encrypt,
1582 .decrypt = safexcel_decrypt,
1583 .min_keysize = DES_KEY_SIZE,
1584 .max_keysize = DES_KEY_SIZE,
1586 .cra_name = "ecb(des)",
1587 .cra_driver_name = "safexcel-ecb-des",
1588 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1589 .cra_flags = CRYPTO_ALG_ASYNC |
1590 CRYPTO_ALG_ALLOCATES_MEMORY |
1591 CRYPTO_ALG_KERN_DRIVER_ONLY,
1592 .cra_blocksize = DES_BLOCK_SIZE,
1593 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1595 .cra_init = safexcel_skcipher_des_ecb_cra_init,
1596 .cra_exit = safexcel_skcipher_cra_exit,
1597 .cra_module = THIS_MODULE,
1602 static int safexcel_des3_ede_setkey(struct crypto_skcipher *ctfm,
1603 const u8 *key, unsigned int len)
1605 struct safexcel_cipher_ctx *ctx = crypto_skcipher_ctx(ctfm);
1606 struct safexcel_crypto_priv *priv = ctx->base.priv;
1609 err = verify_skcipher_des3_key(ctfm, key);
1613 /* if context exits and key changed, need to invalidate it */
1614 if (priv->flags & EIP197_TRC_CACHE && ctx->base.ctxr_dma)
1615 if (memcmp(ctx->key, key, len))
1616 ctx->base.needs_inv = true;
1618 memcpy(ctx->key, key, len);
1624 static int safexcel_skcipher_des3_cbc_cra_init(struct crypto_tfm *tfm)
1626 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1628 safexcel_skcipher_cra_init(tfm);
1629 ctx->alg = SAFEXCEL_3DES;
1630 ctx->blocksz = DES3_EDE_BLOCK_SIZE;
1631 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
1632 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CBC;
1636 struct safexcel_alg_template safexcel_alg_cbc_des3_ede = {
1637 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
1638 .algo_mask = SAFEXCEL_ALG_DES,
1640 .setkey = safexcel_des3_ede_setkey,
1641 .encrypt = safexcel_encrypt,
1642 .decrypt = safexcel_decrypt,
1643 .min_keysize = DES3_EDE_KEY_SIZE,
1644 .max_keysize = DES3_EDE_KEY_SIZE,
1645 .ivsize = DES3_EDE_BLOCK_SIZE,
1647 .cra_name = "cbc(des3_ede)",
1648 .cra_driver_name = "safexcel-cbc-des3_ede",
1649 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1650 .cra_flags = CRYPTO_ALG_ASYNC |
1651 CRYPTO_ALG_ALLOCATES_MEMORY |
1652 CRYPTO_ALG_KERN_DRIVER_ONLY,
1653 .cra_blocksize = DES3_EDE_BLOCK_SIZE,
1654 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1656 .cra_init = safexcel_skcipher_des3_cbc_cra_init,
1657 .cra_exit = safexcel_skcipher_cra_exit,
1658 .cra_module = THIS_MODULE,
1663 static int safexcel_skcipher_des3_ecb_cra_init(struct crypto_tfm *tfm)
1665 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1667 safexcel_skcipher_cra_init(tfm);
1668 ctx->alg = SAFEXCEL_3DES;
1669 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_ECB;
1671 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
1675 struct safexcel_alg_template safexcel_alg_ecb_des3_ede = {
1676 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
1677 .algo_mask = SAFEXCEL_ALG_DES,
1679 .setkey = safexcel_des3_ede_setkey,
1680 .encrypt = safexcel_encrypt,
1681 .decrypt = safexcel_decrypt,
1682 .min_keysize = DES3_EDE_KEY_SIZE,
1683 .max_keysize = DES3_EDE_KEY_SIZE,
1685 .cra_name = "ecb(des3_ede)",
1686 .cra_driver_name = "safexcel-ecb-des3_ede",
1687 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1688 .cra_flags = CRYPTO_ALG_ASYNC |
1689 CRYPTO_ALG_ALLOCATES_MEMORY |
1690 CRYPTO_ALG_KERN_DRIVER_ONLY,
1691 .cra_blocksize = DES3_EDE_BLOCK_SIZE,
1692 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1694 .cra_init = safexcel_skcipher_des3_ecb_cra_init,
1695 .cra_exit = safexcel_skcipher_cra_exit,
1696 .cra_module = THIS_MODULE,
1701 static int safexcel_aead_encrypt(struct aead_request *req)
1703 struct safexcel_cipher_req *creq = aead_request_ctx(req);
1705 return safexcel_queue_req(&req->base, creq, SAFEXCEL_ENCRYPT);
1708 static int safexcel_aead_decrypt(struct aead_request *req)
1710 struct safexcel_cipher_req *creq = aead_request_ctx(req);
1712 return safexcel_queue_req(&req->base, creq, SAFEXCEL_DECRYPT);
1715 static int safexcel_aead_cra_init(struct crypto_tfm *tfm)
1717 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1718 struct safexcel_alg_template *tmpl =
1719 container_of(tfm->__crt_alg, struct safexcel_alg_template,
1722 crypto_aead_set_reqsize(__crypto_aead_cast(tfm),
1723 sizeof(struct safexcel_cipher_req));
1725 ctx->base.priv = tmpl->priv;
1727 ctx->alg = SAFEXCEL_AES; /* default */
1728 ctx->blocksz = AES_BLOCK_SIZE;
1729 ctx->ivmask = EIP197_OPTION_4_TOKEN_IV_CMD;
1731 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CBC; /* default */
1733 ctx->base.send = safexcel_aead_send;
1734 ctx->base.handle_result = safexcel_aead_handle_result;
1738 static int safexcel_aead_sha1_cra_init(struct crypto_tfm *tfm)
1740 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1742 safexcel_aead_cra_init(tfm);
1743 ctx->hash_alg = CONTEXT_CONTROL_CRYPTO_ALG_SHA1;
1744 ctx->state_sz = SHA1_DIGEST_SIZE;
1748 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha1_cbc_aes = {
1749 .type = SAFEXCEL_ALG_TYPE_AEAD,
1750 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_SHA1,
1752 .setkey = safexcel_aead_setkey,
1753 .encrypt = safexcel_aead_encrypt,
1754 .decrypt = safexcel_aead_decrypt,
1755 .ivsize = AES_BLOCK_SIZE,
1756 .maxauthsize = SHA1_DIGEST_SIZE,
1758 .cra_name = "authenc(hmac(sha1),cbc(aes))",
1759 .cra_driver_name = "safexcel-authenc-hmac-sha1-cbc-aes",
1760 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1761 .cra_flags = CRYPTO_ALG_ASYNC |
1762 CRYPTO_ALG_ALLOCATES_MEMORY |
1763 CRYPTO_ALG_KERN_DRIVER_ONLY,
1764 .cra_blocksize = AES_BLOCK_SIZE,
1765 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1767 .cra_init = safexcel_aead_sha1_cra_init,
1768 .cra_exit = safexcel_aead_cra_exit,
1769 .cra_module = THIS_MODULE,
1774 static int safexcel_aead_sha256_cra_init(struct crypto_tfm *tfm)
1776 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1778 safexcel_aead_cra_init(tfm);
1779 ctx->hash_alg = CONTEXT_CONTROL_CRYPTO_ALG_SHA256;
1780 ctx->state_sz = SHA256_DIGEST_SIZE;
1784 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha256_cbc_aes = {
1785 .type = SAFEXCEL_ALG_TYPE_AEAD,
1786 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_SHA2_256,
1788 .setkey = safexcel_aead_setkey,
1789 .encrypt = safexcel_aead_encrypt,
1790 .decrypt = safexcel_aead_decrypt,
1791 .ivsize = AES_BLOCK_SIZE,
1792 .maxauthsize = SHA256_DIGEST_SIZE,
1794 .cra_name = "authenc(hmac(sha256),cbc(aes))",
1795 .cra_driver_name = "safexcel-authenc-hmac-sha256-cbc-aes",
1796 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1797 .cra_flags = CRYPTO_ALG_ASYNC |
1798 CRYPTO_ALG_ALLOCATES_MEMORY |
1799 CRYPTO_ALG_KERN_DRIVER_ONLY,
1800 .cra_blocksize = AES_BLOCK_SIZE,
1801 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1803 .cra_init = safexcel_aead_sha256_cra_init,
1804 .cra_exit = safexcel_aead_cra_exit,
1805 .cra_module = THIS_MODULE,
1810 static int safexcel_aead_sha224_cra_init(struct crypto_tfm *tfm)
1812 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1814 safexcel_aead_cra_init(tfm);
1815 ctx->hash_alg = CONTEXT_CONTROL_CRYPTO_ALG_SHA224;
1816 ctx->state_sz = SHA256_DIGEST_SIZE;
1820 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha224_cbc_aes = {
1821 .type = SAFEXCEL_ALG_TYPE_AEAD,
1822 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_SHA2_256,
1824 .setkey = safexcel_aead_setkey,
1825 .encrypt = safexcel_aead_encrypt,
1826 .decrypt = safexcel_aead_decrypt,
1827 .ivsize = AES_BLOCK_SIZE,
1828 .maxauthsize = SHA224_DIGEST_SIZE,
1830 .cra_name = "authenc(hmac(sha224),cbc(aes))",
1831 .cra_driver_name = "safexcel-authenc-hmac-sha224-cbc-aes",
1832 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1833 .cra_flags = CRYPTO_ALG_ASYNC |
1834 CRYPTO_ALG_ALLOCATES_MEMORY |
1835 CRYPTO_ALG_KERN_DRIVER_ONLY,
1836 .cra_blocksize = AES_BLOCK_SIZE,
1837 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1839 .cra_init = safexcel_aead_sha224_cra_init,
1840 .cra_exit = safexcel_aead_cra_exit,
1841 .cra_module = THIS_MODULE,
1846 static int safexcel_aead_sha512_cra_init(struct crypto_tfm *tfm)
1848 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1850 safexcel_aead_cra_init(tfm);
1851 ctx->hash_alg = CONTEXT_CONTROL_CRYPTO_ALG_SHA512;
1852 ctx->state_sz = SHA512_DIGEST_SIZE;
1856 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha512_cbc_aes = {
1857 .type = SAFEXCEL_ALG_TYPE_AEAD,
1858 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_SHA2_512,
1860 .setkey = safexcel_aead_setkey,
1861 .encrypt = safexcel_aead_encrypt,
1862 .decrypt = safexcel_aead_decrypt,
1863 .ivsize = AES_BLOCK_SIZE,
1864 .maxauthsize = SHA512_DIGEST_SIZE,
1866 .cra_name = "authenc(hmac(sha512),cbc(aes))",
1867 .cra_driver_name = "safexcel-authenc-hmac-sha512-cbc-aes",
1868 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1869 .cra_flags = CRYPTO_ALG_ASYNC |
1870 CRYPTO_ALG_ALLOCATES_MEMORY |
1871 CRYPTO_ALG_KERN_DRIVER_ONLY,
1872 .cra_blocksize = AES_BLOCK_SIZE,
1873 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1875 .cra_init = safexcel_aead_sha512_cra_init,
1876 .cra_exit = safexcel_aead_cra_exit,
1877 .cra_module = THIS_MODULE,
1882 static int safexcel_aead_sha384_cra_init(struct crypto_tfm *tfm)
1884 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1886 safexcel_aead_cra_init(tfm);
1887 ctx->hash_alg = CONTEXT_CONTROL_CRYPTO_ALG_SHA384;
1888 ctx->state_sz = SHA512_DIGEST_SIZE;
1892 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha384_cbc_aes = {
1893 .type = SAFEXCEL_ALG_TYPE_AEAD,
1894 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_SHA2_512,
1896 .setkey = safexcel_aead_setkey,
1897 .encrypt = safexcel_aead_encrypt,
1898 .decrypt = safexcel_aead_decrypt,
1899 .ivsize = AES_BLOCK_SIZE,
1900 .maxauthsize = SHA384_DIGEST_SIZE,
1902 .cra_name = "authenc(hmac(sha384),cbc(aes))",
1903 .cra_driver_name = "safexcel-authenc-hmac-sha384-cbc-aes",
1904 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1905 .cra_flags = CRYPTO_ALG_ASYNC |
1906 CRYPTO_ALG_ALLOCATES_MEMORY |
1907 CRYPTO_ALG_KERN_DRIVER_ONLY,
1908 .cra_blocksize = AES_BLOCK_SIZE,
1909 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1911 .cra_init = safexcel_aead_sha384_cra_init,
1912 .cra_exit = safexcel_aead_cra_exit,
1913 .cra_module = THIS_MODULE,
1918 static int safexcel_aead_sha1_des3_cra_init(struct crypto_tfm *tfm)
1920 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1922 safexcel_aead_sha1_cra_init(tfm);
1923 ctx->alg = SAFEXCEL_3DES; /* override default */
1924 ctx->blocksz = DES3_EDE_BLOCK_SIZE;
1925 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
1929 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha1_cbc_des3_ede = {
1930 .type = SAFEXCEL_ALG_TYPE_AEAD,
1931 .algo_mask = SAFEXCEL_ALG_DES | SAFEXCEL_ALG_SHA1,
1933 .setkey = safexcel_aead_setkey,
1934 .encrypt = safexcel_aead_encrypt,
1935 .decrypt = safexcel_aead_decrypt,
1936 .ivsize = DES3_EDE_BLOCK_SIZE,
1937 .maxauthsize = SHA1_DIGEST_SIZE,
1939 .cra_name = "authenc(hmac(sha1),cbc(des3_ede))",
1940 .cra_driver_name = "safexcel-authenc-hmac-sha1-cbc-des3_ede",
1941 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1942 .cra_flags = CRYPTO_ALG_ASYNC |
1943 CRYPTO_ALG_ALLOCATES_MEMORY |
1944 CRYPTO_ALG_KERN_DRIVER_ONLY,
1945 .cra_blocksize = DES3_EDE_BLOCK_SIZE,
1946 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1948 .cra_init = safexcel_aead_sha1_des3_cra_init,
1949 .cra_exit = safexcel_aead_cra_exit,
1950 .cra_module = THIS_MODULE,
1955 static int safexcel_aead_sha256_des3_cra_init(struct crypto_tfm *tfm)
1957 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1959 safexcel_aead_sha256_cra_init(tfm);
1960 ctx->alg = SAFEXCEL_3DES; /* override default */
1961 ctx->blocksz = DES3_EDE_BLOCK_SIZE;
1962 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
1966 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha256_cbc_des3_ede = {
1967 .type = SAFEXCEL_ALG_TYPE_AEAD,
1968 .algo_mask = SAFEXCEL_ALG_DES | SAFEXCEL_ALG_SHA2_256,
1970 .setkey = safexcel_aead_setkey,
1971 .encrypt = safexcel_aead_encrypt,
1972 .decrypt = safexcel_aead_decrypt,
1973 .ivsize = DES3_EDE_BLOCK_SIZE,
1974 .maxauthsize = SHA256_DIGEST_SIZE,
1976 .cra_name = "authenc(hmac(sha256),cbc(des3_ede))",
1977 .cra_driver_name = "safexcel-authenc-hmac-sha256-cbc-des3_ede",
1978 .cra_priority = SAFEXCEL_CRA_PRIORITY,
1979 .cra_flags = CRYPTO_ALG_ASYNC |
1980 CRYPTO_ALG_ALLOCATES_MEMORY |
1981 CRYPTO_ALG_KERN_DRIVER_ONLY,
1982 .cra_blocksize = DES3_EDE_BLOCK_SIZE,
1983 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
1985 .cra_init = safexcel_aead_sha256_des3_cra_init,
1986 .cra_exit = safexcel_aead_cra_exit,
1987 .cra_module = THIS_MODULE,
1992 static int safexcel_aead_sha224_des3_cra_init(struct crypto_tfm *tfm)
1994 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
1996 safexcel_aead_sha224_cra_init(tfm);
1997 ctx->alg = SAFEXCEL_3DES; /* override default */
1998 ctx->blocksz = DES3_EDE_BLOCK_SIZE;
1999 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
2003 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha224_cbc_des3_ede = {
2004 .type = SAFEXCEL_ALG_TYPE_AEAD,
2005 .algo_mask = SAFEXCEL_ALG_DES | SAFEXCEL_ALG_SHA2_256,
2007 .setkey = safexcel_aead_setkey,
2008 .encrypt = safexcel_aead_encrypt,
2009 .decrypt = safexcel_aead_decrypt,
2010 .ivsize = DES3_EDE_BLOCK_SIZE,
2011 .maxauthsize = SHA224_DIGEST_SIZE,
2013 .cra_name = "authenc(hmac(sha224),cbc(des3_ede))",
2014 .cra_driver_name = "safexcel-authenc-hmac-sha224-cbc-des3_ede",
2015 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2016 .cra_flags = CRYPTO_ALG_ASYNC |
2017 CRYPTO_ALG_ALLOCATES_MEMORY |
2018 CRYPTO_ALG_KERN_DRIVER_ONLY,
2019 .cra_blocksize = DES3_EDE_BLOCK_SIZE,
2020 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2022 .cra_init = safexcel_aead_sha224_des3_cra_init,
2023 .cra_exit = safexcel_aead_cra_exit,
2024 .cra_module = THIS_MODULE,
2029 static int safexcel_aead_sha512_des3_cra_init(struct crypto_tfm *tfm)
2031 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2033 safexcel_aead_sha512_cra_init(tfm);
2034 ctx->alg = SAFEXCEL_3DES; /* override default */
2035 ctx->blocksz = DES3_EDE_BLOCK_SIZE;
2036 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
2040 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha512_cbc_des3_ede = {
2041 .type = SAFEXCEL_ALG_TYPE_AEAD,
2042 .algo_mask = SAFEXCEL_ALG_DES | SAFEXCEL_ALG_SHA2_512,
2044 .setkey = safexcel_aead_setkey,
2045 .encrypt = safexcel_aead_encrypt,
2046 .decrypt = safexcel_aead_decrypt,
2047 .ivsize = DES3_EDE_BLOCK_SIZE,
2048 .maxauthsize = SHA512_DIGEST_SIZE,
2050 .cra_name = "authenc(hmac(sha512),cbc(des3_ede))",
2051 .cra_driver_name = "safexcel-authenc-hmac-sha512-cbc-des3_ede",
2052 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2053 .cra_flags = CRYPTO_ALG_ASYNC |
2054 CRYPTO_ALG_ALLOCATES_MEMORY |
2055 CRYPTO_ALG_KERN_DRIVER_ONLY,
2056 .cra_blocksize = DES3_EDE_BLOCK_SIZE,
2057 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2059 .cra_init = safexcel_aead_sha512_des3_cra_init,
2060 .cra_exit = safexcel_aead_cra_exit,
2061 .cra_module = THIS_MODULE,
2066 static int safexcel_aead_sha384_des3_cra_init(struct crypto_tfm *tfm)
2068 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2070 safexcel_aead_sha384_cra_init(tfm);
2071 ctx->alg = SAFEXCEL_3DES; /* override default */
2072 ctx->blocksz = DES3_EDE_BLOCK_SIZE;
2073 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
2077 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha384_cbc_des3_ede = {
2078 .type = SAFEXCEL_ALG_TYPE_AEAD,
2079 .algo_mask = SAFEXCEL_ALG_DES | SAFEXCEL_ALG_SHA2_512,
2081 .setkey = safexcel_aead_setkey,
2082 .encrypt = safexcel_aead_encrypt,
2083 .decrypt = safexcel_aead_decrypt,
2084 .ivsize = DES3_EDE_BLOCK_SIZE,
2085 .maxauthsize = SHA384_DIGEST_SIZE,
2087 .cra_name = "authenc(hmac(sha384),cbc(des3_ede))",
2088 .cra_driver_name = "safexcel-authenc-hmac-sha384-cbc-des3_ede",
2089 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2090 .cra_flags = CRYPTO_ALG_ASYNC |
2091 CRYPTO_ALG_ALLOCATES_MEMORY |
2092 CRYPTO_ALG_KERN_DRIVER_ONLY,
2093 .cra_blocksize = DES3_EDE_BLOCK_SIZE,
2094 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2096 .cra_init = safexcel_aead_sha384_des3_cra_init,
2097 .cra_exit = safexcel_aead_cra_exit,
2098 .cra_module = THIS_MODULE,
2103 static int safexcel_aead_sha1_des_cra_init(struct crypto_tfm *tfm)
2105 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2107 safexcel_aead_sha1_cra_init(tfm);
2108 ctx->alg = SAFEXCEL_DES; /* override default */
2109 ctx->blocksz = DES_BLOCK_SIZE;
2110 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
2114 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha1_cbc_des = {
2115 .type = SAFEXCEL_ALG_TYPE_AEAD,
2116 .algo_mask = SAFEXCEL_ALG_DES | SAFEXCEL_ALG_SHA1,
2118 .setkey = safexcel_aead_setkey,
2119 .encrypt = safexcel_aead_encrypt,
2120 .decrypt = safexcel_aead_decrypt,
2121 .ivsize = DES_BLOCK_SIZE,
2122 .maxauthsize = SHA1_DIGEST_SIZE,
2124 .cra_name = "authenc(hmac(sha1),cbc(des))",
2125 .cra_driver_name = "safexcel-authenc-hmac-sha1-cbc-des",
2126 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2127 .cra_flags = CRYPTO_ALG_ASYNC |
2128 CRYPTO_ALG_ALLOCATES_MEMORY |
2129 CRYPTO_ALG_KERN_DRIVER_ONLY,
2130 .cra_blocksize = DES_BLOCK_SIZE,
2131 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2133 .cra_init = safexcel_aead_sha1_des_cra_init,
2134 .cra_exit = safexcel_aead_cra_exit,
2135 .cra_module = THIS_MODULE,
2140 static int safexcel_aead_sha256_des_cra_init(struct crypto_tfm *tfm)
2142 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2144 safexcel_aead_sha256_cra_init(tfm);
2145 ctx->alg = SAFEXCEL_DES; /* override default */
2146 ctx->blocksz = DES_BLOCK_SIZE;
2147 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
2151 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha256_cbc_des = {
2152 .type = SAFEXCEL_ALG_TYPE_AEAD,
2153 .algo_mask = SAFEXCEL_ALG_DES | SAFEXCEL_ALG_SHA2_256,
2155 .setkey = safexcel_aead_setkey,
2156 .encrypt = safexcel_aead_encrypt,
2157 .decrypt = safexcel_aead_decrypt,
2158 .ivsize = DES_BLOCK_SIZE,
2159 .maxauthsize = SHA256_DIGEST_SIZE,
2161 .cra_name = "authenc(hmac(sha256),cbc(des))",
2162 .cra_driver_name = "safexcel-authenc-hmac-sha256-cbc-des",
2163 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2164 .cra_flags = CRYPTO_ALG_ASYNC |
2165 CRYPTO_ALG_ALLOCATES_MEMORY |
2166 CRYPTO_ALG_KERN_DRIVER_ONLY,
2167 .cra_blocksize = DES_BLOCK_SIZE,
2168 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2170 .cra_init = safexcel_aead_sha256_des_cra_init,
2171 .cra_exit = safexcel_aead_cra_exit,
2172 .cra_module = THIS_MODULE,
2177 static int safexcel_aead_sha224_des_cra_init(struct crypto_tfm *tfm)
2179 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2181 safexcel_aead_sha224_cra_init(tfm);
2182 ctx->alg = SAFEXCEL_DES; /* override default */
2183 ctx->blocksz = DES_BLOCK_SIZE;
2184 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
2188 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha224_cbc_des = {
2189 .type = SAFEXCEL_ALG_TYPE_AEAD,
2190 .algo_mask = SAFEXCEL_ALG_DES | SAFEXCEL_ALG_SHA2_256,
2192 .setkey = safexcel_aead_setkey,
2193 .encrypt = safexcel_aead_encrypt,
2194 .decrypt = safexcel_aead_decrypt,
2195 .ivsize = DES_BLOCK_SIZE,
2196 .maxauthsize = SHA224_DIGEST_SIZE,
2198 .cra_name = "authenc(hmac(sha224),cbc(des))",
2199 .cra_driver_name = "safexcel-authenc-hmac-sha224-cbc-des",
2200 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2201 .cra_flags = CRYPTO_ALG_ASYNC |
2202 CRYPTO_ALG_ALLOCATES_MEMORY |
2203 CRYPTO_ALG_KERN_DRIVER_ONLY,
2204 .cra_blocksize = DES_BLOCK_SIZE,
2205 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2207 .cra_init = safexcel_aead_sha224_des_cra_init,
2208 .cra_exit = safexcel_aead_cra_exit,
2209 .cra_module = THIS_MODULE,
2214 static int safexcel_aead_sha512_des_cra_init(struct crypto_tfm *tfm)
2216 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2218 safexcel_aead_sha512_cra_init(tfm);
2219 ctx->alg = SAFEXCEL_DES; /* override default */
2220 ctx->blocksz = DES_BLOCK_SIZE;
2221 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
2225 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha512_cbc_des = {
2226 .type = SAFEXCEL_ALG_TYPE_AEAD,
2227 .algo_mask = SAFEXCEL_ALG_DES | SAFEXCEL_ALG_SHA2_512,
2229 .setkey = safexcel_aead_setkey,
2230 .encrypt = safexcel_aead_encrypt,
2231 .decrypt = safexcel_aead_decrypt,
2232 .ivsize = DES_BLOCK_SIZE,
2233 .maxauthsize = SHA512_DIGEST_SIZE,
2235 .cra_name = "authenc(hmac(sha512),cbc(des))",
2236 .cra_driver_name = "safexcel-authenc-hmac-sha512-cbc-des",
2237 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2238 .cra_flags = CRYPTO_ALG_ASYNC |
2239 CRYPTO_ALG_ALLOCATES_MEMORY |
2240 CRYPTO_ALG_KERN_DRIVER_ONLY,
2241 .cra_blocksize = DES_BLOCK_SIZE,
2242 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2244 .cra_init = safexcel_aead_sha512_des_cra_init,
2245 .cra_exit = safexcel_aead_cra_exit,
2246 .cra_module = THIS_MODULE,
2251 static int safexcel_aead_sha384_des_cra_init(struct crypto_tfm *tfm)
2253 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2255 safexcel_aead_sha384_cra_init(tfm);
2256 ctx->alg = SAFEXCEL_DES; /* override default */
2257 ctx->blocksz = DES_BLOCK_SIZE;
2258 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
2262 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha384_cbc_des = {
2263 .type = SAFEXCEL_ALG_TYPE_AEAD,
2264 .algo_mask = SAFEXCEL_ALG_DES | SAFEXCEL_ALG_SHA2_512,
2266 .setkey = safexcel_aead_setkey,
2267 .encrypt = safexcel_aead_encrypt,
2268 .decrypt = safexcel_aead_decrypt,
2269 .ivsize = DES_BLOCK_SIZE,
2270 .maxauthsize = SHA384_DIGEST_SIZE,
2272 .cra_name = "authenc(hmac(sha384),cbc(des))",
2273 .cra_driver_name = "safexcel-authenc-hmac-sha384-cbc-des",
2274 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2275 .cra_flags = CRYPTO_ALG_ASYNC |
2276 CRYPTO_ALG_ALLOCATES_MEMORY |
2277 CRYPTO_ALG_KERN_DRIVER_ONLY,
2278 .cra_blocksize = DES_BLOCK_SIZE,
2279 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2281 .cra_init = safexcel_aead_sha384_des_cra_init,
2282 .cra_exit = safexcel_aead_cra_exit,
2283 .cra_module = THIS_MODULE,
2288 static int safexcel_aead_sha1_ctr_cra_init(struct crypto_tfm *tfm)
2290 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2292 safexcel_aead_sha1_cra_init(tfm);
2293 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CTR_LOAD; /* override default */
2297 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha1_ctr_aes = {
2298 .type = SAFEXCEL_ALG_TYPE_AEAD,
2299 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_SHA1,
2301 .setkey = safexcel_aead_setkey,
2302 .encrypt = safexcel_aead_encrypt,
2303 .decrypt = safexcel_aead_decrypt,
2304 .ivsize = CTR_RFC3686_IV_SIZE,
2305 .maxauthsize = SHA1_DIGEST_SIZE,
2307 .cra_name = "authenc(hmac(sha1),rfc3686(ctr(aes)))",
2308 .cra_driver_name = "safexcel-authenc-hmac-sha1-ctr-aes",
2309 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2310 .cra_flags = CRYPTO_ALG_ASYNC |
2311 CRYPTO_ALG_ALLOCATES_MEMORY |
2312 CRYPTO_ALG_KERN_DRIVER_ONLY,
2314 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2316 .cra_init = safexcel_aead_sha1_ctr_cra_init,
2317 .cra_exit = safexcel_aead_cra_exit,
2318 .cra_module = THIS_MODULE,
2323 static int safexcel_aead_sha256_ctr_cra_init(struct crypto_tfm *tfm)
2325 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2327 safexcel_aead_sha256_cra_init(tfm);
2328 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CTR_LOAD; /* override default */
2332 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha256_ctr_aes = {
2333 .type = SAFEXCEL_ALG_TYPE_AEAD,
2334 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_SHA2_256,
2336 .setkey = safexcel_aead_setkey,
2337 .encrypt = safexcel_aead_encrypt,
2338 .decrypt = safexcel_aead_decrypt,
2339 .ivsize = CTR_RFC3686_IV_SIZE,
2340 .maxauthsize = SHA256_DIGEST_SIZE,
2342 .cra_name = "authenc(hmac(sha256),rfc3686(ctr(aes)))",
2343 .cra_driver_name = "safexcel-authenc-hmac-sha256-ctr-aes",
2344 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2345 .cra_flags = CRYPTO_ALG_ASYNC |
2346 CRYPTO_ALG_ALLOCATES_MEMORY |
2347 CRYPTO_ALG_KERN_DRIVER_ONLY,
2349 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2351 .cra_init = safexcel_aead_sha256_ctr_cra_init,
2352 .cra_exit = safexcel_aead_cra_exit,
2353 .cra_module = THIS_MODULE,
2358 static int safexcel_aead_sha224_ctr_cra_init(struct crypto_tfm *tfm)
2360 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2362 safexcel_aead_sha224_cra_init(tfm);
2363 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CTR_LOAD; /* override default */
2367 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha224_ctr_aes = {
2368 .type = SAFEXCEL_ALG_TYPE_AEAD,
2369 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_SHA2_256,
2371 .setkey = safexcel_aead_setkey,
2372 .encrypt = safexcel_aead_encrypt,
2373 .decrypt = safexcel_aead_decrypt,
2374 .ivsize = CTR_RFC3686_IV_SIZE,
2375 .maxauthsize = SHA224_DIGEST_SIZE,
2377 .cra_name = "authenc(hmac(sha224),rfc3686(ctr(aes)))",
2378 .cra_driver_name = "safexcel-authenc-hmac-sha224-ctr-aes",
2379 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2380 .cra_flags = CRYPTO_ALG_ASYNC |
2381 CRYPTO_ALG_ALLOCATES_MEMORY |
2382 CRYPTO_ALG_KERN_DRIVER_ONLY,
2384 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2386 .cra_init = safexcel_aead_sha224_ctr_cra_init,
2387 .cra_exit = safexcel_aead_cra_exit,
2388 .cra_module = THIS_MODULE,
2393 static int safexcel_aead_sha512_ctr_cra_init(struct crypto_tfm *tfm)
2395 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2397 safexcel_aead_sha512_cra_init(tfm);
2398 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CTR_LOAD; /* override default */
2402 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha512_ctr_aes = {
2403 .type = SAFEXCEL_ALG_TYPE_AEAD,
2404 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_SHA2_512,
2406 .setkey = safexcel_aead_setkey,
2407 .encrypt = safexcel_aead_encrypt,
2408 .decrypt = safexcel_aead_decrypt,
2409 .ivsize = CTR_RFC3686_IV_SIZE,
2410 .maxauthsize = SHA512_DIGEST_SIZE,
2412 .cra_name = "authenc(hmac(sha512),rfc3686(ctr(aes)))",
2413 .cra_driver_name = "safexcel-authenc-hmac-sha512-ctr-aes",
2414 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2415 .cra_flags = CRYPTO_ALG_ASYNC |
2416 CRYPTO_ALG_ALLOCATES_MEMORY |
2417 CRYPTO_ALG_KERN_DRIVER_ONLY,
2419 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2421 .cra_init = safexcel_aead_sha512_ctr_cra_init,
2422 .cra_exit = safexcel_aead_cra_exit,
2423 .cra_module = THIS_MODULE,
2428 static int safexcel_aead_sha384_ctr_cra_init(struct crypto_tfm *tfm)
2430 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2432 safexcel_aead_sha384_cra_init(tfm);
2433 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CTR_LOAD; /* override default */
2437 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha384_ctr_aes = {
2438 .type = SAFEXCEL_ALG_TYPE_AEAD,
2439 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_SHA2_512,
2441 .setkey = safexcel_aead_setkey,
2442 .encrypt = safexcel_aead_encrypt,
2443 .decrypt = safexcel_aead_decrypt,
2444 .ivsize = CTR_RFC3686_IV_SIZE,
2445 .maxauthsize = SHA384_DIGEST_SIZE,
2447 .cra_name = "authenc(hmac(sha384),rfc3686(ctr(aes)))",
2448 .cra_driver_name = "safexcel-authenc-hmac-sha384-ctr-aes",
2449 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2450 .cra_flags = CRYPTO_ALG_ASYNC |
2451 CRYPTO_ALG_ALLOCATES_MEMORY |
2452 CRYPTO_ALG_KERN_DRIVER_ONLY,
2454 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2456 .cra_init = safexcel_aead_sha384_ctr_cra_init,
2457 .cra_exit = safexcel_aead_cra_exit,
2458 .cra_module = THIS_MODULE,
2463 static int safexcel_skcipher_aesxts_setkey(struct crypto_skcipher *ctfm,
2464 const u8 *key, unsigned int len)
2466 struct crypto_tfm *tfm = crypto_skcipher_tfm(ctfm);
2467 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2468 struct safexcel_crypto_priv *priv = ctx->base.priv;
2469 struct crypto_aes_ctx aes;
2471 unsigned int keylen;
2473 /* Check for illegal XTS keys */
2474 ret = xts_verify_key(ctfm, key, len);
2478 /* Only half of the key data is cipher key */
2479 keylen = (len >> 1);
2480 ret = aes_expandkey(&aes, key, keylen);
2484 if (priv->flags & EIP197_TRC_CACHE && ctx->base.ctxr_dma) {
2485 for (i = 0; i < keylen / sizeof(u32); i++) {
2486 if (le32_to_cpu(ctx->key[i]) != aes.key_enc[i]) {
2487 ctx->base.needs_inv = true;
2493 for (i = 0; i < keylen / sizeof(u32); i++)
2494 ctx->key[i] = cpu_to_le32(aes.key_enc[i]);
2496 /* The other half is the tweak key */
2497 ret = aes_expandkey(&aes, (u8 *)(key + keylen), keylen);
2501 if (priv->flags & EIP197_TRC_CACHE && ctx->base.ctxr_dma) {
2502 for (i = 0; i < keylen / sizeof(u32); i++) {
2503 if (le32_to_cpu(ctx->key[i + keylen / sizeof(u32)]) !=
2505 ctx->base.needs_inv = true;
2511 for (i = 0; i < keylen / sizeof(u32); i++)
2512 ctx->key[i + keylen / sizeof(u32)] =
2513 cpu_to_le32(aes.key_enc[i]);
2515 ctx->key_len = keylen << 1;
2517 memzero_explicit(&aes, sizeof(aes));
2521 static int safexcel_skcipher_aes_xts_cra_init(struct crypto_tfm *tfm)
2523 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2525 safexcel_skcipher_cra_init(tfm);
2526 ctx->alg = SAFEXCEL_AES;
2527 ctx->blocksz = AES_BLOCK_SIZE;
2529 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_XTS;
2533 static int safexcel_encrypt_xts(struct skcipher_request *req)
2535 if (req->cryptlen < XTS_BLOCK_SIZE)
2537 return safexcel_queue_req(&req->base, skcipher_request_ctx(req),
2541 static int safexcel_decrypt_xts(struct skcipher_request *req)
2543 if (req->cryptlen < XTS_BLOCK_SIZE)
2545 return safexcel_queue_req(&req->base, skcipher_request_ctx(req),
2549 struct safexcel_alg_template safexcel_alg_xts_aes = {
2550 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
2551 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_AES_XTS,
2553 .setkey = safexcel_skcipher_aesxts_setkey,
2554 .encrypt = safexcel_encrypt_xts,
2555 .decrypt = safexcel_decrypt_xts,
2556 /* XTS actually uses 2 AES keys glued together */
2557 .min_keysize = AES_MIN_KEY_SIZE * 2,
2558 .max_keysize = AES_MAX_KEY_SIZE * 2,
2559 .ivsize = XTS_BLOCK_SIZE,
2561 .cra_name = "xts(aes)",
2562 .cra_driver_name = "safexcel-xts-aes",
2563 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2564 .cra_flags = CRYPTO_ALG_ASYNC |
2565 CRYPTO_ALG_ALLOCATES_MEMORY |
2566 CRYPTO_ALG_KERN_DRIVER_ONLY,
2567 .cra_blocksize = XTS_BLOCK_SIZE,
2568 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2570 .cra_init = safexcel_skcipher_aes_xts_cra_init,
2571 .cra_exit = safexcel_skcipher_cra_exit,
2572 .cra_module = THIS_MODULE,
2577 static int safexcel_aead_gcm_setkey(struct crypto_aead *ctfm, const u8 *key,
2580 struct crypto_tfm *tfm = crypto_aead_tfm(ctfm);
2581 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2582 struct safexcel_crypto_priv *priv = ctx->base.priv;
2583 struct crypto_aes_ctx aes;
2584 u32 hashkey[AES_BLOCK_SIZE >> 2];
2587 ret = aes_expandkey(&aes, key, len);
2589 memzero_explicit(&aes, sizeof(aes));
2593 if (priv->flags & EIP197_TRC_CACHE && ctx->base.ctxr_dma) {
2594 for (i = 0; i < len / sizeof(u32); i++) {
2595 if (le32_to_cpu(ctx->key[i]) != aes.key_enc[i]) {
2596 ctx->base.needs_inv = true;
2602 for (i = 0; i < len / sizeof(u32); i++)
2603 ctx->key[i] = cpu_to_le32(aes.key_enc[i]);
2607 /* Compute hash key by encrypting zeroes with cipher key */
2608 memset(hashkey, 0, AES_BLOCK_SIZE);
2609 aes_encrypt(&aes, (u8 *)hashkey, (u8 *)hashkey);
2611 if (priv->flags & EIP197_TRC_CACHE && ctx->base.ctxr_dma) {
2612 for (i = 0; i < AES_BLOCK_SIZE / sizeof(u32); i++) {
2613 if (be32_to_cpu(ctx->base.ipad.be[i]) != hashkey[i]) {
2614 ctx->base.needs_inv = true;
2620 for (i = 0; i < AES_BLOCK_SIZE / sizeof(u32); i++)
2621 ctx->base.ipad.be[i] = cpu_to_be32(hashkey[i]);
2623 memzero_explicit(hashkey, AES_BLOCK_SIZE);
2624 memzero_explicit(&aes, sizeof(aes));
2628 static int safexcel_aead_gcm_cra_init(struct crypto_tfm *tfm)
2630 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2632 safexcel_aead_cra_init(tfm);
2633 ctx->hash_alg = CONTEXT_CONTROL_CRYPTO_ALG_GHASH;
2634 ctx->state_sz = GHASH_BLOCK_SIZE;
2635 ctx->xcm = EIP197_XCM_MODE_GCM;
2636 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_XCM; /* override default */
2641 static void safexcel_aead_gcm_cra_exit(struct crypto_tfm *tfm)
2643 safexcel_aead_cra_exit(tfm);
2646 static int safexcel_aead_gcm_setauthsize(struct crypto_aead *tfm,
2647 unsigned int authsize)
2649 return crypto_gcm_check_authsize(authsize);
2652 struct safexcel_alg_template safexcel_alg_gcm = {
2653 .type = SAFEXCEL_ALG_TYPE_AEAD,
2654 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_GHASH,
2656 .setkey = safexcel_aead_gcm_setkey,
2657 .setauthsize = safexcel_aead_gcm_setauthsize,
2658 .encrypt = safexcel_aead_encrypt,
2659 .decrypt = safexcel_aead_decrypt,
2660 .ivsize = GCM_AES_IV_SIZE,
2661 .maxauthsize = GHASH_DIGEST_SIZE,
2663 .cra_name = "gcm(aes)",
2664 .cra_driver_name = "safexcel-gcm-aes",
2665 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2666 .cra_flags = CRYPTO_ALG_ASYNC |
2667 CRYPTO_ALG_ALLOCATES_MEMORY |
2668 CRYPTO_ALG_KERN_DRIVER_ONLY,
2670 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2672 .cra_init = safexcel_aead_gcm_cra_init,
2673 .cra_exit = safexcel_aead_gcm_cra_exit,
2674 .cra_module = THIS_MODULE,
2679 static int safexcel_aead_ccm_setkey(struct crypto_aead *ctfm, const u8 *key,
2682 struct crypto_tfm *tfm = crypto_aead_tfm(ctfm);
2683 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2684 struct safexcel_crypto_priv *priv = ctx->base.priv;
2685 struct crypto_aes_ctx aes;
2688 ret = aes_expandkey(&aes, key, len);
2690 memzero_explicit(&aes, sizeof(aes));
2694 if (priv->flags & EIP197_TRC_CACHE && ctx->base.ctxr_dma) {
2695 for (i = 0; i < len / sizeof(u32); i++) {
2696 if (le32_to_cpu(ctx->key[i]) != aes.key_enc[i]) {
2697 ctx->base.needs_inv = true;
2703 for (i = 0; i < len / sizeof(u32); i++) {
2704 ctx->key[i] = cpu_to_le32(aes.key_enc[i]);
2705 ctx->base.ipad.be[i + 2 * AES_BLOCK_SIZE / sizeof(u32)] =
2706 cpu_to_be32(aes.key_enc[i]);
2710 ctx->state_sz = 2 * AES_BLOCK_SIZE + len;
2712 if (len == AES_KEYSIZE_192)
2713 ctx->hash_alg = CONTEXT_CONTROL_CRYPTO_ALG_XCBC192;
2714 else if (len == AES_KEYSIZE_256)
2715 ctx->hash_alg = CONTEXT_CONTROL_CRYPTO_ALG_XCBC256;
2717 ctx->hash_alg = CONTEXT_CONTROL_CRYPTO_ALG_XCBC128;
2719 memzero_explicit(&aes, sizeof(aes));
2723 static int safexcel_aead_ccm_cra_init(struct crypto_tfm *tfm)
2725 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2727 safexcel_aead_cra_init(tfm);
2728 ctx->hash_alg = CONTEXT_CONTROL_CRYPTO_ALG_XCBC128;
2729 ctx->state_sz = 3 * AES_BLOCK_SIZE;
2730 ctx->xcm = EIP197_XCM_MODE_CCM;
2731 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_XCM; /* override default */
2736 static int safexcel_aead_ccm_setauthsize(struct crypto_aead *tfm,
2737 unsigned int authsize)
2739 /* Borrowed from crypto/ccm.c */
2756 static int safexcel_ccm_encrypt(struct aead_request *req)
2758 struct safexcel_cipher_req *creq = aead_request_ctx(req);
2760 if (req->iv[0] < 1 || req->iv[0] > 7)
2763 return safexcel_queue_req(&req->base, creq, SAFEXCEL_ENCRYPT);
2766 static int safexcel_ccm_decrypt(struct aead_request *req)
2768 struct safexcel_cipher_req *creq = aead_request_ctx(req);
2770 if (req->iv[0] < 1 || req->iv[0] > 7)
2773 return safexcel_queue_req(&req->base, creq, SAFEXCEL_DECRYPT);
2776 struct safexcel_alg_template safexcel_alg_ccm = {
2777 .type = SAFEXCEL_ALG_TYPE_AEAD,
2778 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_CBC_MAC_ALL,
2780 .setkey = safexcel_aead_ccm_setkey,
2781 .setauthsize = safexcel_aead_ccm_setauthsize,
2782 .encrypt = safexcel_ccm_encrypt,
2783 .decrypt = safexcel_ccm_decrypt,
2784 .ivsize = AES_BLOCK_SIZE,
2785 .maxauthsize = AES_BLOCK_SIZE,
2787 .cra_name = "ccm(aes)",
2788 .cra_driver_name = "safexcel-ccm-aes",
2789 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2790 .cra_flags = CRYPTO_ALG_ASYNC |
2791 CRYPTO_ALG_ALLOCATES_MEMORY |
2792 CRYPTO_ALG_KERN_DRIVER_ONLY,
2794 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2796 .cra_init = safexcel_aead_ccm_cra_init,
2797 .cra_exit = safexcel_aead_cra_exit,
2798 .cra_module = THIS_MODULE,
2803 static void safexcel_chacha20_setkey(struct safexcel_cipher_ctx *ctx,
2806 struct safexcel_crypto_priv *priv = ctx->base.priv;
2808 if (priv->flags & EIP197_TRC_CACHE && ctx->base.ctxr_dma)
2809 if (memcmp(ctx->key, key, CHACHA_KEY_SIZE))
2810 ctx->base.needs_inv = true;
2812 memcpy(ctx->key, key, CHACHA_KEY_SIZE);
2813 ctx->key_len = CHACHA_KEY_SIZE;
2816 static int safexcel_skcipher_chacha20_setkey(struct crypto_skcipher *ctfm,
2817 const u8 *key, unsigned int len)
2819 struct safexcel_cipher_ctx *ctx = crypto_skcipher_ctx(ctfm);
2821 if (len != CHACHA_KEY_SIZE)
2824 safexcel_chacha20_setkey(ctx, key);
2829 static int safexcel_skcipher_chacha20_cra_init(struct crypto_tfm *tfm)
2831 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2833 safexcel_skcipher_cra_init(tfm);
2834 ctx->alg = SAFEXCEL_CHACHA20;
2836 ctx->mode = CONTEXT_CONTROL_CHACHA20_MODE_256_32;
2840 struct safexcel_alg_template safexcel_alg_chacha20 = {
2841 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
2842 .algo_mask = SAFEXCEL_ALG_CHACHA20,
2844 .setkey = safexcel_skcipher_chacha20_setkey,
2845 .encrypt = safexcel_encrypt,
2846 .decrypt = safexcel_decrypt,
2847 .min_keysize = CHACHA_KEY_SIZE,
2848 .max_keysize = CHACHA_KEY_SIZE,
2849 .ivsize = CHACHA_IV_SIZE,
2851 .cra_name = "chacha20",
2852 .cra_driver_name = "safexcel-chacha20",
2853 .cra_priority = SAFEXCEL_CRA_PRIORITY,
2854 .cra_flags = CRYPTO_ALG_ASYNC |
2855 CRYPTO_ALG_ALLOCATES_MEMORY |
2856 CRYPTO_ALG_KERN_DRIVER_ONLY,
2858 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
2860 .cra_init = safexcel_skcipher_chacha20_cra_init,
2861 .cra_exit = safexcel_skcipher_cra_exit,
2862 .cra_module = THIS_MODULE,
2867 static int safexcel_aead_chachapoly_setkey(struct crypto_aead *ctfm,
2868 const u8 *key, unsigned int len)
2870 struct safexcel_cipher_ctx *ctx = crypto_aead_ctx(ctfm);
2872 if (ctx->aead == EIP197_AEAD_TYPE_IPSEC_ESP &&
2873 len > EIP197_AEAD_IPSEC_NONCE_SIZE) {
2874 /* ESP variant has nonce appended to key */
2875 len -= EIP197_AEAD_IPSEC_NONCE_SIZE;
2876 ctx->nonce = *(u32 *)(key + len);
2878 if (len != CHACHA_KEY_SIZE)
2881 safexcel_chacha20_setkey(ctx, key);
2886 static int safexcel_aead_chachapoly_setauthsize(struct crypto_aead *tfm,
2887 unsigned int authsize)
2889 if (authsize != POLY1305_DIGEST_SIZE)
2894 static int safexcel_aead_chachapoly_crypt(struct aead_request *req,
2895 enum safexcel_cipher_direction dir)
2897 struct safexcel_cipher_req *creq = aead_request_ctx(req);
2898 struct crypto_aead *aead = crypto_aead_reqtfm(req);
2899 struct crypto_tfm *tfm = crypto_aead_tfm(aead);
2900 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2901 struct aead_request *subreq = aead_request_ctx(req);
2902 u32 key[CHACHA_KEY_SIZE / sizeof(u32) + 1];
2906 * Instead of wasting time detecting umpteen silly corner cases,
2907 * just dump all "small" requests to the fallback implementation.
2908 * HW would not be faster on such small requests anyway.
2910 if (likely((ctx->aead != EIP197_AEAD_TYPE_IPSEC_ESP ||
2911 req->assoclen >= EIP197_AEAD_IPSEC_IV_SIZE) &&
2912 req->cryptlen > POLY1305_DIGEST_SIZE)) {
2913 return safexcel_queue_req(&req->base, creq, dir);
2916 /* HW cannot do full (AAD+payload) zero length, use fallback */
2917 memcpy(key, ctx->key, CHACHA_KEY_SIZE);
2918 if (ctx->aead == EIP197_AEAD_TYPE_IPSEC_ESP) {
2919 /* ESP variant has nonce appended to the key */
2920 key[CHACHA_KEY_SIZE / sizeof(u32)] = ctx->nonce;
2921 ret = crypto_aead_setkey(ctx->fback, (u8 *)key,
2923 EIP197_AEAD_IPSEC_NONCE_SIZE);
2925 ret = crypto_aead_setkey(ctx->fback, (u8 *)key,
2929 crypto_aead_clear_flags(aead, CRYPTO_TFM_REQ_MASK);
2930 crypto_aead_set_flags(aead, crypto_aead_get_flags(ctx->fback) &
2931 CRYPTO_TFM_REQ_MASK);
2935 aead_request_set_tfm(subreq, ctx->fback);
2936 aead_request_set_callback(subreq, req->base.flags, req->base.complete,
2938 aead_request_set_crypt(subreq, req->src, req->dst, req->cryptlen,
2940 aead_request_set_ad(subreq, req->assoclen);
2942 return (dir == SAFEXCEL_ENCRYPT) ?
2943 crypto_aead_encrypt(subreq) :
2944 crypto_aead_decrypt(subreq);
2947 static int safexcel_aead_chachapoly_encrypt(struct aead_request *req)
2949 return safexcel_aead_chachapoly_crypt(req, SAFEXCEL_ENCRYPT);
2952 static int safexcel_aead_chachapoly_decrypt(struct aead_request *req)
2954 return safexcel_aead_chachapoly_crypt(req, SAFEXCEL_DECRYPT);
2957 static int safexcel_aead_fallback_cra_init(struct crypto_tfm *tfm)
2959 struct crypto_aead *aead = __crypto_aead_cast(tfm);
2960 struct aead_alg *alg = crypto_aead_alg(aead);
2961 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2963 safexcel_aead_cra_init(tfm);
2965 /* Allocate fallback implementation */
2966 ctx->fback = crypto_alloc_aead(alg->base.cra_name, 0,
2968 CRYPTO_ALG_NEED_FALLBACK);
2969 if (IS_ERR(ctx->fback))
2970 return PTR_ERR(ctx->fback);
2972 crypto_aead_set_reqsize(aead, max(sizeof(struct safexcel_cipher_req),
2973 sizeof(struct aead_request) +
2974 crypto_aead_reqsize(ctx->fback)));
2979 static int safexcel_aead_chachapoly_cra_init(struct crypto_tfm *tfm)
2981 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2983 safexcel_aead_fallback_cra_init(tfm);
2984 ctx->alg = SAFEXCEL_CHACHA20;
2985 ctx->mode = CONTEXT_CONTROL_CHACHA20_MODE_256_32 |
2986 CONTEXT_CONTROL_CHACHA20_MODE_CALC_OTK;
2988 ctx->hash_alg = CONTEXT_CONTROL_CRYPTO_ALG_POLY1305;
2989 ctx->state_sz = 0; /* Precomputed by HW */
2993 static void safexcel_aead_fallback_cra_exit(struct crypto_tfm *tfm)
2995 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
2997 crypto_free_aead(ctx->fback);
2998 safexcel_aead_cra_exit(tfm);
3001 struct safexcel_alg_template safexcel_alg_chachapoly = {
3002 .type = SAFEXCEL_ALG_TYPE_AEAD,
3003 .algo_mask = SAFEXCEL_ALG_CHACHA20 | SAFEXCEL_ALG_POLY1305,
3005 .setkey = safexcel_aead_chachapoly_setkey,
3006 .setauthsize = safexcel_aead_chachapoly_setauthsize,
3007 .encrypt = safexcel_aead_chachapoly_encrypt,
3008 .decrypt = safexcel_aead_chachapoly_decrypt,
3009 .ivsize = CHACHAPOLY_IV_SIZE,
3010 .maxauthsize = POLY1305_DIGEST_SIZE,
3012 .cra_name = "rfc7539(chacha20,poly1305)",
3013 .cra_driver_name = "safexcel-chacha20-poly1305",
3014 /* +1 to put it above HW chacha + SW poly */
3015 .cra_priority = SAFEXCEL_CRA_PRIORITY + 1,
3016 .cra_flags = CRYPTO_ALG_ASYNC |
3017 CRYPTO_ALG_ALLOCATES_MEMORY |
3018 CRYPTO_ALG_KERN_DRIVER_ONLY |
3019 CRYPTO_ALG_NEED_FALLBACK,
3021 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3023 .cra_init = safexcel_aead_chachapoly_cra_init,
3024 .cra_exit = safexcel_aead_fallback_cra_exit,
3025 .cra_module = THIS_MODULE,
3030 static int safexcel_aead_chachapolyesp_cra_init(struct crypto_tfm *tfm)
3032 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3035 ret = safexcel_aead_chachapoly_cra_init(tfm);
3036 ctx->aead = EIP197_AEAD_TYPE_IPSEC_ESP;
3037 ctx->aadskip = EIP197_AEAD_IPSEC_IV_SIZE;
3041 struct safexcel_alg_template safexcel_alg_chachapoly_esp = {
3042 .type = SAFEXCEL_ALG_TYPE_AEAD,
3043 .algo_mask = SAFEXCEL_ALG_CHACHA20 | SAFEXCEL_ALG_POLY1305,
3045 .setkey = safexcel_aead_chachapoly_setkey,
3046 .setauthsize = safexcel_aead_chachapoly_setauthsize,
3047 .encrypt = safexcel_aead_chachapoly_encrypt,
3048 .decrypt = safexcel_aead_chachapoly_decrypt,
3049 .ivsize = CHACHAPOLY_IV_SIZE - EIP197_AEAD_IPSEC_NONCE_SIZE,
3050 .maxauthsize = POLY1305_DIGEST_SIZE,
3052 .cra_name = "rfc7539esp(chacha20,poly1305)",
3053 .cra_driver_name = "safexcel-chacha20-poly1305-esp",
3054 /* +1 to put it above HW chacha + SW poly */
3055 .cra_priority = SAFEXCEL_CRA_PRIORITY + 1,
3056 .cra_flags = CRYPTO_ALG_ASYNC |
3057 CRYPTO_ALG_ALLOCATES_MEMORY |
3058 CRYPTO_ALG_KERN_DRIVER_ONLY |
3059 CRYPTO_ALG_NEED_FALLBACK,
3061 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3063 .cra_init = safexcel_aead_chachapolyesp_cra_init,
3064 .cra_exit = safexcel_aead_fallback_cra_exit,
3065 .cra_module = THIS_MODULE,
3070 static int safexcel_skcipher_sm4_setkey(struct crypto_skcipher *ctfm,
3071 const u8 *key, unsigned int len)
3073 struct crypto_tfm *tfm = crypto_skcipher_tfm(ctfm);
3074 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3075 struct safexcel_crypto_priv *priv = ctx->base.priv;
3077 if (len != SM4_KEY_SIZE)
3080 if (priv->flags & EIP197_TRC_CACHE && ctx->base.ctxr_dma)
3081 if (memcmp(ctx->key, key, SM4_KEY_SIZE))
3082 ctx->base.needs_inv = true;
3084 memcpy(ctx->key, key, SM4_KEY_SIZE);
3085 ctx->key_len = SM4_KEY_SIZE;
3090 static int safexcel_sm4_blk_encrypt(struct skcipher_request *req)
3092 /* Workaround for HW bug: EIP96 4.3 does not report blocksize error */
3093 if (req->cryptlen & (SM4_BLOCK_SIZE - 1))
3096 return safexcel_queue_req(&req->base, skcipher_request_ctx(req),
3100 static int safexcel_sm4_blk_decrypt(struct skcipher_request *req)
3102 /* Workaround for HW bug: EIP96 4.3 does not report blocksize error */
3103 if (req->cryptlen & (SM4_BLOCK_SIZE - 1))
3106 return safexcel_queue_req(&req->base, skcipher_request_ctx(req),
3110 static int safexcel_skcipher_sm4_ecb_cra_init(struct crypto_tfm *tfm)
3112 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3114 safexcel_skcipher_cra_init(tfm);
3115 ctx->alg = SAFEXCEL_SM4;
3116 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_ECB;
3118 ctx->ivmask = EIP197_OPTION_2_TOKEN_IV_CMD;
3122 struct safexcel_alg_template safexcel_alg_ecb_sm4 = {
3123 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
3124 .algo_mask = SAFEXCEL_ALG_SM4,
3126 .setkey = safexcel_skcipher_sm4_setkey,
3127 .encrypt = safexcel_sm4_blk_encrypt,
3128 .decrypt = safexcel_sm4_blk_decrypt,
3129 .min_keysize = SM4_KEY_SIZE,
3130 .max_keysize = SM4_KEY_SIZE,
3132 .cra_name = "ecb(sm4)",
3133 .cra_driver_name = "safexcel-ecb-sm4",
3134 .cra_priority = SAFEXCEL_CRA_PRIORITY,
3135 .cra_flags = CRYPTO_ALG_ASYNC |
3136 CRYPTO_ALG_ALLOCATES_MEMORY |
3137 CRYPTO_ALG_KERN_DRIVER_ONLY,
3138 .cra_blocksize = SM4_BLOCK_SIZE,
3139 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3141 .cra_init = safexcel_skcipher_sm4_ecb_cra_init,
3142 .cra_exit = safexcel_skcipher_cra_exit,
3143 .cra_module = THIS_MODULE,
3148 static int safexcel_skcipher_sm4_cbc_cra_init(struct crypto_tfm *tfm)
3150 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3152 safexcel_skcipher_cra_init(tfm);
3153 ctx->alg = SAFEXCEL_SM4;
3154 ctx->blocksz = SM4_BLOCK_SIZE;
3155 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CBC;
3159 struct safexcel_alg_template safexcel_alg_cbc_sm4 = {
3160 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
3161 .algo_mask = SAFEXCEL_ALG_SM4,
3163 .setkey = safexcel_skcipher_sm4_setkey,
3164 .encrypt = safexcel_sm4_blk_encrypt,
3165 .decrypt = safexcel_sm4_blk_decrypt,
3166 .min_keysize = SM4_KEY_SIZE,
3167 .max_keysize = SM4_KEY_SIZE,
3168 .ivsize = SM4_BLOCK_SIZE,
3170 .cra_name = "cbc(sm4)",
3171 .cra_driver_name = "safexcel-cbc-sm4",
3172 .cra_priority = SAFEXCEL_CRA_PRIORITY,
3173 .cra_flags = CRYPTO_ALG_ASYNC |
3174 CRYPTO_ALG_ALLOCATES_MEMORY |
3175 CRYPTO_ALG_KERN_DRIVER_ONLY,
3176 .cra_blocksize = SM4_BLOCK_SIZE,
3177 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3179 .cra_init = safexcel_skcipher_sm4_cbc_cra_init,
3180 .cra_exit = safexcel_skcipher_cra_exit,
3181 .cra_module = THIS_MODULE,
3186 static int safexcel_skcipher_sm4_ofb_cra_init(struct crypto_tfm *tfm)
3188 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3190 safexcel_skcipher_cra_init(tfm);
3191 ctx->alg = SAFEXCEL_SM4;
3192 ctx->blocksz = SM4_BLOCK_SIZE;
3193 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_OFB;
3197 struct safexcel_alg_template safexcel_alg_ofb_sm4 = {
3198 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
3199 .algo_mask = SAFEXCEL_ALG_SM4 | SAFEXCEL_ALG_AES_XFB,
3201 .setkey = safexcel_skcipher_sm4_setkey,
3202 .encrypt = safexcel_encrypt,
3203 .decrypt = safexcel_decrypt,
3204 .min_keysize = SM4_KEY_SIZE,
3205 .max_keysize = SM4_KEY_SIZE,
3206 .ivsize = SM4_BLOCK_SIZE,
3208 .cra_name = "ofb(sm4)",
3209 .cra_driver_name = "safexcel-ofb-sm4",
3210 .cra_priority = SAFEXCEL_CRA_PRIORITY,
3211 .cra_flags = CRYPTO_ALG_ASYNC |
3212 CRYPTO_ALG_ALLOCATES_MEMORY |
3213 CRYPTO_ALG_KERN_DRIVER_ONLY,
3215 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3217 .cra_init = safexcel_skcipher_sm4_ofb_cra_init,
3218 .cra_exit = safexcel_skcipher_cra_exit,
3219 .cra_module = THIS_MODULE,
3224 static int safexcel_skcipher_sm4_cfb_cra_init(struct crypto_tfm *tfm)
3226 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3228 safexcel_skcipher_cra_init(tfm);
3229 ctx->alg = SAFEXCEL_SM4;
3230 ctx->blocksz = SM4_BLOCK_SIZE;
3231 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CFB;
3235 struct safexcel_alg_template safexcel_alg_cfb_sm4 = {
3236 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
3237 .algo_mask = SAFEXCEL_ALG_SM4 | SAFEXCEL_ALG_AES_XFB,
3239 .setkey = safexcel_skcipher_sm4_setkey,
3240 .encrypt = safexcel_encrypt,
3241 .decrypt = safexcel_decrypt,
3242 .min_keysize = SM4_KEY_SIZE,
3243 .max_keysize = SM4_KEY_SIZE,
3244 .ivsize = SM4_BLOCK_SIZE,
3246 .cra_name = "cfb(sm4)",
3247 .cra_driver_name = "safexcel-cfb-sm4",
3248 .cra_priority = SAFEXCEL_CRA_PRIORITY,
3249 .cra_flags = CRYPTO_ALG_ASYNC |
3250 CRYPTO_ALG_ALLOCATES_MEMORY |
3251 CRYPTO_ALG_KERN_DRIVER_ONLY,
3253 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3255 .cra_init = safexcel_skcipher_sm4_cfb_cra_init,
3256 .cra_exit = safexcel_skcipher_cra_exit,
3257 .cra_module = THIS_MODULE,
3262 static int safexcel_skcipher_sm4ctr_setkey(struct crypto_skcipher *ctfm,
3263 const u8 *key, unsigned int len)
3265 struct crypto_tfm *tfm = crypto_skcipher_tfm(ctfm);
3266 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3268 /* last 4 bytes of key are the nonce! */
3269 ctx->nonce = *(u32 *)(key + len - CTR_RFC3686_NONCE_SIZE);
3270 /* exclude the nonce here */
3271 len -= CTR_RFC3686_NONCE_SIZE;
3273 return safexcel_skcipher_sm4_setkey(ctfm, key, len);
3276 static int safexcel_skcipher_sm4_ctr_cra_init(struct crypto_tfm *tfm)
3278 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3280 safexcel_skcipher_cra_init(tfm);
3281 ctx->alg = SAFEXCEL_SM4;
3282 ctx->blocksz = SM4_BLOCK_SIZE;
3283 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CTR_LOAD;
3287 struct safexcel_alg_template safexcel_alg_ctr_sm4 = {
3288 .type = SAFEXCEL_ALG_TYPE_SKCIPHER,
3289 .algo_mask = SAFEXCEL_ALG_SM4,
3291 .setkey = safexcel_skcipher_sm4ctr_setkey,
3292 .encrypt = safexcel_encrypt,
3293 .decrypt = safexcel_decrypt,
3294 /* Add nonce size */
3295 .min_keysize = SM4_KEY_SIZE + CTR_RFC3686_NONCE_SIZE,
3296 .max_keysize = SM4_KEY_SIZE + CTR_RFC3686_NONCE_SIZE,
3297 .ivsize = CTR_RFC3686_IV_SIZE,
3299 .cra_name = "rfc3686(ctr(sm4))",
3300 .cra_driver_name = "safexcel-ctr-sm4",
3301 .cra_priority = SAFEXCEL_CRA_PRIORITY,
3302 .cra_flags = CRYPTO_ALG_ASYNC |
3303 CRYPTO_ALG_ALLOCATES_MEMORY |
3304 CRYPTO_ALG_KERN_DRIVER_ONLY,
3306 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3308 .cra_init = safexcel_skcipher_sm4_ctr_cra_init,
3309 .cra_exit = safexcel_skcipher_cra_exit,
3310 .cra_module = THIS_MODULE,
3315 static int safexcel_aead_sm4_blk_encrypt(struct aead_request *req)
3317 /* Workaround for HW bug: EIP96 4.3 does not report blocksize error */
3318 if (req->cryptlen & (SM4_BLOCK_SIZE - 1))
3321 return safexcel_queue_req(&req->base, aead_request_ctx(req),
3325 static int safexcel_aead_sm4_blk_decrypt(struct aead_request *req)
3327 struct crypto_aead *tfm = crypto_aead_reqtfm(req);
3329 /* Workaround for HW bug: EIP96 4.3 does not report blocksize error */
3330 if ((req->cryptlen - crypto_aead_authsize(tfm)) & (SM4_BLOCK_SIZE - 1))
3333 return safexcel_queue_req(&req->base, aead_request_ctx(req),
3337 static int safexcel_aead_sm4cbc_sha1_cra_init(struct crypto_tfm *tfm)
3339 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3341 safexcel_aead_cra_init(tfm);
3342 ctx->alg = SAFEXCEL_SM4;
3343 ctx->blocksz = SM4_BLOCK_SIZE;
3344 ctx->hash_alg = CONTEXT_CONTROL_CRYPTO_ALG_SHA1;
3345 ctx->state_sz = SHA1_DIGEST_SIZE;
3349 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha1_cbc_sm4 = {
3350 .type = SAFEXCEL_ALG_TYPE_AEAD,
3351 .algo_mask = SAFEXCEL_ALG_SM4 | SAFEXCEL_ALG_SHA1,
3353 .setkey = safexcel_aead_setkey,
3354 .encrypt = safexcel_aead_sm4_blk_encrypt,
3355 .decrypt = safexcel_aead_sm4_blk_decrypt,
3356 .ivsize = SM4_BLOCK_SIZE,
3357 .maxauthsize = SHA1_DIGEST_SIZE,
3359 .cra_name = "authenc(hmac(sha1),cbc(sm4))",
3360 .cra_driver_name = "safexcel-authenc-hmac-sha1-cbc-sm4",
3361 .cra_priority = SAFEXCEL_CRA_PRIORITY,
3362 .cra_flags = CRYPTO_ALG_ASYNC |
3363 CRYPTO_ALG_ALLOCATES_MEMORY |
3364 CRYPTO_ALG_KERN_DRIVER_ONLY,
3365 .cra_blocksize = SM4_BLOCK_SIZE,
3366 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3368 .cra_init = safexcel_aead_sm4cbc_sha1_cra_init,
3369 .cra_exit = safexcel_aead_cra_exit,
3370 .cra_module = THIS_MODULE,
3375 static int safexcel_aead_fallback_setkey(struct crypto_aead *ctfm,
3376 const u8 *key, unsigned int len)
3378 struct crypto_tfm *tfm = crypto_aead_tfm(ctfm);
3379 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3381 /* Keep fallback cipher synchronized */
3382 return crypto_aead_setkey(ctx->fback, (u8 *)key, len) ?:
3383 safexcel_aead_setkey(ctfm, key, len);
3386 static int safexcel_aead_fallback_setauthsize(struct crypto_aead *ctfm,
3387 unsigned int authsize)
3389 struct crypto_tfm *tfm = crypto_aead_tfm(ctfm);
3390 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3392 /* Keep fallback cipher synchronized */
3393 return crypto_aead_setauthsize(ctx->fback, authsize);
3396 static int safexcel_aead_fallback_crypt(struct aead_request *req,
3397 enum safexcel_cipher_direction dir)
3399 struct crypto_aead *aead = crypto_aead_reqtfm(req);
3400 struct crypto_tfm *tfm = crypto_aead_tfm(aead);
3401 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3402 struct aead_request *subreq = aead_request_ctx(req);
3404 aead_request_set_tfm(subreq, ctx->fback);
3405 aead_request_set_callback(subreq, req->base.flags, req->base.complete,
3407 aead_request_set_crypt(subreq, req->src, req->dst, req->cryptlen,
3409 aead_request_set_ad(subreq, req->assoclen);
3411 return (dir == SAFEXCEL_ENCRYPT) ?
3412 crypto_aead_encrypt(subreq) :
3413 crypto_aead_decrypt(subreq);
3416 static int safexcel_aead_sm4cbc_sm3_encrypt(struct aead_request *req)
3418 struct safexcel_cipher_req *creq = aead_request_ctx(req);
3420 /* Workaround for HW bug: EIP96 4.3 does not report blocksize error */
3421 if (req->cryptlen & (SM4_BLOCK_SIZE - 1))
3423 else if (req->cryptlen || req->assoclen) /* If input length > 0 only */
3424 return safexcel_queue_req(&req->base, creq, SAFEXCEL_ENCRYPT);
3426 /* HW cannot do full (AAD+payload) zero length, use fallback */
3427 return safexcel_aead_fallback_crypt(req, SAFEXCEL_ENCRYPT);
3430 static int safexcel_aead_sm4cbc_sm3_decrypt(struct aead_request *req)
3432 struct safexcel_cipher_req *creq = aead_request_ctx(req);
3433 struct crypto_aead *tfm = crypto_aead_reqtfm(req);
3435 /* Workaround for HW bug: EIP96 4.3 does not report blocksize error */
3436 if ((req->cryptlen - crypto_aead_authsize(tfm)) & (SM4_BLOCK_SIZE - 1))
3438 else if (req->cryptlen > crypto_aead_authsize(tfm) || req->assoclen)
3439 /* If input length > 0 only */
3440 return safexcel_queue_req(&req->base, creq, SAFEXCEL_DECRYPT);
3442 /* HW cannot do full (AAD+payload) zero length, use fallback */
3443 return safexcel_aead_fallback_crypt(req, SAFEXCEL_DECRYPT);
3446 static int safexcel_aead_sm4cbc_sm3_cra_init(struct crypto_tfm *tfm)
3448 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3450 safexcel_aead_fallback_cra_init(tfm);
3451 ctx->alg = SAFEXCEL_SM4;
3452 ctx->blocksz = SM4_BLOCK_SIZE;
3453 ctx->hash_alg = CONTEXT_CONTROL_CRYPTO_ALG_SM3;
3454 ctx->state_sz = SM3_DIGEST_SIZE;
3458 struct safexcel_alg_template safexcel_alg_authenc_hmac_sm3_cbc_sm4 = {
3459 .type = SAFEXCEL_ALG_TYPE_AEAD,
3460 .algo_mask = SAFEXCEL_ALG_SM4 | SAFEXCEL_ALG_SM3,
3462 .setkey = safexcel_aead_fallback_setkey,
3463 .setauthsize = safexcel_aead_fallback_setauthsize,
3464 .encrypt = safexcel_aead_sm4cbc_sm3_encrypt,
3465 .decrypt = safexcel_aead_sm4cbc_sm3_decrypt,
3466 .ivsize = SM4_BLOCK_SIZE,
3467 .maxauthsize = SM3_DIGEST_SIZE,
3469 .cra_name = "authenc(hmac(sm3),cbc(sm4))",
3470 .cra_driver_name = "safexcel-authenc-hmac-sm3-cbc-sm4",
3471 .cra_priority = SAFEXCEL_CRA_PRIORITY,
3472 .cra_flags = CRYPTO_ALG_ASYNC |
3473 CRYPTO_ALG_ALLOCATES_MEMORY |
3474 CRYPTO_ALG_KERN_DRIVER_ONLY |
3475 CRYPTO_ALG_NEED_FALLBACK,
3476 .cra_blocksize = SM4_BLOCK_SIZE,
3477 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3479 .cra_init = safexcel_aead_sm4cbc_sm3_cra_init,
3480 .cra_exit = safexcel_aead_fallback_cra_exit,
3481 .cra_module = THIS_MODULE,
3486 static int safexcel_aead_sm4ctr_sha1_cra_init(struct crypto_tfm *tfm)
3488 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3490 safexcel_aead_sm4cbc_sha1_cra_init(tfm);
3491 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CTR_LOAD;
3495 struct safexcel_alg_template safexcel_alg_authenc_hmac_sha1_ctr_sm4 = {
3496 .type = SAFEXCEL_ALG_TYPE_AEAD,
3497 .algo_mask = SAFEXCEL_ALG_SM4 | SAFEXCEL_ALG_SHA1,
3499 .setkey = safexcel_aead_setkey,
3500 .encrypt = safexcel_aead_encrypt,
3501 .decrypt = safexcel_aead_decrypt,
3502 .ivsize = CTR_RFC3686_IV_SIZE,
3503 .maxauthsize = SHA1_DIGEST_SIZE,
3505 .cra_name = "authenc(hmac(sha1),rfc3686(ctr(sm4)))",
3506 .cra_driver_name = "safexcel-authenc-hmac-sha1-ctr-sm4",
3507 .cra_priority = SAFEXCEL_CRA_PRIORITY,
3508 .cra_flags = CRYPTO_ALG_ASYNC |
3509 CRYPTO_ALG_ALLOCATES_MEMORY |
3510 CRYPTO_ALG_KERN_DRIVER_ONLY,
3512 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3514 .cra_init = safexcel_aead_sm4ctr_sha1_cra_init,
3515 .cra_exit = safexcel_aead_cra_exit,
3516 .cra_module = THIS_MODULE,
3521 static int safexcel_aead_sm4ctr_sm3_cra_init(struct crypto_tfm *tfm)
3523 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3525 safexcel_aead_sm4cbc_sm3_cra_init(tfm);
3526 ctx->mode = CONTEXT_CONTROL_CRYPTO_MODE_CTR_LOAD;
3530 struct safexcel_alg_template safexcel_alg_authenc_hmac_sm3_ctr_sm4 = {
3531 .type = SAFEXCEL_ALG_TYPE_AEAD,
3532 .algo_mask = SAFEXCEL_ALG_SM4 | SAFEXCEL_ALG_SM3,
3534 .setkey = safexcel_aead_setkey,
3535 .encrypt = safexcel_aead_encrypt,
3536 .decrypt = safexcel_aead_decrypt,
3537 .ivsize = CTR_RFC3686_IV_SIZE,
3538 .maxauthsize = SM3_DIGEST_SIZE,
3540 .cra_name = "authenc(hmac(sm3),rfc3686(ctr(sm4)))",
3541 .cra_driver_name = "safexcel-authenc-hmac-sm3-ctr-sm4",
3542 .cra_priority = SAFEXCEL_CRA_PRIORITY,
3543 .cra_flags = CRYPTO_ALG_ASYNC |
3544 CRYPTO_ALG_ALLOCATES_MEMORY |
3545 CRYPTO_ALG_KERN_DRIVER_ONLY,
3547 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3549 .cra_init = safexcel_aead_sm4ctr_sm3_cra_init,
3550 .cra_exit = safexcel_aead_cra_exit,
3551 .cra_module = THIS_MODULE,
3556 static int safexcel_rfc4106_gcm_setkey(struct crypto_aead *ctfm, const u8 *key,
3559 struct crypto_tfm *tfm = crypto_aead_tfm(ctfm);
3560 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3562 /* last 4 bytes of key are the nonce! */
3563 ctx->nonce = *(u32 *)(key + len - CTR_RFC3686_NONCE_SIZE);
3565 len -= CTR_RFC3686_NONCE_SIZE;
3566 return safexcel_aead_gcm_setkey(ctfm, key, len);
3569 static int safexcel_rfc4106_gcm_setauthsize(struct crypto_aead *tfm,
3570 unsigned int authsize)
3572 return crypto_rfc4106_check_authsize(authsize);
3575 static int safexcel_rfc4106_encrypt(struct aead_request *req)
3577 return crypto_ipsec_check_assoclen(req->assoclen) ?:
3578 safexcel_aead_encrypt(req);
3581 static int safexcel_rfc4106_decrypt(struct aead_request *req)
3583 return crypto_ipsec_check_assoclen(req->assoclen) ?:
3584 safexcel_aead_decrypt(req);
3587 static int safexcel_rfc4106_gcm_cra_init(struct crypto_tfm *tfm)
3589 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3592 ret = safexcel_aead_gcm_cra_init(tfm);
3593 ctx->aead = EIP197_AEAD_TYPE_IPSEC_ESP;
3594 ctx->aadskip = EIP197_AEAD_IPSEC_IV_SIZE;
3598 struct safexcel_alg_template safexcel_alg_rfc4106_gcm = {
3599 .type = SAFEXCEL_ALG_TYPE_AEAD,
3600 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_GHASH,
3602 .setkey = safexcel_rfc4106_gcm_setkey,
3603 .setauthsize = safexcel_rfc4106_gcm_setauthsize,
3604 .encrypt = safexcel_rfc4106_encrypt,
3605 .decrypt = safexcel_rfc4106_decrypt,
3606 .ivsize = GCM_RFC4106_IV_SIZE,
3607 .maxauthsize = GHASH_DIGEST_SIZE,
3609 .cra_name = "rfc4106(gcm(aes))",
3610 .cra_driver_name = "safexcel-rfc4106-gcm-aes",
3611 .cra_priority = SAFEXCEL_CRA_PRIORITY,
3612 .cra_flags = CRYPTO_ALG_ASYNC |
3613 CRYPTO_ALG_ALLOCATES_MEMORY |
3614 CRYPTO_ALG_KERN_DRIVER_ONLY,
3616 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3618 .cra_init = safexcel_rfc4106_gcm_cra_init,
3619 .cra_exit = safexcel_aead_gcm_cra_exit,
3624 static int safexcel_rfc4543_gcm_setauthsize(struct crypto_aead *tfm,
3625 unsigned int authsize)
3627 if (authsize != GHASH_DIGEST_SIZE)
3633 static int safexcel_rfc4543_gcm_cra_init(struct crypto_tfm *tfm)
3635 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3638 ret = safexcel_aead_gcm_cra_init(tfm);
3639 ctx->aead = EIP197_AEAD_TYPE_IPSEC_ESP_GMAC;
3643 struct safexcel_alg_template safexcel_alg_rfc4543_gcm = {
3644 .type = SAFEXCEL_ALG_TYPE_AEAD,
3645 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_GHASH,
3647 .setkey = safexcel_rfc4106_gcm_setkey,
3648 .setauthsize = safexcel_rfc4543_gcm_setauthsize,
3649 .encrypt = safexcel_rfc4106_encrypt,
3650 .decrypt = safexcel_rfc4106_decrypt,
3651 .ivsize = GCM_RFC4543_IV_SIZE,
3652 .maxauthsize = GHASH_DIGEST_SIZE,
3654 .cra_name = "rfc4543(gcm(aes))",
3655 .cra_driver_name = "safexcel-rfc4543-gcm-aes",
3656 .cra_priority = SAFEXCEL_CRA_PRIORITY,
3657 .cra_flags = CRYPTO_ALG_ASYNC |
3658 CRYPTO_ALG_ALLOCATES_MEMORY |
3659 CRYPTO_ALG_KERN_DRIVER_ONLY,
3661 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3663 .cra_init = safexcel_rfc4543_gcm_cra_init,
3664 .cra_exit = safexcel_aead_gcm_cra_exit,
3669 static int safexcel_rfc4309_ccm_setkey(struct crypto_aead *ctfm, const u8 *key,
3672 struct crypto_tfm *tfm = crypto_aead_tfm(ctfm);
3673 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3675 /* First byte of the nonce = L = always 3 for RFC4309 (4 byte ctr) */
3676 *(u8 *)&ctx->nonce = EIP197_AEAD_IPSEC_COUNTER_SIZE - 1;
3677 /* last 3 bytes of key are the nonce! */
3678 memcpy((u8 *)&ctx->nonce + 1, key + len -
3679 EIP197_AEAD_IPSEC_CCM_NONCE_SIZE,
3680 EIP197_AEAD_IPSEC_CCM_NONCE_SIZE);
3682 len -= EIP197_AEAD_IPSEC_CCM_NONCE_SIZE;
3683 return safexcel_aead_ccm_setkey(ctfm, key, len);
3686 static int safexcel_rfc4309_ccm_setauthsize(struct crypto_aead *tfm,
3687 unsigned int authsize)
3689 /* Borrowed from crypto/ccm.c */
3702 static int safexcel_rfc4309_ccm_encrypt(struct aead_request *req)
3704 struct safexcel_cipher_req *creq = aead_request_ctx(req);
3706 /* Borrowed from crypto/ccm.c */
3707 if (req->assoclen != 16 && req->assoclen != 20)
3710 return safexcel_queue_req(&req->base, creq, SAFEXCEL_ENCRYPT);
3713 static int safexcel_rfc4309_ccm_decrypt(struct aead_request *req)
3715 struct safexcel_cipher_req *creq = aead_request_ctx(req);
3717 /* Borrowed from crypto/ccm.c */
3718 if (req->assoclen != 16 && req->assoclen != 20)
3721 return safexcel_queue_req(&req->base, creq, SAFEXCEL_DECRYPT);
3724 static int safexcel_rfc4309_ccm_cra_init(struct crypto_tfm *tfm)
3726 struct safexcel_cipher_ctx *ctx = crypto_tfm_ctx(tfm);
3729 ret = safexcel_aead_ccm_cra_init(tfm);
3730 ctx->aead = EIP197_AEAD_TYPE_IPSEC_ESP;
3731 ctx->aadskip = EIP197_AEAD_IPSEC_IV_SIZE;
3735 struct safexcel_alg_template safexcel_alg_rfc4309_ccm = {
3736 .type = SAFEXCEL_ALG_TYPE_AEAD,
3737 .algo_mask = SAFEXCEL_ALG_AES | SAFEXCEL_ALG_CBC_MAC_ALL,
3739 .setkey = safexcel_rfc4309_ccm_setkey,
3740 .setauthsize = safexcel_rfc4309_ccm_setauthsize,
3741 .encrypt = safexcel_rfc4309_ccm_encrypt,
3742 .decrypt = safexcel_rfc4309_ccm_decrypt,
3743 .ivsize = EIP197_AEAD_IPSEC_IV_SIZE,
3744 .maxauthsize = AES_BLOCK_SIZE,
3746 .cra_name = "rfc4309(ccm(aes))",
3747 .cra_driver_name = "safexcel-rfc4309-ccm-aes",
3748 .cra_priority = SAFEXCEL_CRA_PRIORITY,
3749 .cra_flags = CRYPTO_ALG_ASYNC |
3750 CRYPTO_ALG_ALLOCATES_MEMORY |
3751 CRYPTO_ALG_KERN_DRIVER_ONLY,
3753 .cra_ctxsize = sizeof(struct safexcel_cipher_ctx),
3755 .cra_init = safexcel_rfc4309_ccm_cra_init,
3756 .cra_exit = safexcel_aead_cra_exit,
3757 .cra_module = THIS_MODULE,