xref: /linux/drivers/crypto/axis/artpec6_crypto.c (revision e9f0878c4b2004ac19581274c1ae4c61ae3ca70e)
1 /*
2  *   Driver for ARTPEC-6 crypto block using the kernel asynchronous crypto api.
3  *
4  *    Copyright (C) 2014-2017  Axis Communications AB
5  */
6 #define pr_fmt(fmt)     KBUILD_MODNAME ": " fmt
7 
8 #include <linux/bitfield.h>
9 #include <linux/crypto.h>
10 #include <linux/debugfs.h>
11 #include <linux/delay.h>
12 #include <linux/dma-mapping.h>
13 #include <linux/fault-inject.h>
14 #include <linux/init.h>
15 #include <linux/interrupt.h>
16 #include <linux/kernel.h>
17 #include <linux/list.h>
18 #include <linux/module.h>
19 #include <linux/of.h>
20 #include <linux/platform_device.h>
21 #include <linux/scatterlist.h>
22 #include <linux/slab.h>
23 
24 #include <crypto/aes.h>
25 #include <crypto/gcm.h>
26 #include <crypto/internal/aead.h>
27 #include <crypto/internal/hash.h>
28 #include <crypto/internal/skcipher.h>
29 #include <crypto/scatterwalk.h>
30 #include <crypto/sha.h>
31 #include <crypto/xts.h>
32 
33 /* Max length of a line in all cache levels for Artpec SoCs. */
34 #define ARTPEC_CACHE_LINE_MAX	32
35 
36 #define PDMA_OUT_CFG		0x0000
37 #define PDMA_OUT_BUF_CFG	0x0004
38 #define PDMA_OUT_CMD		0x0008
39 #define PDMA_OUT_DESCRQ_PUSH	0x0010
40 #define PDMA_OUT_DESCRQ_STAT	0x0014
41 
42 #define A6_PDMA_IN_CFG		0x0028
43 #define A6_PDMA_IN_BUF_CFG	0x002c
44 #define A6_PDMA_IN_CMD		0x0030
45 #define A6_PDMA_IN_STATQ_PUSH	0x0038
46 #define A6_PDMA_IN_DESCRQ_PUSH	0x0044
47 #define A6_PDMA_IN_DESCRQ_STAT	0x0048
48 #define A6_PDMA_INTR_MASK	0x0068
49 #define A6_PDMA_ACK_INTR	0x006c
50 #define A6_PDMA_MASKED_INTR	0x0074
51 
52 #define A7_PDMA_IN_CFG		0x002c
53 #define A7_PDMA_IN_BUF_CFG	0x0030
54 #define A7_PDMA_IN_CMD		0x0034
55 #define A7_PDMA_IN_STATQ_PUSH	0x003c
56 #define A7_PDMA_IN_DESCRQ_PUSH	0x0048
57 #define A7_PDMA_IN_DESCRQ_STAT	0x004C
58 #define A7_PDMA_INTR_MASK	0x006c
59 #define A7_PDMA_ACK_INTR	0x0070
60 #define A7_PDMA_MASKED_INTR	0x0078
61 
62 #define PDMA_OUT_CFG_EN				BIT(0)
63 
64 #define PDMA_OUT_BUF_CFG_DATA_BUF_SIZE		GENMASK(4, 0)
65 #define PDMA_OUT_BUF_CFG_DESCR_BUF_SIZE		GENMASK(9, 5)
66 
67 #define PDMA_OUT_CMD_START			BIT(0)
68 #define A6_PDMA_OUT_CMD_STOP			BIT(3)
69 #define A7_PDMA_OUT_CMD_STOP			BIT(2)
70 
71 #define PDMA_OUT_DESCRQ_PUSH_LEN		GENMASK(5, 0)
72 #define PDMA_OUT_DESCRQ_PUSH_ADDR		GENMASK(31, 6)
73 
74 #define PDMA_OUT_DESCRQ_STAT_LEVEL		GENMASK(3, 0)
75 #define PDMA_OUT_DESCRQ_STAT_SIZE		GENMASK(7, 4)
76 
77 #define PDMA_IN_CFG_EN				BIT(0)
78 
79 #define PDMA_IN_BUF_CFG_DATA_BUF_SIZE		GENMASK(4, 0)
80 #define PDMA_IN_BUF_CFG_DESCR_BUF_SIZE		GENMASK(9, 5)
81 #define PDMA_IN_BUF_CFG_STAT_BUF_SIZE		GENMASK(14, 10)
82 
83 #define PDMA_IN_CMD_START			BIT(0)
84 #define A6_PDMA_IN_CMD_FLUSH_STAT		BIT(2)
85 #define A6_PDMA_IN_CMD_STOP			BIT(3)
86 #define A7_PDMA_IN_CMD_FLUSH_STAT		BIT(1)
87 #define A7_PDMA_IN_CMD_STOP			BIT(2)
88 
89 #define PDMA_IN_STATQ_PUSH_LEN			GENMASK(5, 0)
90 #define PDMA_IN_STATQ_PUSH_ADDR			GENMASK(31, 6)
91 
92 #define PDMA_IN_DESCRQ_PUSH_LEN			GENMASK(5, 0)
93 #define PDMA_IN_DESCRQ_PUSH_ADDR		GENMASK(31, 6)
94 
95 #define PDMA_IN_DESCRQ_STAT_LEVEL		GENMASK(3, 0)
96 #define PDMA_IN_DESCRQ_STAT_SIZE		GENMASK(7, 4)
97 
98 #define A6_PDMA_INTR_MASK_IN_DATA		BIT(2)
99 #define A6_PDMA_INTR_MASK_IN_EOP		BIT(3)
100 #define A6_PDMA_INTR_MASK_IN_EOP_FLUSH		BIT(4)
101 
102 #define A7_PDMA_INTR_MASK_IN_DATA		BIT(3)
103 #define A7_PDMA_INTR_MASK_IN_EOP		BIT(4)
104 #define A7_PDMA_INTR_MASK_IN_EOP_FLUSH		BIT(5)
105 
106 #define A6_CRY_MD_OPER		GENMASK(19, 16)
107 
108 #define A6_CRY_MD_HASH_SEL_CTX	GENMASK(21, 20)
109 #define A6_CRY_MD_HASH_HMAC_FIN	BIT(23)
110 
111 #define A6_CRY_MD_CIPHER_LEN	GENMASK(21, 20)
112 #define A6_CRY_MD_CIPHER_DECR	BIT(22)
113 #define A6_CRY_MD_CIPHER_TWEAK	BIT(23)
114 #define A6_CRY_MD_CIPHER_DSEQ	BIT(24)
115 
116 #define A7_CRY_MD_OPER		GENMASK(11, 8)
117 
118 #define A7_CRY_MD_HASH_SEL_CTX	GENMASK(13, 12)
119 #define A7_CRY_MD_HASH_HMAC_FIN	BIT(15)
120 
121 #define A7_CRY_MD_CIPHER_LEN	GENMASK(13, 12)
122 #define A7_CRY_MD_CIPHER_DECR	BIT(14)
123 #define A7_CRY_MD_CIPHER_TWEAK	BIT(15)
124 #define A7_CRY_MD_CIPHER_DSEQ	BIT(16)
125 
126 /* DMA metadata constants */
127 #define regk_crypto_aes_cbc     0x00000002
128 #define regk_crypto_aes_ctr     0x00000003
129 #define regk_crypto_aes_ecb     0x00000001
130 #define regk_crypto_aes_gcm     0x00000004
131 #define regk_crypto_aes_xts     0x00000005
132 #define regk_crypto_cache       0x00000002
133 #define a6_regk_crypto_dlkey    0x0000000a
134 #define a7_regk_crypto_dlkey    0x0000000e
135 #define regk_crypto_ext         0x00000001
136 #define regk_crypto_hmac_sha1   0x00000007
137 #define regk_crypto_hmac_sha256 0x00000009
138 #define regk_crypto_hmac_sha384 0x0000000b
139 #define regk_crypto_hmac_sha512 0x0000000d
140 #define regk_crypto_init        0x00000000
141 #define regk_crypto_key_128     0x00000000
142 #define regk_crypto_key_192     0x00000001
143 #define regk_crypto_key_256     0x00000002
144 #define regk_crypto_null        0x00000000
145 #define regk_crypto_sha1        0x00000006
146 #define regk_crypto_sha256      0x00000008
147 #define regk_crypto_sha384      0x0000000a
148 #define regk_crypto_sha512      0x0000000c
149 
150 /* DMA descriptor structures */
151 struct pdma_descr_ctrl  {
152 	unsigned char short_descr : 1;
153 	unsigned char pad1        : 1;
154 	unsigned char eop         : 1;
155 	unsigned char intr        : 1;
156 	unsigned char short_len   : 3;
157 	unsigned char pad2        : 1;
158 } __packed;
159 
160 struct pdma_data_descr {
161 	unsigned int len : 24;
162 	unsigned int buf : 32;
163 } __packed;
164 
165 struct pdma_short_descr {
166 	unsigned char data[7];
167 } __packed;
168 
169 struct pdma_descr {
170 	struct pdma_descr_ctrl ctrl;
171 	union {
172 		struct pdma_data_descr   data;
173 		struct pdma_short_descr  shrt;
174 	};
175 };
176 
177 struct pdma_stat_descr {
178 	unsigned char pad1        : 1;
179 	unsigned char pad2        : 1;
180 	unsigned char eop         : 1;
181 	unsigned char pad3        : 5;
182 	unsigned int  len         : 24;
183 };
184 
185 /* Each descriptor array can hold max 64 entries */
186 #define PDMA_DESCR_COUNT	64
187 
188 #define MODULE_NAME   "Artpec-6 CA"
189 
190 /* Hash modes (including HMAC variants) */
191 #define ARTPEC6_CRYPTO_HASH_SHA1	1
192 #define ARTPEC6_CRYPTO_HASH_SHA256	2
193 #define ARTPEC6_CRYPTO_HASH_SHA384	3
194 #define ARTPEC6_CRYPTO_HASH_SHA512	4
195 
196 /* Crypto modes */
197 #define ARTPEC6_CRYPTO_CIPHER_AES_ECB	1
198 #define ARTPEC6_CRYPTO_CIPHER_AES_CBC	2
199 #define ARTPEC6_CRYPTO_CIPHER_AES_CTR	3
200 #define ARTPEC6_CRYPTO_CIPHER_AES_XTS	5
201 
202 /* The PDMA is a DMA-engine tightly coupled with a ciphering engine.
203  * It operates on a descriptor array with up to 64 descriptor entries.
204  * The arrays must be 64 byte aligned in memory.
205  *
206  * The ciphering unit has no registers and is completely controlled by
207  * a 4-byte metadata that is inserted at the beginning of each dma packet.
208  *
209  * A dma packet is a sequence of descriptors terminated by setting the .eop
210  * field in the final descriptor of the packet.
211  *
212  * Multiple packets are used for providing context data, key data and
213  * the plain/ciphertext.
214  *
215  *   PDMA Descriptors (Array)
216  *  +------+------+------+~~+-------+------+----
217  *  |  0   |  1   |  2   |~~| 11 EOP|  12  |  ....
218  *  +--+---+--+---+----+-+~~+-------+----+-+----
219  *     |      |        |       |         |
220  *     |      |        |       |         |
221  *   __|__  +-------++-------++-------+ +----+
222  *  | MD  | |Payload||Payload||Payload| | MD |
223  *  +-----+ +-------++-------++-------+ +----+
224  */
225 
226 struct artpec6_crypto_bounce_buffer {
227 	struct list_head list;
228 	size_t length;
229 	struct scatterlist *sg;
230 	size_t offset;
231 	/* buf is aligned to ARTPEC_CACHE_LINE_MAX and
232 	 * holds up to ARTPEC_CACHE_LINE_MAX bytes data.
233 	 */
234 	void *buf;
235 };
236 
237 struct artpec6_crypto_dma_map {
238 	dma_addr_t dma_addr;
239 	size_t size;
240 	enum dma_data_direction dir;
241 };
242 
243 struct artpec6_crypto_dma_descriptors {
244 	struct pdma_descr out[PDMA_DESCR_COUNT] __aligned(64);
245 	struct pdma_descr in[PDMA_DESCR_COUNT] __aligned(64);
246 	u32 stat[PDMA_DESCR_COUNT] __aligned(64);
247 	struct list_head bounce_buffers;
248 	/* Enough maps for all out/in buffers, and all three descr. arrays */
249 	struct artpec6_crypto_dma_map maps[PDMA_DESCR_COUNT * 2 + 2];
250 	dma_addr_t out_dma_addr;
251 	dma_addr_t in_dma_addr;
252 	dma_addr_t stat_dma_addr;
253 	size_t out_cnt;
254 	size_t in_cnt;
255 	size_t map_count;
256 };
257 
258 enum artpec6_crypto_variant {
259 	ARTPEC6_CRYPTO,
260 	ARTPEC7_CRYPTO,
261 };
262 
263 struct artpec6_crypto {
264 	void __iomem *base;
265 	spinlock_t queue_lock;
266 	struct list_head queue; /* waiting for pdma fifo space */
267 	struct list_head pending; /* submitted to pdma fifo */
268 	struct tasklet_struct task;
269 	struct kmem_cache *dma_cache;
270 	int pending_count;
271 	struct timer_list timer;
272 	enum artpec6_crypto_variant variant;
273 	void *pad_buffer; /* cache-aligned block padding buffer */
274 	void *zero_buffer;
275 };
276 
277 enum artpec6_crypto_hash_flags {
278 	HASH_FLAG_INIT_CTX = 2,
279 	HASH_FLAG_UPDATE = 4,
280 	HASH_FLAG_FINALIZE = 8,
281 	HASH_FLAG_HMAC = 16,
282 	HASH_FLAG_UPDATE_KEY = 32,
283 };
284 
285 struct artpec6_crypto_req_common {
286 	struct list_head list;
287 	struct artpec6_crypto_dma_descriptors *dma;
288 	struct crypto_async_request *req;
289 	void (*complete)(struct crypto_async_request *req);
290 	gfp_t gfp_flags;
291 };
292 
293 struct artpec6_hash_request_context {
294 	char partial_buffer[SHA512_BLOCK_SIZE];
295 	char partial_buffer_out[SHA512_BLOCK_SIZE];
296 	char key_buffer[SHA512_BLOCK_SIZE];
297 	char pad_buffer[SHA512_BLOCK_SIZE + 32];
298 	unsigned char digeststate[SHA512_DIGEST_SIZE];
299 	size_t partial_bytes;
300 	u64 digcnt;
301 	u32 key_md;
302 	u32 hash_md;
303 	enum artpec6_crypto_hash_flags hash_flags;
304 	struct artpec6_crypto_req_common common;
305 };
306 
307 struct artpec6_hash_export_state {
308 	char partial_buffer[SHA512_BLOCK_SIZE];
309 	unsigned char digeststate[SHA512_DIGEST_SIZE];
310 	size_t partial_bytes;
311 	u64 digcnt;
312 	int oper;
313 	unsigned int hash_flags;
314 };
315 
316 struct artpec6_hashalg_context {
317 	char hmac_key[SHA512_BLOCK_SIZE];
318 	size_t hmac_key_length;
319 	struct crypto_shash *child_hash;
320 };
321 
322 struct artpec6_crypto_request_context {
323 	u32 cipher_md;
324 	bool decrypt;
325 	struct artpec6_crypto_req_common common;
326 };
327 
328 struct artpec6_cryptotfm_context {
329 	unsigned char aes_key[2*AES_MAX_KEY_SIZE];
330 	size_t key_length;
331 	u32 key_md;
332 	int crypto_type;
333 	struct crypto_skcipher *fallback;
334 };
335 
336 struct artpec6_crypto_aead_hw_ctx {
337 	__be64	aad_length_bits;
338 	__be64  text_length_bits;
339 	__u8	J0[AES_BLOCK_SIZE];
340 };
341 
342 struct artpec6_crypto_aead_req_ctx {
343 	struct artpec6_crypto_aead_hw_ctx hw_ctx;
344 	u32 cipher_md;
345 	bool decrypt;
346 	struct artpec6_crypto_req_common common;
347 	__u8 decryption_tag[AES_BLOCK_SIZE] ____cacheline_aligned;
348 };
349 
350 /* The crypto framework makes it hard to avoid this global. */
351 static struct device *artpec6_crypto_dev;
352 
353 #ifdef CONFIG_FAULT_INJECTION
354 static DECLARE_FAULT_ATTR(artpec6_crypto_fail_status_read);
355 static DECLARE_FAULT_ATTR(artpec6_crypto_fail_dma_array_full);
356 #endif
357 
358 enum {
359 	ARTPEC6_CRYPTO_PREPARE_HASH_NO_START,
360 	ARTPEC6_CRYPTO_PREPARE_HASH_START,
361 };
362 
363 static int artpec6_crypto_prepare_aead(struct aead_request *areq);
364 static int artpec6_crypto_prepare_crypto(struct skcipher_request *areq);
365 static int artpec6_crypto_prepare_hash(struct ahash_request *areq);
366 
367 static void
368 artpec6_crypto_complete_crypto(struct crypto_async_request *req);
369 static void
370 artpec6_crypto_complete_cbc_encrypt(struct crypto_async_request *req);
371 static void
372 artpec6_crypto_complete_cbc_decrypt(struct crypto_async_request *req);
373 static void
374 artpec6_crypto_complete_aead(struct crypto_async_request *req);
375 static void
376 artpec6_crypto_complete_hash(struct crypto_async_request *req);
377 
378 static int
379 artpec6_crypto_common_destroy(struct artpec6_crypto_req_common *common);
380 
381 static void
382 artpec6_crypto_start_dma(struct artpec6_crypto_req_common *common);
383 
384 struct artpec6_crypto_walk {
385 	struct scatterlist *sg;
386 	size_t offset;
387 };
388 
389 static void artpec6_crypto_walk_init(struct artpec6_crypto_walk *awalk,
390 				     struct scatterlist *sg)
391 {
392 	awalk->sg = sg;
393 	awalk->offset = 0;
394 }
395 
396 static size_t artpec6_crypto_walk_advance(struct artpec6_crypto_walk *awalk,
397 					  size_t nbytes)
398 {
399 	while (nbytes && awalk->sg) {
400 		size_t piece;
401 
402 		WARN_ON(awalk->offset > awalk->sg->length);
403 
404 		piece = min(nbytes, (size_t)awalk->sg->length - awalk->offset);
405 		nbytes -= piece;
406 		awalk->offset += piece;
407 		if (awalk->offset == awalk->sg->length) {
408 			awalk->sg = sg_next(awalk->sg);
409 			awalk->offset = 0;
410 		}
411 
412 	}
413 
414 	return nbytes;
415 }
416 
417 static size_t
418 artpec6_crypto_walk_chunklen(const struct artpec6_crypto_walk *awalk)
419 {
420 	WARN_ON(awalk->sg->length == awalk->offset);
421 
422 	return awalk->sg->length - awalk->offset;
423 }
424 
425 static dma_addr_t
426 artpec6_crypto_walk_chunk_phys(const struct artpec6_crypto_walk *awalk)
427 {
428 	return sg_phys(awalk->sg) + awalk->offset;
429 }
430 
431 static void
432 artpec6_crypto_copy_bounce_buffers(struct artpec6_crypto_req_common *common)
433 {
434 	struct artpec6_crypto_dma_descriptors *dma = common->dma;
435 	struct artpec6_crypto_bounce_buffer *b;
436 	struct artpec6_crypto_bounce_buffer *next;
437 
438 	list_for_each_entry_safe(b, next, &dma->bounce_buffers, list) {
439 		pr_debug("bounce entry %p: %zu bytes @ %zu from %p\n",
440 			 b, b->length, b->offset, b->buf);
441 		sg_pcopy_from_buffer(b->sg,
442 				   1,
443 				   b->buf,
444 				   b->length,
445 				   b->offset);
446 
447 		list_del(&b->list);
448 		kfree(b);
449 	}
450 }
451 
452 static inline bool artpec6_crypto_busy(void)
453 {
454 	struct artpec6_crypto *ac = dev_get_drvdata(artpec6_crypto_dev);
455 	int fifo_count = ac->pending_count;
456 
457 	return fifo_count > 6;
458 }
459 
460 static int artpec6_crypto_submit(struct artpec6_crypto_req_common *req)
461 {
462 	struct artpec6_crypto *ac = dev_get_drvdata(artpec6_crypto_dev);
463 	int ret = -EBUSY;
464 
465 	spin_lock_bh(&ac->queue_lock);
466 
467 	if (!artpec6_crypto_busy()) {
468 		list_add_tail(&req->list, &ac->pending);
469 		artpec6_crypto_start_dma(req);
470 		ret = -EINPROGRESS;
471 	} else if (req->req->flags & CRYPTO_TFM_REQ_MAY_BACKLOG) {
472 		list_add_tail(&req->list, &ac->queue);
473 	} else {
474 		artpec6_crypto_common_destroy(req);
475 	}
476 
477 	spin_unlock_bh(&ac->queue_lock);
478 
479 	return ret;
480 }
481 
482 static void artpec6_crypto_start_dma(struct artpec6_crypto_req_common *common)
483 {
484 	struct artpec6_crypto *ac = dev_get_drvdata(artpec6_crypto_dev);
485 	enum artpec6_crypto_variant variant = ac->variant;
486 	void __iomem *base = ac->base;
487 	struct artpec6_crypto_dma_descriptors *dma = common->dma;
488 	u32 ind, statd, outd;
489 
490 	/* Make descriptor content visible to the DMA before starting it. */
491 	wmb();
492 
493 	ind = FIELD_PREP(PDMA_IN_DESCRQ_PUSH_LEN, dma->in_cnt - 1) |
494 	      FIELD_PREP(PDMA_IN_DESCRQ_PUSH_ADDR, dma->in_dma_addr >> 6);
495 
496 	statd = FIELD_PREP(PDMA_IN_STATQ_PUSH_LEN, dma->in_cnt - 1) |
497 		FIELD_PREP(PDMA_IN_STATQ_PUSH_ADDR, dma->stat_dma_addr >> 6);
498 
499 	outd = FIELD_PREP(PDMA_OUT_DESCRQ_PUSH_LEN, dma->out_cnt - 1) |
500 	       FIELD_PREP(PDMA_OUT_DESCRQ_PUSH_ADDR, dma->out_dma_addr >> 6);
501 
502 	if (variant == ARTPEC6_CRYPTO) {
503 		writel_relaxed(ind, base + A6_PDMA_IN_DESCRQ_PUSH);
504 		writel_relaxed(statd, base + A6_PDMA_IN_STATQ_PUSH);
505 		writel_relaxed(PDMA_IN_CMD_START, base + A6_PDMA_IN_CMD);
506 	} else {
507 		writel_relaxed(ind, base + A7_PDMA_IN_DESCRQ_PUSH);
508 		writel_relaxed(statd, base + A7_PDMA_IN_STATQ_PUSH);
509 		writel_relaxed(PDMA_IN_CMD_START, base + A7_PDMA_IN_CMD);
510 	}
511 
512 	writel_relaxed(outd, base + PDMA_OUT_DESCRQ_PUSH);
513 	writel_relaxed(PDMA_OUT_CMD_START, base + PDMA_OUT_CMD);
514 
515 	ac->pending_count++;
516 }
517 
518 static void
519 artpec6_crypto_init_dma_operation(struct artpec6_crypto_req_common *common)
520 {
521 	struct artpec6_crypto_dma_descriptors *dma = common->dma;
522 
523 	dma->out_cnt = 0;
524 	dma->in_cnt = 0;
525 	dma->map_count = 0;
526 	INIT_LIST_HEAD(&dma->bounce_buffers);
527 }
528 
529 static bool fault_inject_dma_descr(void)
530 {
531 #ifdef CONFIG_FAULT_INJECTION
532 	return should_fail(&artpec6_crypto_fail_dma_array_full, 1);
533 #else
534 	return false;
535 #endif
536 }
537 
538 /** artpec6_crypto_setup_out_descr_phys - Setup an out channel with a
539  *                                        physical address
540  *
541  * @addr: The physical address of the data buffer
542  * @len:  The length of the data buffer
543  * @eop:  True if this is the last buffer in the packet
544  *
545  * @return 0 on success or -ENOSPC if there are no more descriptors available
546  */
547 static int
548 artpec6_crypto_setup_out_descr_phys(struct artpec6_crypto_req_common *common,
549 				    dma_addr_t addr, size_t len, bool eop)
550 {
551 	struct artpec6_crypto_dma_descriptors *dma = common->dma;
552 	struct pdma_descr *d;
553 
554 	if (dma->out_cnt >= PDMA_DESCR_COUNT ||
555 	    fault_inject_dma_descr()) {
556 		pr_err("No free OUT DMA descriptors available!\n");
557 		return -ENOSPC;
558 	}
559 
560 	d = &dma->out[dma->out_cnt++];
561 	memset(d, 0, sizeof(*d));
562 
563 	d->ctrl.short_descr = 0;
564 	d->ctrl.eop = eop;
565 	d->data.len = len;
566 	d->data.buf = addr;
567 	return 0;
568 }
569 
570 /** artpec6_crypto_setup_out_descr_short - Setup a short out descriptor
571  *
572  * @dst: The virtual address of the data
573  * @len: The length of the data, must be between 1 to 7 bytes
574  * @eop: True if this is the last buffer in the packet
575  *
576  * @return 0 on success
577  *	-ENOSPC if no more descriptors are available
578  *	-EINVAL if the data length exceeds 7 bytes
579  */
580 static int
581 artpec6_crypto_setup_out_descr_short(struct artpec6_crypto_req_common *common,
582 				     void *dst, unsigned int len, bool eop)
583 {
584 	struct artpec6_crypto_dma_descriptors *dma = common->dma;
585 	struct pdma_descr *d;
586 
587 	if (dma->out_cnt >= PDMA_DESCR_COUNT ||
588 	    fault_inject_dma_descr()) {
589 		pr_err("No free OUT DMA descriptors available!\n");
590 		return -ENOSPC;
591 	} else if (len > 7 || len < 1) {
592 		return -EINVAL;
593 	}
594 	d = &dma->out[dma->out_cnt++];
595 	memset(d, 0, sizeof(*d));
596 
597 	d->ctrl.short_descr = 1;
598 	d->ctrl.short_len = len;
599 	d->ctrl.eop = eop;
600 	memcpy(d->shrt.data, dst, len);
601 	return 0;
602 }
603 
604 static int artpec6_crypto_dma_map_page(struct artpec6_crypto_req_common *common,
605 				      struct page *page, size_t offset,
606 				      size_t size,
607 				      enum dma_data_direction dir,
608 				      dma_addr_t *dma_addr_out)
609 {
610 	struct artpec6_crypto_dma_descriptors *dma = common->dma;
611 	struct device *dev = artpec6_crypto_dev;
612 	struct artpec6_crypto_dma_map *map;
613 	dma_addr_t dma_addr;
614 
615 	*dma_addr_out = 0;
616 
617 	if (dma->map_count >= ARRAY_SIZE(dma->maps))
618 		return -ENOMEM;
619 
620 	dma_addr = dma_map_page(dev, page, offset, size, dir);
621 	if (dma_mapping_error(dev, dma_addr))
622 		return -ENOMEM;
623 
624 	map = &dma->maps[dma->map_count++];
625 	map->size = size;
626 	map->dma_addr = dma_addr;
627 	map->dir = dir;
628 
629 	*dma_addr_out = dma_addr;
630 
631 	return 0;
632 }
633 
634 static int
635 artpec6_crypto_dma_map_single(struct artpec6_crypto_req_common *common,
636 			      void *ptr, size_t size,
637 			      enum dma_data_direction dir,
638 			      dma_addr_t *dma_addr_out)
639 {
640 	struct page *page = virt_to_page(ptr);
641 	size_t offset = (uintptr_t)ptr & ~PAGE_MASK;
642 
643 	return artpec6_crypto_dma_map_page(common, page, offset, size, dir,
644 					  dma_addr_out);
645 }
646 
647 static int
648 artpec6_crypto_dma_map_descs(struct artpec6_crypto_req_common *common)
649 {
650 	struct artpec6_crypto_dma_descriptors *dma = common->dma;
651 	int ret;
652 
653 	ret = artpec6_crypto_dma_map_single(common, dma->in,
654 				sizeof(dma->in[0]) * dma->in_cnt,
655 				DMA_TO_DEVICE, &dma->in_dma_addr);
656 	if (ret)
657 		return ret;
658 
659 	ret = artpec6_crypto_dma_map_single(common, dma->out,
660 				sizeof(dma->out[0]) * dma->out_cnt,
661 				DMA_TO_DEVICE, &dma->out_dma_addr);
662 	if (ret)
663 		return ret;
664 
665 	/* We only read one stat descriptor */
666 	dma->stat[dma->in_cnt - 1] = 0;
667 
668 	/*
669 	 * DMA_BIDIRECTIONAL since we need our zeroing of the stat descriptor
670 	 * to be written.
671 	 */
672 	return artpec6_crypto_dma_map_single(common,
673 				dma->stat + dma->in_cnt - 1,
674 				sizeof(dma->stat[0]),
675 				DMA_BIDIRECTIONAL,
676 				&dma->stat_dma_addr);
677 }
678 
679 static void
680 artpec6_crypto_dma_unmap_all(struct artpec6_crypto_req_common *common)
681 {
682 	struct artpec6_crypto_dma_descriptors *dma = common->dma;
683 	struct device *dev = artpec6_crypto_dev;
684 	int i;
685 
686 	for (i = 0; i < dma->map_count; i++) {
687 		struct artpec6_crypto_dma_map *map = &dma->maps[i];
688 
689 		dma_unmap_page(dev, map->dma_addr, map->size, map->dir);
690 	}
691 
692 	dma->map_count = 0;
693 }
694 
695 /** artpec6_crypto_setup_out_descr - Setup an out descriptor
696  *
697  * @dst: The virtual address of the data
698  * @len: The length of the data
699  * @eop: True if this is the last buffer in the packet
700  * @use_short: If this is true and the data length is 7 bytes or less then
701  *	a short descriptor will be used
702  *
703  * @return 0 on success
704  *	Any errors from artpec6_crypto_setup_out_descr_short() or
705  *	setup_out_descr_phys()
706  */
707 static int
708 artpec6_crypto_setup_out_descr(struct artpec6_crypto_req_common *common,
709 			       void *dst, unsigned int len, bool eop,
710 			       bool use_short)
711 {
712 	if (use_short && len < 7) {
713 		return artpec6_crypto_setup_out_descr_short(common, dst, len,
714 							    eop);
715 	} else {
716 		int ret;
717 		dma_addr_t dma_addr;
718 
719 		ret = artpec6_crypto_dma_map_single(common, dst, len,
720 						   DMA_TO_DEVICE,
721 						   &dma_addr);
722 		if (ret)
723 			return ret;
724 
725 		return artpec6_crypto_setup_out_descr_phys(common, dma_addr,
726 							   len, eop);
727 	}
728 }
729 
730 /** artpec6_crypto_setup_in_descr_phys - Setup an in channel with a
731  *                                       physical address
732  *
733  * @addr: The physical address of the data buffer
734  * @len:  The length of the data buffer
735  * @intr: True if an interrupt should be fired after HW processing of this
736  *	  descriptor
737  *
738  */
739 static int
740 artpec6_crypto_setup_in_descr_phys(struct artpec6_crypto_req_common *common,
741 			       dma_addr_t addr, unsigned int len, bool intr)
742 {
743 	struct artpec6_crypto_dma_descriptors *dma = common->dma;
744 	struct pdma_descr *d;
745 
746 	if (dma->in_cnt >= PDMA_DESCR_COUNT ||
747 	    fault_inject_dma_descr()) {
748 		pr_err("No free IN DMA descriptors available!\n");
749 		return -ENOSPC;
750 	}
751 	d = &dma->in[dma->in_cnt++];
752 	memset(d, 0, sizeof(*d));
753 
754 	d->ctrl.intr = intr;
755 	d->data.len = len;
756 	d->data.buf = addr;
757 	return 0;
758 }
759 
760 /** artpec6_crypto_setup_in_descr - Setup an in channel descriptor
761  *
762  * @buffer: The virtual address to of the data buffer
763  * @len:    The length of the data buffer
764  * @last:   If this is the last data buffer in the request (i.e. an interrupt
765  *	    is needed
766  *
767  * Short descriptors are not used for the in channel
768  */
769 static int
770 artpec6_crypto_setup_in_descr(struct artpec6_crypto_req_common *common,
771 			  void *buffer, unsigned int len, bool last)
772 {
773 	dma_addr_t dma_addr;
774 	int ret;
775 
776 	ret = artpec6_crypto_dma_map_single(common, buffer, len,
777 					   DMA_FROM_DEVICE, &dma_addr);
778 	if (ret)
779 		return ret;
780 
781 	return artpec6_crypto_setup_in_descr_phys(common, dma_addr, len, last);
782 }
783 
784 static struct artpec6_crypto_bounce_buffer *
785 artpec6_crypto_alloc_bounce(gfp_t flags)
786 {
787 	void *base;
788 	size_t alloc_size = sizeof(struct artpec6_crypto_bounce_buffer) +
789 			    2 * ARTPEC_CACHE_LINE_MAX;
790 	struct artpec6_crypto_bounce_buffer *bbuf = kzalloc(alloc_size, flags);
791 
792 	if (!bbuf)
793 		return NULL;
794 
795 	base = bbuf + 1;
796 	bbuf->buf = PTR_ALIGN(base, ARTPEC_CACHE_LINE_MAX);
797 	return bbuf;
798 }
799 
800 static int setup_bounce_buffer_in(struct artpec6_crypto_req_common *common,
801 				  struct artpec6_crypto_walk *walk, size_t size)
802 {
803 	struct artpec6_crypto_bounce_buffer *bbuf;
804 	int ret;
805 
806 	bbuf = artpec6_crypto_alloc_bounce(common->gfp_flags);
807 	if (!bbuf)
808 		return -ENOMEM;
809 
810 	bbuf->length = size;
811 	bbuf->sg = walk->sg;
812 	bbuf->offset = walk->offset;
813 
814 	ret =  artpec6_crypto_setup_in_descr(common, bbuf->buf, size, false);
815 	if (ret) {
816 		kfree(bbuf);
817 		return ret;
818 	}
819 
820 	pr_debug("BOUNCE %zu offset %zu\n", size, walk->offset);
821 	list_add_tail(&bbuf->list, &common->dma->bounce_buffers);
822 	return 0;
823 }
824 
825 static int
826 artpec6_crypto_setup_sg_descrs_in(struct artpec6_crypto_req_common *common,
827 				  struct artpec6_crypto_walk *walk,
828 				  size_t count)
829 {
830 	size_t chunk;
831 	int ret;
832 	dma_addr_t addr;
833 
834 	while (walk->sg && count) {
835 		chunk = min(count, artpec6_crypto_walk_chunklen(walk));
836 		addr = artpec6_crypto_walk_chunk_phys(walk);
837 
838 		/* When destination buffers are not aligned to the cache line
839 		 * size we need bounce buffers. The DMA-API requires that the
840 		 * entire line is owned by the DMA buffer and this holds also
841 		 * for the case when coherent DMA is used.
842 		 */
843 		if (!IS_ALIGNED(addr, ARTPEC_CACHE_LINE_MAX)) {
844 			chunk = min_t(dma_addr_t, chunk,
845 				      ALIGN(addr, ARTPEC_CACHE_LINE_MAX) -
846 				      addr);
847 
848 			pr_debug("CHUNK-b %pad:%zu\n", &addr, chunk);
849 			ret = setup_bounce_buffer_in(common, walk, chunk);
850 		} else if (chunk < ARTPEC_CACHE_LINE_MAX) {
851 			pr_debug("CHUNK-b %pad:%zu\n", &addr, chunk);
852 			ret = setup_bounce_buffer_in(common, walk, chunk);
853 		} else {
854 			dma_addr_t dma_addr;
855 
856 			chunk = chunk & ~(ARTPEC_CACHE_LINE_MAX-1);
857 
858 			pr_debug("CHUNK %pad:%zu\n", &addr, chunk);
859 
860 			ret = artpec6_crypto_dma_map_page(common,
861 							 sg_page(walk->sg),
862 							 walk->sg->offset +
863 							 walk->offset,
864 							 chunk,
865 							 DMA_FROM_DEVICE,
866 							 &dma_addr);
867 			if (ret)
868 				return ret;
869 
870 			ret = artpec6_crypto_setup_in_descr_phys(common,
871 								 dma_addr,
872 								 chunk, false);
873 		}
874 
875 		if (ret)
876 			return ret;
877 
878 		count = count - chunk;
879 		artpec6_crypto_walk_advance(walk, chunk);
880 	}
881 
882 	if (count)
883 		pr_err("EOL unexpected %zu bytes left\n", count);
884 
885 	return count ? -EINVAL : 0;
886 }
887 
888 static int
889 artpec6_crypto_setup_sg_descrs_out(struct artpec6_crypto_req_common *common,
890 				   struct artpec6_crypto_walk *walk,
891 				   size_t count)
892 {
893 	size_t chunk;
894 	int ret;
895 	dma_addr_t addr;
896 
897 	while (walk->sg && count) {
898 		chunk = min(count, artpec6_crypto_walk_chunklen(walk));
899 		addr = artpec6_crypto_walk_chunk_phys(walk);
900 
901 		pr_debug("OUT-CHUNK %pad:%zu\n", &addr, chunk);
902 
903 		if (addr & 3) {
904 			char buf[3];
905 
906 			chunk = min_t(size_t, chunk, (4-(addr&3)));
907 
908 			sg_pcopy_to_buffer(walk->sg, 1, buf, chunk,
909 					   walk->offset);
910 
911 			ret = artpec6_crypto_setup_out_descr_short(common, buf,
912 								   chunk,
913 								   false);
914 		} else {
915 			dma_addr_t dma_addr;
916 
917 			ret = artpec6_crypto_dma_map_page(common,
918 							 sg_page(walk->sg),
919 							 walk->sg->offset +
920 							 walk->offset,
921 							 chunk,
922 							 DMA_TO_DEVICE,
923 							 &dma_addr);
924 			if (ret)
925 				return ret;
926 
927 			ret = artpec6_crypto_setup_out_descr_phys(common,
928 								 dma_addr,
929 								 chunk, false);
930 		}
931 
932 		if (ret)
933 			return ret;
934 
935 		count = count - chunk;
936 		artpec6_crypto_walk_advance(walk, chunk);
937 	}
938 
939 	if (count)
940 		pr_err("EOL unexpected %zu bytes left\n", count);
941 
942 	return count ? -EINVAL : 0;
943 }
944 
945 
946 /** artpec6_crypto_terminate_out_descrs - Set the EOP on the last out descriptor
947  *
948  * If the out descriptor list is non-empty, then the eop flag on the
949  * last used out descriptor will be set.
950  *
951  * @return  0 on success
952  *	-EINVAL if the out descriptor is empty or has overflown
953  */
954 static int
955 artpec6_crypto_terminate_out_descrs(struct artpec6_crypto_req_common *common)
956 {
957 	struct artpec6_crypto_dma_descriptors *dma = common->dma;
958 	struct pdma_descr *d;
959 
960 	if (!dma->out_cnt || dma->out_cnt > PDMA_DESCR_COUNT) {
961 		pr_err("%s: OUT descriptor list is %s\n",
962 			MODULE_NAME, dma->out_cnt ? "empty" : "full");
963 		return -EINVAL;
964 
965 	}
966 
967 	d = &dma->out[dma->out_cnt-1];
968 	d->ctrl.eop = 1;
969 
970 	return 0;
971 }
972 
973 /** artpec6_crypto_terminate_in_descrs - Set the interrupt flag on the last
974  *                                       in descriptor
975  *
976  * See artpec6_crypto_terminate_out_descrs() for return values
977  */
978 static int
979 artpec6_crypto_terminate_in_descrs(struct artpec6_crypto_req_common *common)
980 {
981 	struct artpec6_crypto_dma_descriptors *dma = common->dma;
982 	struct pdma_descr *d;
983 
984 	if (!dma->in_cnt || dma->in_cnt > PDMA_DESCR_COUNT) {
985 		pr_err("%s: IN descriptor list is %s\n",
986 			MODULE_NAME, dma->in_cnt ? "empty" : "full");
987 		return -EINVAL;
988 	}
989 
990 	d = &dma->in[dma->in_cnt-1];
991 	d->ctrl.intr = 1;
992 	return 0;
993 }
994 
995 /** create_hash_pad - Create a Secure Hash conformant pad
996  *
997  * @dst:      The destination buffer to write the pad. Must be at least 64 bytes
998  * @dgstlen:  The total length of the hash digest in bytes
999  * @bitcount: The total length of the digest in bits
1000  *
1001  * @return The total number of padding bytes written to @dst
1002  */
1003 static size_t
1004 create_hash_pad(int oper, unsigned char *dst, u64 dgstlen, u64 bitcount)
1005 {
1006 	unsigned int mod, target, diff, pad_bytes, size_bytes;
1007 	__be64 bits = __cpu_to_be64(bitcount);
1008 
1009 	switch (oper) {
1010 	case regk_crypto_sha1:
1011 	case regk_crypto_sha256:
1012 	case regk_crypto_hmac_sha1:
1013 	case regk_crypto_hmac_sha256:
1014 		target = 448 / 8;
1015 		mod = 512 / 8;
1016 		size_bytes = 8;
1017 		break;
1018 	default:
1019 		target = 896 / 8;
1020 		mod = 1024 / 8;
1021 		size_bytes = 16;
1022 		break;
1023 	}
1024 
1025 	target -= 1;
1026 	diff = dgstlen & (mod - 1);
1027 	pad_bytes = diff > target ? target + mod - diff : target - diff;
1028 
1029 	memset(dst + 1, 0, pad_bytes);
1030 	dst[0] = 0x80;
1031 
1032 	if (size_bytes == 16) {
1033 		memset(dst + 1 + pad_bytes, 0, 8);
1034 		memcpy(dst + 1 + pad_bytes + 8, &bits, 8);
1035 	} else {
1036 		memcpy(dst + 1 + pad_bytes, &bits, 8);
1037 	}
1038 
1039 	return pad_bytes + size_bytes + 1;
1040 }
1041 
1042 static int artpec6_crypto_common_init(struct artpec6_crypto_req_common *common,
1043 		struct crypto_async_request *parent,
1044 		void (*complete)(struct crypto_async_request *req),
1045 		struct scatterlist *dstsg, unsigned int nbytes)
1046 {
1047 	gfp_t flags;
1048 	struct artpec6_crypto *ac = dev_get_drvdata(artpec6_crypto_dev);
1049 
1050 	flags = (parent->flags & CRYPTO_TFM_REQ_MAY_SLEEP) ?
1051 		 GFP_KERNEL : GFP_ATOMIC;
1052 
1053 	common->gfp_flags = flags;
1054 	common->dma = kmem_cache_alloc(ac->dma_cache, flags);
1055 	if (!common->dma)
1056 		return -ENOMEM;
1057 
1058 	common->req = parent;
1059 	common->complete = complete;
1060 	return 0;
1061 }
1062 
1063 static void
1064 artpec6_crypto_bounce_destroy(struct artpec6_crypto_dma_descriptors *dma)
1065 {
1066 	struct artpec6_crypto_bounce_buffer *b;
1067 	struct artpec6_crypto_bounce_buffer *next;
1068 
1069 	list_for_each_entry_safe(b, next, &dma->bounce_buffers, list) {
1070 		kfree(b);
1071 	}
1072 }
1073 
1074 static int
1075 artpec6_crypto_common_destroy(struct artpec6_crypto_req_common *common)
1076 {
1077 	struct artpec6_crypto *ac = dev_get_drvdata(artpec6_crypto_dev);
1078 
1079 	artpec6_crypto_dma_unmap_all(common);
1080 	artpec6_crypto_bounce_destroy(common->dma);
1081 	kmem_cache_free(ac->dma_cache, common->dma);
1082 	common->dma = NULL;
1083 	return 0;
1084 }
1085 
1086 /*
1087  * Ciphering functions.
1088  */
1089 static int artpec6_crypto_encrypt(struct skcipher_request *req)
1090 {
1091 	struct crypto_skcipher *cipher = crypto_skcipher_reqtfm(req);
1092 	struct artpec6_cryptotfm_context *ctx = crypto_skcipher_ctx(cipher);
1093 	struct artpec6_crypto_request_context *req_ctx = NULL;
1094 	void (*complete)(struct crypto_async_request *req);
1095 	int ret;
1096 
1097 	req_ctx = skcipher_request_ctx(req);
1098 
1099 	switch (ctx->crypto_type) {
1100 	case ARTPEC6_CRYPTO_CIPHER_AES_CBC:
1101 	case ARTPEC6_CRYPTO_CIPHER_AES_ECB:
1102 	case ARTPEC6_CRYPTO_CIPHER_AES_XTS:
1103 		req_ctx->decrypt = 0;
1104 		break;
1105 	default:
1106 		break;
1107 	}
1108 
1109 	switch (ctx->crypto_type) {
1110 	case ARTPEC6_CRYPTO_CIPHER_AES_CBC:
1111 		complete = artpec6_crypto_complete_cbc_encrypt;
1112 		break;
1113 	default:
1114 		complete = artpec6_crypto_complete_crypto;
1115 		break;
1116 	}
1117 
1118 	ret = artpec6_crypto_common_init(&req_ctx->common,
1119 				  &req->base,
1120 				  complete,
1121 				  req->dst, req->cryptlen);
1122 	if (ret)
1123 		return ret;
1124 
1125 	ret = artpec6_crypto_prepare_crypto(req);
1126 	if (ret) {
1127 		artpec6_crypto_common_destroy(&req_ctx->common);
1128 		return ret;
1129 	}
1130 
1131 	return artpec6_crypto_submit(&req_ctx->common);
1132 }
1133 
1134 static int artpec6_crypto_decrypt(struct skcipher_request *req)
1135 {
1136 	int ret;
1137 	struct crypto_skcipher *cipher = crypto_skcipher_reqtfm(req);
1138 	struct artpec6_cryptotfm_context *ctx = crypto_skcipher_ctx(cipher);
1139 	struct artpec6_crypto_request_context *req_ctx = NULL;
1140 	void (*complete)(struct crypto_async_request *req);
1141 
1142 	req_ctx = skcipher_request_ctx(req);
1143 
1144 	switch (ctx->crypto_type) {
1145 	case ARTPEC6_CRYPTO_CIPHER_AES_CBC:
1146 	case ARTPEC6_CRYPTO_CIPHER_AES_ECB:
1147 	case ARTPEC6_CRYPTO_CIPHER_AES_XTS:
1148 		req_ctx->decrypt = 1;
1149 		break;
1150 	default:
1151 		break;
1152 	}
1153 
1154 
1155 	switch (ctx->crypto_type) {
1156 	case ARTPEC6_CRYPTO_CIPHER_AES_CBC:
1157 		complete = artpec6_crypto_complete_cbc_decrypt;
1158 		break;
1159 	default:
1160 		complete = artpec6_crypto_complete_crypto;
1161 		break;
1162 	}
1163 
1164 	ret = artpec6_crypto_common_init(&req_ctx->common, &req->base,
1165 				  complete,
1166 				  req->dst, req->cryptlen);
1167 	if (ret)
1168 		return ret;
1169 
1170 	ret = artpec6_crypto_prepare_crypto(req);
1171 	if (ret) {
1172 		artpec6_crypto_common_destroy(&req_ctx->common);
1173 		return ret;
1174 	}
1175 
1176 	return artpec6_crypto_submit(&req_ctx->common);
1177 }
1178 
1179 static int
1180 artpec6_crypto_ctr_crypt(struct skcipher_request *req, bool encrypt)
1181 {
1182 	struct crypto_skcipher *cipher = crypto_skcipher_reqtfm(req);
1183 	struct artpec6_cryptotfm_context *ctx = crypto_skcipher_ctx(cipher);
1184 	size_t iv_len = crypto_skcipher_ivsize(cipher);
1185 	unsigned int counter = be32_to_cpup((__be32 *)
1186 					    (req->iv + iv_len - 4));
1187 	unsigned int nblks = ALIGN(req->cryptlen, AES_BLOCK_SIZE) /
1188 			     AES_BLOCK_SIZE;
1189 
1190 	/*
1191 	 * The hardware uses only the last 32-bits as the counter while the
1192 	 * kernel tests (aes_ctr_enc_tv_template[4] for example) expect that
1193 	 * the whole IV is a counter.  So fallback if the counter is going to
1194 	 * overlow.
1195 	 */
1196 	if (counter + nblks < counter) {
1197 		int ret;
1198 
1199 		pr_debug("counter %x will overflow (nblks %u), falling back\n",
1200 			 counter, counter + nblks);
1201 
1202 		ret = crypto_skcipher_setkey(ctx->fallback, ctx->aes_key,
1203 					     ctx->key_length);
1204 		if (ret)
1205 			return ret;
1206 
1207 		{
1208 			SKCIPHER_REQUEST_ON_STACK(subreq, ctx->fallback);
1209 
1210 			skcipher_request_set_tfm(subreq, ctx->fallback);
1211 			skcipher_request_set_callback(subreq, req->base.flags,
1212 						      NULL, NULL);
1213 			skcipher_request_set_crypt(subreq, req->src, req->dst,
1214 						   req->cryptlen, req->iv);
1215 			ret = encrypt ? crypto_skcipher_encrypt(subreq)
1216 				      : crypto_skcipher_decrypt(subreq);
1217 			skcipher_request_zero(subreq);
1218 		}
1219 		return ret;
1220 	}
1221 
1222 	return encrypt ? artpec6_crypto_encrypt(req)
1223 		       : artpec6_crypto_decrypt(req);
1224 }
1225 
1226 static int artpec6_crypto_ctr_encrypt(struct skcipher_request *req)
1227 {
1228 	return artpec6_crypto_ctr_crypt(req, true);
1229 }
1230 
1231 static int artpec6_crypto_ctr_decrypt(struct skcipher_request *req)
1232 {
1233 	return artpec6_crypto_ctr_crypt(req, false);
1234 }
1235 
1236 /*
1237  * AEAD functions
1238  */
1239 static int artpec6_crypto_aead_init(struct crypto_aead *tfm)
1240 {
1241 	struct artpec6_cryptotfm_context *tfm_ctx = crypto_aead_ctx(tfm);
1242 
1243 	memset(tfm_ctx, 0, sizeof(*tfm_ctx));
1244 
1245 	crypto_aead_set_reqsize(tfm,
1246 				sizeof(struct artpec6_crypto_aead_req_ctx));
1247 
1248 	return 0;
1249 }
1250 
1251 static int artpec6_crypto_aead_set_key(struct crypto_aead *tfm, const u8 *key,
1252 			       unsigned int len)
1253 {
1254 	struct artpec6_cryptotfm_context *ctx = crypto_tfm_ctx(&tfm->base);
1255 
1256 	if (len != 16 && len != 24 && len != 32) {
1257 		crypto_aead_set_flags(tfm, CRYPTO_TFM_RES_BAD_KEY_LEN);
1258 		return -1;
1259 	}
1260 
1261 	ctx->key_length = len;
1262 
1263 	memcpy(ctx->aes_key, key, len);
1264 	return 0;
1265 }
1266 
1267 static int artpec6_crypto_aead_encrypt(struct aead_request *req)
1268 {
1269 	int ret;
1270 	struct artpec6_crypto_aead_req_ctx *req_ctx = aead_request_ctx(req);
1271 
1272 	req_ctx->decrypt = false;
1273 	ret = artpec6_crypto_common_init(&req_ctx->common, &req->base,
1274 				  artpec6_crypto_complete_aead,
1275 				  NULL, 0);
1276 	if (ret)
1277 		return ret;
1278 
1279 	ret = artpec6_crypto_prepare_aead(req);
1280 	if (ret) {
1281 		artpec6_crypto_common_destroy(&req_ctx->common);
1282 		return ret;
1283 	}
1284 
1285 	return artpec6_crypto_submit(&req_ctx->common);
1286 }
1287 
1288 static int artpec6_crypto_aead_decrypt(struct aead_request *req)
1289 {
1290 	int ret;
1291 	struct artpec6_crypto_aead_req_ctx *req_ctx = aead_request_ctx(req);
1292 
1293 	req_ctx->decrypt = true;
1294 	if (req->cryptlen < AES_BLOCK_SIZE)
1295 		return -EINVAL;
1296 
1297 	ret = artpec6_crypto_common_init(&req_ctx->common,
1298 				  &req->base,
1299 				  artpec6_crypto_complete_aead,
1300 				  NULL, 0);
1301 	if (ret)
1302 		return ret;
1303 
1304 	ret = artpec6_crypto_prepare_aead(req);
1305 	if (ret) {
1306 		artpec6_crypto_common_destroy(&req_ctx->common);
1307 		return ret;
1308 	}
1309 
1310 	return artpec6_crypto_submit(&req_ctx->common);
1311 }
1312 
1313 static int artpec6_crypto_prepare_hash(struct ahash_request *areq)
1314 {
1315 	struct artpec6_hashalg_context *ctx = crypto_tfm_ctx(areq->base.tfm);
1316 	struct artpec6_hash_request_context *req_ctx = ahash_request_ctx(areq);
1317 	size_t digestsize = crypto_ahash_digestsize(crypto_ahash_reqtfm(areq));
1318 	size_t contextsize = digestsize == SHA384_DIGEST_SIZE ?
1319 		SHA512_DIGEST_SIZE : digestsize;
1320 	size_t blocksize = crypto_tfm_alg_blocksize(
1321 		crypto_ahash_tfm(crypto_ahash_reqtfm(areq)));
1322 	struct artpec6_crypto_req_common *common = &req_ctx->common;
1323 	struct artpec6_crypto *ac = dev_get_drvdata(artpec6_crypto_dev);
1324 	enum artpec6_crypto_variant variant = ac->variant;
1325 	u32 sel_ctx;
1326 	bool ext_ctx = false;
1327 	bool run_hw = false;
1328 	int error = 0;
1329 
1330 	artpec6_crypto_init_dma_operation(common);
1331 
1332 	/* Upload HMAC key, must be first the first packet */
1333 	if (req_ctx->hash_flags & HASH_FLAG_HMAC) {
1334 		if (variant == ARTPEC6_CRYPTO) {
1335 			req_ctx->key_md = FIELD_PREP(A6_CRY_MD_OPER,
1336 						     a6_regk_crypto_dlkey);
1337 		} else {
1338 			req_ctx->key_md = FIELD_PREP(A7_CRY_MD_OPER,
1339 						     a7_regk_crypto_dlkey);
1340 		}
1341 
1342 		/* Copy and pad up the key */
1343 		memcpy(req_ctx->key_buffer, ctx->hmac_key,
1344 		       ctx->hmac_key_length);
1345 		memset(req_ctx->key_buffer + ctx->hmac_key_length, 0,
1346 		       blocksize - ctx->hmac_key_length);
1347 
1348 		error = artpec6_crypto_setup_out_descr(common,
1349 					(void *)&req_ctx->key_md,
1350 					sizeof(req_ctx->key_md), false, false);
1351 		if (error)
1352 			return error;
1353 
1354 		error = artpec6_crypto_setup_out_descr(common,
1355 					req_ctx->key_buffer, blocksize,
1356 					true, false);
1357 		if (error)
1358 			return error;
1359 	}
1360 
1361 	if (!(req_ctx->hash_flags & HASH_FLAG_INIT_CTX)) {
1362 		/* Restore context */
1363 		sel_ctx = regk_crypto_ext;
1364 		ext_ctx = true;
1365 	} else {
1366 		sel_ctx = regk_crypto_init;
1367 	}
1368 
1369 	if (variant == ARTPEC6_CRYPTO) {
1370 		req_ctx->hash_md &= ~A6_CRY_MD_HASH_SEL_CTX;
1371 		req_ctx->hash_md |= FIELD_PREP(A6_CRY_MD_HASH_SEL_CTX, sel_ctx);
1372 
1373 		/* If this is the final round, set the final flag */
1374 		if (req_ctx->hash_flags & HASH_FLAG_FINALIZE)
1375 			req_ctx->hash_md |= A6_CRY_MD_HASH_HMAC_FIN;
1376 	} else {
1377 		req_ctx->hash_md &= ~A7_CRY_MD_HASH_SEL_CTX;
1378 		req_ctx->hash_md |= FIELD_PREP(A7_CRY_MD_HASH_SEL_CTX, sel_ctx);
1379 
1380 		/* If this is the final round, set the final flag */
1381 		if (req_ctx->hash_flags & HASH_FLAG_FINALIZE)
1382 			req_ctx->hash_md |= A7_CRY_MD_HASH_HMAC_FIN;
1383 	}
1384 
1385 	/* Setup up metadata descriptors */
1386 	error = artpec6_crypto_setup_out_descr(common,
1387 				(void *)&req_ctx->hash_md,
1388 				sizeof(req_ctx->hash_md), false, false);
1389 	if (error)
1390 		return error;
1391 
1392 	error = artpec6_crypto_setup_in_descr(common, ac->pad_buffer, 4, false);
1393 	if (error)
1394 		return error;
1395 
1396 	if (ext_ctx) {
1397 		error = artpec6_crypto_setup_out_descr(common,
1398 					req_ctx->digeststate,
1399 					contextsize, false, false);
1400 
1401 		if (error)
1402 			return error;
1403 	}
1404 
1405 	if (req_ctx->hash_flags & HASH_FLAG_UPDATE) {
1406 		size_t done_bytes = 0;
1407 		size_t total_bytes = areq->nbytes + req_ctx->partial_bytes;
1408 		size_t ready_bytes = round_down(total_bytes, blocksize);
1409 		struct artpec6_crypto_walk walk;
1410 
1411 		run_hw = ready_bytes > 0;
1412 		if (req_ctx->partial_bytes && ready_bytes) {
1413 			/* We have a partial buffer and will at least some bytes
1414 			 * to the HW. Empty this partial buffer before tackling
1415 			 * the SG lists
1416 			 */
1417 			memcpy(req_ctx->partial_buffer_out,
1418 				req_ctx->partial_buffer,
1419 				req_ctx->partial_bytes);
1420 
1421 			error = artpec6_crypto_setup_out_descr(common,
1422 						req_ctx->partial_buffer_out,
1423 						req_ctx->partial_bytes,
1424 						false, true);
1425 			if (error)
1426 				return error;
1427 
1428 			/* Reset partial buffer */
1429 			done_bytes += req_ctx->partial_bytes;
1430 			req_ctx->partial_bytes = 0;
1431 		}
1432 
1433 		artpec6_crypto_walk_init(&walk, areq->src);
1434 
1435 		error = artpec6_crypto_setup_sg_descrs_out(common, &walk,
1436 							   ready_bytes -
1437 							   done_bytes);
1438 		if (error)
1439 			return error;
1440 
1441 		if (walk.sg) {
1442 			size_t sg_skip = ready_bytes - done_bytes;
1443 			size_t sg_rem = areq->nbytes - sg_skip;
1444 
1445 			sg_pcopy_to_buffer(areq->src, sg_nents(areq->src),
1446 					   req_ctx->partial_buffer +
1447 					   req_ctx->partial_bytes,
1448 					   sg_rem, sg_skip);
1449 
1450 			req_ctx->partial_bytes += sg_rem;
1451 		}
1452 
1453 		req_ctx->digcnt += ready_bytes;
1454 		req_ctx->hash_flags &= ~(HASH_FLAG_UPDATE);
1455 	}
1456 
1457 	/* Finalize */
1458 	if (req_ctx->hash_flags & HASH_FLAG_FINALIZE) {
1459 		bool needtrim = contextsize != digestsize;
1460 		size_t hash_pad_len;
1461 		u64 digest_bits;
1462 		u32 oper;
1463 
1464 		if (variant == ARTPEC6_CRYPTO)
1465 			oper = FIELD_GET(A6_CRY_MD_OPER, req_ctx->hash_md);
1466 		else
1467 			oper = FIELD_GET(A7_CRY_MD_OPER, req_ctx->hash_md);
1468 
1469 		/* Write out the partial buffer if present */
1470 		if (req_ctx->partial_bytes) {
1471 			memcpy(req_ctx->partial_buffer_out,
1472 			       req_ctx->partial_buffer,
1473 			       req_ctx->partial_bytes);
1474 			error = artpec6_crypto_setup_out_descr(common,
1475 						req_ctx->partial_buffer_out,
1476 						req_ctx->partial_bytes,
1477 						false, true);
1478 			if (error)
1479 				return error;
1480 
1481 			req_ctx->digcnt += req_ctx->partial_bytes;
1482 			req_ctx->partial_bytes = 0;
1483 		}
1484 
1485 		if (req_ctx->hash_flags & HASH_FLAG_HMAC)
1486 			digest_bits = 8 * (req_ctx->digcnt + blocksize);
1487 		else
1488 			digest_bits = 8 * req_ctx->digcnt;
1489 
1490 		/* Add the hash pad */
1491 		hash_pad_len = create_hash_pad(oper, req_ctx->pad_buffer,
1492 					       req_ctx->digcnt, digest_bits);
1493 		error = artpec6_crypto_setup_out_descr(common,
1494 						      req_ctx->pad_buffer,
1495 						      hash_pad_len, false,
1496 						      true);
1497 		req_ctx->digcnt = 0;
1498 
1499 		if (error)
1500 			return error;
1501 
1502 		/* Descriptor for the final result */
1503 		error = artpec6_crypto_setup_in_descr(common, areq->result,
1504 						      digestsize,
1505 						      !needtrim);
1506 		if (error)
1507 			return error;
1508 
1509 		if (needtrim) {
1510 			/* Discard the extra context bytes for SHA-384 */
1511 			error = artpec6_crypto_setup_in_descr(common,
1512 					req_ctx->partial_buffer,
1513 					digestsize - contextsize, true);
1514 			if (error)
1515 				return error;
1516 		}
1517 
1518 	} else { /* This is not the final operation for this request */
1519 		if (!run_hw)
1520 			return ARTPEC6_CRYPTO_PREPARE_HASH_NO_START;
1521 
1522 		/* Save the result to the context */
1523 		error = artpec6_crypto_setup_in_descr(common,
1524 						      req_ctx->digeststate,
1525 						      contextsize, false);
1526 		if (error)
1527 			return error;
1528 		/* fall through */
1529 	}
1530 
1531 	req_ctx->hash_flags &= ~(HASH_FLAG_INIT_CTX | HASH_FLAG_UPDATE |
1532 				 HASH_FLAG_FINALIZE);
1533 
1534 	error = artpec6_crypto_terminate_in_descrs(common);
1535 	if (error)
1536 		return error;
1537 
1538 	error = artpec6_crypto_terminate_out_descrs(common);
1539 	if (error)
1540 		return error;
1541 
1542 	error = artpec6_crypto_dma_map_descs(common);
1543 	if (error)
1544 		return error;
1545 
1546 	return ARTPEC6_CRYPTO_PREPARE_HASH_START;
1547 }
1548 
1549 
1550 static int artpec6_crypto_aes_ecb_init(struct crypto_skcipher *tfm)
1551 {
1552 	struct artpec6_cryptotfm_context *ctx = crypto_skcipher_ctx(tfm);
1553 
1554 	tfm->reqsize = sizeof(struct artpec6_crypto_request_context);
1555 	ctx->crypto_type = ARTPEC6_CRYPTO_CIPHER_AES_ECB;
1556 
1557 	return 0;
1558 }
1559 
1560 static int artpec6_crypto_aes_ctr_init(struct crypto_skcipher *tfm)
1561 {
1562 	struct artpec6_cryptotfm_context *ctx = crypto_skcipher_ctx(tfm);
1563 
1564 	ctx->fallback = crypto_alloc_skcipher(crypto_tfm_alg_name(&tfm->base),
1565 					      0,
1566 					      CRYPTO_ALG_ASYNC |
1567 					      CRYPTO_ALG_NEED_FALLBACK);
1568 	if (IS_ERR(ctx->fallback))
1569 		return PTR_ERR(ctx->fallback);
1570 
1571 	tfm->reqsize = sizeof(struct artpec6_crypto_request_context);
1572 	ctx->crypto_type = ARTPEC6_CRYPTO_CIPHER_AES_CTR;
1573 
1574 	return 0;
1575 }
1576 
1577 static int artpec6_crypto_aes_cbc_init(struct crypto_skcipher *tfm)
1578 {
1579 	struct artpec6_cryptotfm_context *ctx = crypto_skcipher_ctx(tfm);
1580 
1581 	tfm->reqsize = sizeof(struct artpec6_crypto_request_context);
1582 	ctx->crypto_type = ARTPEC6_CRYPTO_CIPHER_AES_CBC;
1583 
1584 	return 0;
1585 }
1586 
1587 static int artpec6_crypto_aes_xts_init(struct crypto_skcipher *tfm)
1588 {
1589 	struct artpec6_cryptotfm_context *ctx = crypto_skcipher_ctx(tfm);
1590 
1591 	tfm->reqsize = sizeof(struct artpec6_crypto_request_context);
1592 	ctx->crypto_type = ARTPEC6_CRYPTO_CIPHER_AES_XTS;
1593 
1594 	return 0;
1595 }
1596 
1597 static void artpec6_crypto_aes_exit(struct crypto_skcipher *tfm)
1598 {
1599 	struct artpec6_cryptotfm_context *ctx = crypto_skcipher_ctx(tfm);
1600 
1601 	memset(ctx, 0, sizeof(*ctx));
1602 }
1603 
1604 static void artpec6_crypto_aes_ctr_exit(struct crypto_skcipher *tfm)
1605 {
1606 	struct artpec6_cryptotfm_context *ctx = crypto_skcipher_ctx(tfm);
1607 
1608 	crypto_free_skcipher(ctx->fallback);
1609 	artpec6_crypto_aes_exit(tfm);
1610 }
1611 
1612 static int
1613 artpec6_crypto_cipher_set_key(struct crypto_skcipher *cipher, const u8 *key,
1614 			      unsigned int keylen)
1615 {
1616 	struct artpec6_cryptotfm_context *ctx =
1617 		crypto_skcipher_ctx(cipher);
1618 
1619 	switch (keylen) {
1620 	case 16:
1621 	case 24:
1622 	case 32:
1623 		break;
1624 	default:
1625 		crypto_skcipher_set_flags(cipher,
1626 					  CRYPTO_TFM_RES_BAD_KEY_LEN);
1627 		return -EINVAL;
1628 	}
1629 
1630 	memcpy(ctx->aes_key, key, keylen);
1631 	ctx->key_length = keylen;
1632 	return 0;
1633 }
1634 
1635 static int
1636 artpec6_crypto_xts_set_key(struct crypto_skcipher *cipher, const u8 *key,
1637 			      unsigned int keylen)
1638 {
1639 	struct artpec6_cryptotfm_context *ctx =
1640 		crypto_skcipher_ctx(cipher);
1641 	int ret;
1642 
1643 	ret = xts_check_key(&cipher->base, key, keylen);
1644 	if (ret)
1645 		return ret;
1646 
1647 	switch (keylen) {
1648 	case 32:
1649 	case 48:
1650 	case 64:
1651 		break;
1652 	default:
1653 		crypto_skcipher_set_flags(cipher,
1654 					  CRYPTO_TFM_RES_BAD_KEY_LEN);
1655 		return -EINVAL;
1656 	}
1657 
1658 	memcpy(ctx->aes_key, key, keylen);
1659 	ctx->key_length = keylen;
1660 	return 0;
1661 }
1662 
1663 /** artpec6_crypto_process_crypto - Prepare an async block cipher crypto request
1664  *
1665  * @req: The asynch request to process
1666  *
1667  * @return 0 if the dma job was successfully prepared
1668  *	  <0 on error
1669  *
1670  * This function sets up the PDMA descriptors for a block cipher request.
1671  *
1672  * The required padding is added for AES-CTR using a statically defined
1673  * buffer.
1674  *
1675  * The PDMA descriptor list will be as follows:
1676  *
1677  * OUT: [KEY_MD][KEY][EOP]<CIPHER_MD>[IV]<data_0>...[data_n][AES-CTR_pad]<eop>
1678  * IN:  <CIPHER_MD><data_0>...[data_n]<intr>
1679  *
1680  */
1681 static int artpec6_crypto_prepare_crypto(struct skcipher_request *areq)
1682 {
1683 	int ret;
1684 	struct artpec6_crypto_walk walk;
1685 	struct crypto_skcipher *cipher = crypto_skcipher_reqtfm(areq);
1686 	struct artpec6_cryptotfm_context *ctx = crypto_skcipher_ctx(cipher);
1687 	struct artpec6_crypto_request_context *req_ctx = NULL;
1688 	size_t iv_len = crypto_skcipher_ivsize(cipher);
1689 	struct artpec6_crypto *ac = dev_get_drvdata(artpec6_crypto_dev);
1690 	enum artpec6_crypto_variant variant = ac->variant;
1691 	struct artpec6_crypto_req_common *common;
1692 	bool cipher_decr = false;
1693 	size_t cipher_klen;
1694 	u32 cipher_len = 0; /* Same as regk_crypto_key_128 for NULL crypto */
1695 	u32 oper;
1696 
1697 	req_ctx = skcipher_request_ctx(areq);
1698 	common = &req_ctx->common;
1699 
1700 	artpec6_crypto_init_dma_operation(common);
1701 
1702 	if (variant == ARTPEC6_CRYPTO)
1703 		ctx->key_md = FIELD_PREP(A6_CRY_MD_OPER, a6_regk_crypto_dlkey);
1704 	else
1705 		ctx->key_md = FIELD_PREP(A7_CRY_MD_OPER, a7_regk_crypto_dlkey);
1706 
1707 	ret = artpec6_crypto_setup_out_descr(common, (void *)&ctx->key_md,
1708 					     sizeof(ctx->key_md), false, false);
1709 	if (ret)
1710 		return ret;
1711 
1712 	ret = artpec6_crypto_setup_out_descr(common, ctx->aes_key,
1713 					      ctx->key_length, true, false);
1714 	if (ret)
1715 		return ret;
1716 
1717 	req_ctx->cipher_md = 0;
1718 
1719 	if (ctx->crypto_type == ARTPEC6_CRYPTO_CIPHER_AES_XTS)
1720 		cipher_klen = ctx->key_length/2;
1721 	else
1722 		cipher_klen =  ctx->key_length;
1723 
1724 	/* Metadata */
1725 	switch (cipher_klen) {
1726 	case 16:
1727 		cipher_len = regk_crypto_key_128;
1728 		break;
1729 	case 24:
1730 		cipher_len = regk_crypto_key_192;
1731 		break;
1732 	case 32:
1733 		cipher_len = regk_crypto_key_256;
1734 		break;
1735 	default:
1736 		pr_err("%s: Invalid key length %d!\n",
1737 			MODULE_NAME, ctx->key_length);
1738 		return -EINVAL;
1739 	}
1740 
1741 	switch (ctx->crypto_type) {
1742 	case ARTPEC6_CRYPTO_CIPHER_AES_ECB:
1743 		oper = regk_crypto_aes_ecb;
1744 		cipher_decr = req_ctx->decrypt;
1745 		break;
1746 
1747 	case ARTPEC6_CRYPTO_CIPHER_AES_CBC:
1748 		oper = regk_crypto_aes_cbc;
1749 		cipher_decr = req_ctx->decrypt;
1750 		break;
1751 
1752 	case ARTPEC6_CRYPTO_CIPHER_AES_CTR:
1753 		oper = regk_crypto_aes_ctr;
1754 		cipher_decr = false;
1755 		break;
1756 
1757 	case ARTPEC6_CRYPTO_CIPHER_AES_XTS:
1758 		oper = regk_crypto_aes_xts;
1759 		cipher_decr = req_ctx->decrypt;
1760 
1761 		if (variant == ARTPEC6_CRYPTO)
1762 			req_ctx->cipher_md |= A6_CRY_MD_CIPHER_DSEQ;
1763 		else
1764 			req_ctx->cipher_md |= A7_CRY_MD_CIPHER_DSEQ;
1765 		break;
1766 
1767 	default:
1768 		pr_err("%s: Invalid cipher mode %d!\n",
1769 			MODULE_NAME, ctx->crypto_type);
1770 		return -EINVAL;
1771 	}
1772 
1773 	if (variant == ARTPEC6_CRYPTO) {
1774 		req_ctx->cipher_md |= FIELD_PREP(A6_CRY_MD_OPER, oper);
1775 		req_ctx->cipher_md |= FIELD_PREP(A6_CRY_MD_CIPHER_LEN,
1776 						 cipher_len);
1777 		if (cipher_decr)
1778 			req_ctx->cipher_md |= A6_CRY_MD_CIPHER_DECR;
1779 	} else {
1780 		req_ctx->cipher_md |= FIELD_PREP(A7_CRY_MD_OPER, oper);
1781 		req_ctx->cipher_md |= FIELD_PREP(A7_CRY_MD_CIPHER_LEN,
1782 						 cipher_len);
1783 		if (cipher_decr)
1784 			req_ctx->cipher_md |= A7_CRY_MD_CIPHER_DECR;
1785 	}
1786 
1787 	ret = artpec6_crypto_setup_out_descr(common,
1788 					    &req_ctx->cipher_md,
1789 					    sizeof(req_ctx->cipher_md),
1790 					    false, false);
1791 	if (ret)
1792 		return ret;
1793 
1794 	ret = artpec6_crypto_setup_in_descr(common, ac->pad_buffer, 4, false);
1795 	if (ret)
1796 		return ret;
1797 
1798 	if (iv_len) {
1799 		ret = artpec6_crypto_setup_out_descr(common, areq->iv, iv_len,
1800 						     false, false);
1801 		if (ret)
1802 			return ret;
1803 	}
1804 	/* Data out */
1805 	artpec6_crypto_walk_init(&walk, areq->src);
1806 	ret = artpec6_crypto_setup_sg_descrs_out(common, &walk, areq->cryptlen);
1807 	if (ret)
1808 		return ret;
1809 
1810 	/* Data in */
1811 	artpec6_crypto_walk_init(&walk, areq->dst);
1812 	ret = artpec6_crypto_setup_sg_descrs_in(common, &walk, areq->cryptlen);
1813 	if (ret)
1814 		return ret;
1815 
1816 	/* CTR-mode padding required by the HW. */
1817 	if (ctx->crypto_type == ARTPEC6_CRYPTO_CIPHER_AES_CTR ||
1818 	    ctx->crypto_type == ARTPEC6_CRYPTO_CIPHER_AES_XTS) {
1819 		size_t pad = ALIGN(areq->cryptlen, AES_BLOCK_SIZE) -
1820 			     areq->cryptlen;
1821 
1822 		if (pad) {
1823 			ret = artpec6_crypto_setup_out_descr(common,
1824 							     ac->pad_buffer,
1825 							     pad, false, false);
1826 			if (ret)
1827 				return ret;
1828 
1829 			ret = artpec6_crypto_setup_in_descr(common,
1830 							    ac->pad_buffer, pad,
1831 							    false);
1832 			if (ret)
1833 				return ret;
1834 		}
1835 	}
1836 
1837 	ret = artpec6_crypto_terminate_out_descrs(common);
1838 	if (ret)
1839 		return ret;
1840 
1841 	ret = artpec6_crypto_terminate_in_descrs(common);
1842 	if (ret)
1843 		return ret;
1844 
1845 	return artpec6_crypto_dma_map_descs(common);
1846 }
1847 
1848 static int artpec6_crypto_prepare_aead(struct aead_request *areq)
1849 {
1850 	size_t count;
1851 	int ret;
1852 	size_t input_length;
1853 	struct artpec6_cryptotfm_context *ctx = crypto_tfm_ctx(areq->base.tfm);
1854 	struct artpec6_crypto_aead_req_ctx *req_ctx = aead_request_ctx(areq);
1855 	struct crypto_aead *cipher = crypto_aead_reqtfm(areq);
1856 	struct artpec6_crypto_req_common *common = &req_ctx->common;
1857 	struct artpec6_crypto *ac = dev_get_drvdata(artpec6_crypto_dev);
1858 	enum artpec6_crypto_variant variant = ac->variant;
1859 	u32 md_cipher_len;
1860 
1861 	artpec6_crypto_init_dma_operation(common);
1862 
1863 	/* Key */
1864 	if (variant == ARTPEC6_CRYPTO) {
1865 		ctx->key_md = FIELD_PREP(A6_CRY_MD_OPER,
1866 					 a6_regk_crypto_dlkey);
1867 	} else {
1868 		ctx->key_md = FIELD_PREP(A7_CRY_MD_OPER,
1869 					 a7_regk_crypto_dlkey);
1870 	}
1871 	ret = artpec6_crypto_setup_out_descr(common, (void *)&ctx->key_md,
1872 					     sizeof(ctx->key_md), false, false);
1873 	if (ret)
1874 		return ret;
1875 
1876 	ret = artpec6_crypto_setup_out_descr(common, ctx->aes_key,
1877 					     ctx->key_length, true, false);
1878 	if (ret)
1879 		return ret;
1880 
1881 	req_ctx->cipher_md = 0;
1882 
1883 	switch (ctx->key_length) {
1884 	case 16:
1885 		md_cipher_len = regk_crypto_key_128;
1886 		break;
1887 	case 24:
1888 		md_cipher_len = regk_crypto_key_192;
1889 		break;
1890 	case 32:
1891 		md_cipher_len = regk_crypto_key_256;
1892 		break;
1893 	default:
1894 		return -EINVAL;
1895 	}
1896 
1897 	if (variant == ARTPEC6_CRYPTO) {
1898 		req_ctx->cipher_md |= FIELD_PREP(A6_CRY_MD_OPER,
1899 						 regk_crypto_aes_gcm);
1900 		req_ctx->cipher_md |= FIELD_PREP(A6_CRY_MD_CIPHER_LEN,
1901 						 md_cipher_len);
1902 		if (req_ctx->decrypt)
1903 			req_ctx->cipher_md |= A6_CRY_MD_CIPHER_DECR;
1904 	} else {
1905 		req_ctx->cipher_md |= FIELD_PREP(A7_CRY_MD_OPER,
1906 						 regk_crypto_aes_gcm);
1907 		req_ctx->cipher_md |= FIELD_PREP(A7_CRY_MD_CIPHER_LEN,
1908 						 md_cipher_len);
1909 		if (req_ctx->decrypt)
1910 			req_ctx->cipher_md |= A7_CRY_MD_CIPHER_DECR;
1911 	}
1912 
1913 	ret = artpec6_crypto_setup_out_descr(common,
1914 					    (void *) &req_ctx->cipher_md,
1915 					    sizeof(req_ctx->cipher_md), false,
1916 					    false);
1917 	if (ret)
1918 		return ret;
1919 
1920 	ret = artpec6_crypto_setup_in_descr(common, ac->pad_buffer, 4, false);
1921 	if (ret)
1922 		return ret;
1923 
1924 	/* For the decryption, cryptlen includes the tag. */
1925 	input_length = areq->cryptlen;
1926 	if (req_ctx->decrypt)
1927 		input_length -= AES_BLOCK_SIZE;
1928 
1929 	/* Prepare the context buffer */
1930 	req_ctx->hw_ctx.aad_length_bits =
1931 		__cpu_to_be64(8*areq->assoclen);
1932 
1933 	req_ctx->hw_ctx.text_length_bits =
1934 		__cpu_to_be64(8*input_length);
1935 
1936 	memcpy(req_ctx->hw_ctx.J0, areq->iv, crypto_aead_ivsize(cipher));
1937 	// The HW omits the initial increment of the counter field.
1938 	memcpy(req_ctx->hw_ctx.J0 + GCM_AES_IV_SIZE, "\x00\x00\x00\x01", 4);
1939 
1940 	ret = artpec6_crypto_setup_out_descr(common, &req_ctx->hw_ctx,
1941 		sizeof(struct artpec6_crypto_aead_hw_ctx), false, false);
1942 	if (ret)
1943 		return ret;
1944 
1945 	{
1946 		struct artpec6_crypto_walk walk;
1947 
1948 		artpec6_crypto_walk_init(&walk, areq->src);
1949 
1950 		/* Associated data */
1951 		count = areq->assoclen;
1952 		ret = artpec6_crypto_setup_sg_descrs_out(common, &walk, count);
1953 		if (ret)
1954 			return ret;
1955 
1956 		if (!IS_ALIGNED(areq->assoclen, 16)) {
1957 			size_t assoc_pad = 16 - (areq->assoclen % 16);
1958 			/* The HW mandates zero padding here */
1959 			ret = artpec6_crypto_setup_out_descr(common,
1960 							     ac->zero_buffer,
1961 							     assoc_pad, false,
1962 							     false);
1963 			if (ret)
1964 				return ret;
1965 		}
1966 
1967 		/* Data to crypto */
1968 		count = input_length;
1969 		ret = artpec6_crypto_setup_sg_descrs_out(common, &walk, count);
1970 		if (ret)
1971 			return ret;
1972 
1973 		if (!IS_ALIGNED(input_length, 16)) {
1974 			size_t crypto_pad = 16 - (input_length % 16);
1975 			/* The HW mandates zero padding here */
1976 			ret = artpec6_crypto_setup_out_descr(common,
1977 							     ac->zero_buffer,
1978 							     crypto_pad,
1979 							     false,
1980 							     false);
1981 			if (ret)
1982 				return ret;
1983 		}
1984 	}
1985 
1986 	/* Data from crypto */
1987 	{
1988 		struct artpec6_crypto_walk walk;
1989 		size_t output_len = areq->cryptlen;
1990 
1991 		if (req_ctx->decrypt)
1992 			output_len -= AES_BLOCK_SIZE;
1993 
1994 		artpec6_crypto_walk_init(&walk, areq->dst);
1995 
1996 		/* skip associated data in the output */
1997 		count = artpec6_crypto_walk_advance(&walk, areq->assoclen);
1998 		if (count)
1999 			return -EINVAL;
2000 
2001 		count = output_len;
2002 		ret = artpec6_crypto_setup_sg_descrs_in(common, &walk, count);
2003 		if (ret)
2004 			return ret;
2005 
2006 		/* Put padding between the cryptotext and the auth tag */
2007 		if (!IS_ALIGNED(output_len, 16)) {
2008 			size_t crypto_pad = 16 - (output_len % 16);
2009 
2010 			ret = artpec6_crypto_setup_in_descr(common,
2011 							    ac->pad_buffer,
2012 							    crypto_pad, false);
2013 			if (ret)
2014 				return ret;
2015 		}
2016 
2017 		/* The authentication tag shall follow immediately after
2018 		 * the output ciphertext. For decryption it is put in a context
2019 		 * buffer for later compare against the input tag.
2020 		 */
2021 		count = AES_BLOCK_SIZE;
2022 
2023 		if (req_ctx->decrypt) {
2024 			ret = artpec6_crypto_setup_in_descr(common,
2025 				req_ctx->decryption_tag, count, false);
2026 			if (ret)
2027 				return ret;
2028 
2029 		} else {
2030 			ret = artpec6_crypto_setup_sg_descrs_in(common, &walk,
2031 								count);
2032 			if (ret)
2033 				return ret;
2034 		}
2035 
2036 	}
2037 
2038 	ret = artpec6_crypto_terminate_in_descrs(common);
2039 	if (ret)
2040 		return ret;
2041 
2042 	ret = artpec6_crypto_terminate_out_descrs(common);
2043 	if (ret)
2044 		return ret;
2045 
2046 	return artpec6_crypto_dma_map_descs(common);
2047 }
2048 
2049 static void artpec6_crypto_process_queue(struct artpec6_crypto *ac)
2050 {
2051 	struct artpec6_crypto_req_common *req;
2052 
2053 	while (!list_empty(&ac->queue) && !artpec6_crypto_busy()) {
2054 		req = list_first_entry(&ac->queue,
2055 				       struct artpec6_crypto_req_common,
2056 				       list);
2057 		list_move_tail(&req->list, &ac->pending);
2058 		artpec6_crypto_start_dma(req);
2059 
2060 		req->req->complete(req->req, -EINPROGRESS);
2061 	}
2062 
2063 	/*
2064 	 * In some cases, the hardware can raise an in_eop_flush interrupt
2065 	 * before actually updating the status, so we have an timer which will
2066 	 * recheck the status on timeout.  Since the cases are expected to be
2067 	 * very rare, we use a relatively large timeout value.  There should be
2068 	 * no noticeable negative effect if we timeout spuriously.
2069 	 */
2070 	if (ac->pending_count)
2071 		mod_timer(&ac->timer, jiffies + msecs_to_jiffies(100));
2072 	else
2073 		del_timer(&ac->timer);
2074 }
2075 
2076 static void artpec6_crypto_timeout(struct timer_list *t)
2077 {
2078 	struct artpec6_crypto *ac = from_timer(ac, t, timer);
2079 
2080 	dev_info_ratelimited(artpec6_crypto_dev, "timeout\n");
2081 
2082 	tasklet_schedule(&ac->task);
2083 }
2084 
2085 static void artpec6_crypto_task(unsigned long data)
2086 {
2087 	struct artpec6_crypto *ac = (struct artpec6_crypto *)data;
2088 	struct artpec6_crypto_req_common *req;
2089 	struct artpec6_crypto_req_common *n;
2090 
2091 	if (list_empty(&ac->pending)) {
2092 		pr_debug("Spurious IRQ\n");
2093 		return;
2094 	}
2095 
2096 	spin_lock_bh(&ac->queue_lock);
2097 
2098 	list_for_each_entry_safe(req, n, &ac->pending, list) {
2099 		struct artpec6_crypto_dma_descriptors *dma = req->dma;
2100 		u32 stat;
2101 
2102 		dma_sync_single_for_cpu(artpec6_crypto_dev, dma->stat_dma_addr,
2103 					sizeof(dma->stat[0]),
2104 					DMA_BIDIRECTIONAL);
2105 
2106 		stat = req->dma->stat[req->dma->in_cnt-1];
2107 
2108 		/* A non-zero final status descriptor indicates
2109 		 * this job has finished.
2110 		 */
2111 		pr_debug("Request %p status is %X\n", req, stat);
2112 		if (!stat)
2113 			break;
2114 
2115 		/* Allow testing of timeout handling with fault injection */
2116 #ifdef CONFIG_FAULT_INJECTION
2117 		if (should_fail(&artpec6_crypto_fail_status_read, 1))
2118 			continue;
2119 #endif
2120 
2121 		pr_debug("Completing request %p\n", req);
2122 
2123 		list_del(&req->list);
2124 
2125 		artpec6_crypto_dma_unmap_all(req);
2126 		artpec6_crypto_copy_bounce_buffers(req);
2127 
2128 		ac->pending_count--;
2129 		artpec6_crypto_common_destroy(req);
2130 		req->complete(req->req);
2131 	}
2132 
2133 	artpec6_crypto_process_queue(ac);
2134 
2135 	spin_unlock_bh(&ac->queue_lock);
2136 }
2137 
2138 static void artpec6_crypto_complete_crypto(struct crypto_async_request *req)
2139 {
2140 	req->complete(req, 0);
2141 }
2142 
2143 static void
2144 artpec6_crypto_complete_cbc_decrypt(struct crypto_async_request *req)
2145 {
2146 	struct skcipher_request *cipher_req = container_of(req,
2147 		struct skcipher_request, base);
2148 
2149 	scatterwalk_map_and_copy(cipher_req->iv, cipher_req->src,
2150 				 cipher_req->cryptlen - AES_BLOCK_SIZE,
2151 				 AES_BLOCK_SIZE, 0);
2152 	req->complete(req, 0);
2153 }
2154 
2155 static void
2156 artpec6_crypto_complete_cbc_encrypt(struct crypto_async_request *req)
2157 {
2158 	struct skcipher_request *cipher_req = container_of(req,
2159 		struct skcipher_request, base);
2160 
2161 	scatterwalk_map_and_copy(cipher_req->iv, cipher_req->dst,
2162 				 cipher_req->cryptlen - AES_BLOCK_SIZE,
2163 				 AES_BLOCK_SIZE, 0);
2164 	req->complete(req, 0);
2165 }
2166 
2167 static void artpec6_crypto_complete_aead(struct crypto_async_request *req)
2168 {
2169 	int result = 0;
2170 
2171 	/* Verify GCM hashtag. */
2172 	struct aead_request *areq = container_of(req,
2173 		struct aead_request, base);
2174 	struct artpec6_crypto_aead_req_ctx *req_ctx = aead_request_ctx(areq);
2175 
2176 	if (req_ctx->decrypt) {
2177 		u8 input_tag[AES_BLOCK_SIZE];
2178 
2179 		sg_pcopy_to_buffer(areq->src,
2180 				   sg_nents(areq->src),
2181 				   input_tag,
2182 				   AES_BLOCK_SIZE,
2183 				   areq->assoclen + areq->cryptlen -
2184 				   AES_BLOCK_SIZE);
2185 
2186 		if (memcmp(req_ctx->decryption_tag,
2187 			   input_tag,
2188 			   AES_BLOCK_SIZE)) {
2189 			pr_debug("***EBADMSG:\n");
2190 			print_hex_dump_debug("ref:", DUMP_PREFIX_ADDRESS, 32, 1,
2191 					     input_tag, AES_BLOCK_SIZE, true);
2192 			print_hex_dump_debug("out:", DUMP_PREFIX_ADDRESS, 32, 1,
2193 					     req_ctx->decryption_tag,
2194 					     AES_BLOCK_SIZE, true);
2195 
2196 			result = -EBADMSG;
2197 		}
2198 	}
2199 
2200 	req->complete(req, result);
2201 }
2202 
2203 static void artpec6_crypto_complete_hash(struct crypto_async_request *req)
2204 {
2205 	req->complete(req, 0);
2206 }
2207 
2208 
2209 /*------------------- Hash functions -----------------------------------------*/
2210 static int
2211 artpec6_crypto_hash_set_key(struct crypto_ahash *tfm,
2212 		    const u8 *key, unsigned int keylen)
2213 {
2214 	struct artpec6_hashalg_context *tfm_ctx = crypto_tfm_ctx(&tfm->base);
2215 	size_t blocksize;
2216 	int ret;
2217 
2218 	if (!keylen) {
2219 		pr_err("Invalid length (%d) of HMAC key\n",
2220 			keylen);
2221 		return -EINVAL;
2222 	}
2223 
2224 	memset(tfm_ctx->hmac_key, 0, sizeof(tfm_ctx->hmac_key));
2225 
2226 	blocksize = crypto_tfm_alg_blocksize(crypto_ahash_tfm(tfm));
2227 
2228 	if (keylen > blocksize) {
2229 		SHASH_DESC_ON_STACK(hdesc, tfm_ctx->child_hash);
2230 
2231 		hdesc->tfm = tfm_ctx->child_hash;
2232 		hdesc->flags = crypto_ahash_get_flags(tfm) &
2233 			       CRYPTO_TFM_REQ_MAY_SLEEP;
2234 
2235 		tfm_ctx->hmac_key_length = blocksize;
2236 		ret = crypto_shash_digest(hdesc, key, keylen,
2237 					  tfm_ctx->hmac_key);
2238 		if (ret)
2239 			return ret;
2240 
2241 	} else {
2242 		memcpy(tfm_ctx->hmac_key, key, keylen);
2243 		tfm_ctx->hmac_key_length = keylen;
2244 	}
2245 
2246 	return 0;
2247 }
2248 
2249 static int
2250 artpec6_crypto_init_hash(struct ahash_request *req, u8 type, int hmac)
2251 {
2252 	struct artpec6_crypto *ac = dev_get_drvdata(artpec6_crypto_dev);
2253 	enum artpec6_crypto_variant variant = ac->variant;
2254 	struct artpec6_hash_request_context *req_ctx = ahash_request_ctx(req);
2255 	u32 oper;
2256 
2257 	memset(req_ctx, 0, sizeof(*req_ctx));
2258 
2259 	req_ctx->hash_flags = HASH_FLAG_INIT_CTX;
2260 	if (hmac)
2261 		req_ctx->hash_flags |= (HASH_FLAG_HMAC | HASH_FLAG_UPDATE_KEY);
2262 
2263 	switch (type) {
2264 	case ARTPEC6_CRYPTO_HASH_SHA1:
2265 		oper = hmac ? regk_crypto_hmac_sha1 : regk_crypto_sha1;
2266 		break;
2267 	case ARTPEC6_CRYPTO_HASH_SHA256:
2268 		oper = hmac ? regk_crypto_hmac_sha256 : regk_crypto_sha256;
2269 		break;
2270 	case ARTPEC6_CRYPTO_HASH_SHA384:
2271 		oper = hmac ? regk_crypto_hmac_sha384 : regk_crypto_sha384;
2272 		break;
2273 	case ARTPEC6_CRYPTO_HASH_SHA512:
2274 		oper = hmac ? regk_crypto_hmac_sha512 : regk_crypto_sha512;
2275 		break;
2276 
2277 	default:
2278 		pr_err("%s: Unsupported hash type 0x%x\n", MODULE_NAME, type);
2279 		return -EINVAL;
2280 	}
2281 
2282 	if (variant == ARTPEC6_CRYPTO)
2283 		req_ctx->hash_md = FIELD_PREP(A6_CRY_MD_OPER, oper);
2284 	else
2285 		req_ctx->hash_md = FIELD_PREP(A7_CRY_MD_OPER, oper);
2286 
2287 	return 0;
2288 }
2289 
2290 static int artpec6_crypto_prepare_submit_hash(struct ahash_request *req)
2291 {
2292 	struct artpec6_hash_request_context *req_ctx = ahash_request_ctx(req);
2293 	int ret;
2294 
2295 	if (!req_ctx->common.dma) {
2296 		ret = artpec6_crypto_common_init(&req_ctx->common,
2297 					  &req->base,
2298 					  artpec6_crypto_complete_hash,
2299 					  NULL, 0);
2300 
2301 		if (ret)
2302 			return ret;
2303 	}
2304 
2305 	ret = artpec6_crypto_prepare_hash(req);
2306 	switch (ret) {
2307 	case ARTPEC6_CRYPTO_PREPARE_HASH_START:
2308 		ret = artpec6_crypto_submit(&req_ctx->common);
2309 		break;
2310 
2311 	case ARTPEC6_CRYPTO_PREPARE_HASH_NO_START:
2312 		ret = 0;
2313 		/* Fallthrough */
2314 
2315 	default:
2316 		artpec6_crypto_common_destroy(&req_ctx->common);
2317 		break;
2318 	}
2319 
2320 	return ret;
2321 }
2322 
2323 static int artpec6_crypto_hash_final(struct ahash_request *req)
2324 {
2325 	struct artpec6_hash_request_context *req_ctx = ahash_request_ctx(req);
2326 
2327 	req_ctx->hash_flags |= HASH_FLAG_FINALIZE;
2328 
2329 	return artpec6_crypto_prepare_submit_hash(req);
2330 }
2331 
2332 static int artpec6_crypto_hash_update(struct ahash_request *req)
2333 {
2334 	struct artpec6_hash_request_context *req_ctx = ahash_request_ctx(req);
2335 
2336 	req_ctx->hash_flags |= HASH_FLAG_UPDATE;
2337 
2338 	return artpec6_crypto_prepare_submit_hash(req);
2339 }
2340 
2341 static int artpec6_crypto_sha1_init(struct ahash_request *req)
2342 {
2343 	return artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA1, 0);
2344 }
2345 
2346 static int artpec6_crypto_sha1_digest(struct ahash_request *req)
2347 {
2348 	struct artpec6_hash_request_context *req_ctx = ahash_request_ctx(req);
2349 
2350 	artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA1, 0);
2351 
2352 	req_ctx->hash_flags |= HASH_FLAG_UPDATE | HASH_FLAG_FINALIZE;
2353 
2354 	return artpec6_crypto_prepare_submit_hash(req);
2355 }
2356 
2357 static int artpec6_crypto_sha256_init(struct ahash_request *req)
2358 {
2359 	return artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA256, 0);
2360 }
2361 
2362 static int artpec6_crypto_sha256_digest(struct ahash_request *req)
2363 {
2364 	struct artpec6_hash_request_context *req_ctx = ahash_request_ctx(req);
2365 
2366 	artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA256, 0);
2367 	req_ctx->hash_flags |= HASH_FLAG_UPDATE | HASH_FLAG_FINALIZE;
2368 
2369 	return artpec6_crypto_prepare_submit_hash(req);
2370 }
2371 
2372 static int __maybe_unused artpec6_crypto_sha384_init(struct ahash_request *req)
2373 {
2374 	return artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA384, 0);
2375 }
2376 
2377 static int __maybe_unused
2378 artpec6_crypto_sha384_digest(struct ahash_request *req)
2379 {
2380 	struct artpec6_hash_request_context *req_ctx = ahash_request_ctx(req);
2381 
2382 	artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA384, 0);
2383 	req_ctx->hash_flags |= HASH_FLAG_UPDATE | HASH_FLAG_FINALIZE;
2384 
2385 	return artpec6_crypto_prepare_submit_hash(req);
2386 }
2387 
2388 static int artpec6_crypto_sha512_init(struct ahash_request *req)
2389 {
2390 	return artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA512, 0);
2391 }
2392 
2393 static int artpec6_crypto_sha512_digest(struct ahash_request *req)
2394 {
2395 	struct artpec6_hash_request_context *req_ctx = ahash_request_ctx(req);
2396 
2397 	artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA512, 0);
2398 	req_ctx->hash_flags |= HASH_FLAG_UPDATE | HASH_FLAG_FINALIZE;
2399 
2400 	return artpec6_crypto_prepare_submit_hash(req);
2401 }
2402 
2403 static int artpec6_crypto_hmac_sha256_init(struct ahash_request *req)
2404 {
2405 	return artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA256, 1);
2406 }
2407 
2408 static int __maybe_unused
2409 artpec6_crypto_hmac_sha384_init(struct ahash_request *req)
2410 {
2411 	return artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA384, 1);
2412 }
2413 
2414 static int artpec6_crypto_hmac_sha512_init(struct ahash_request *req)
2415 {
2416 	return artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA512, 1);
2417 }
2418 
2419 static int artpec6_crypto_hmac_sha256_digest(struct ahash_request *req)
2420 {
2421 	struct artpec6_hash_request_context *req_ctx = ahash_request_ctx(req);
2422 
2423 	artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA256, 1);
2424 	req_ctx->hash_flags |= HASH_FLAG_UPDATE | HASH_FLAG_FINALIZE;
2425 
2426 	return artpec6_crypto_prepare_submit_hash(req);
2427 }
2428 
2429 static int __maybe_unused
2430 artpec6_crypto_hmac_sha384_digest(struct ahash_request *req)
2431 {
2432 	struct artpec6_hash_request_context *req_ctx = ahash_request_ctx(req);
2433 
2434 	artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA384, 1);
2435 	req_ctx->hash_flags |= HASH_FLAG_UPDATE | HASH_FLAG_FINALIZE;
2436 
2437 	return artpec6_crypto_prepare_submit_hash(req);
2438 }
2439 
2440 static int artpec6_crypto_hmac_sha512_digest(struct ahash_request *req)
2441 {
2442 	struct artpec6_hash_request_context *req_ctx = ahash_request_ctx(req);
2443 
2444 	artpec6_crypto_init_hash(req, ARTPEC6_CRYPTO_HASH_SHA512, 1);
2445 	req_ctx->hash_flags |= HASH_FLAG_UPDATE | HASH_FLAG_FINALIZE;
2446 
2447 	return artpec6_crypto_prepare_submit_hash(req);
2448 }
2449 
2450 static int artpec6_crypto_ahash_init_common(struct crypto_tfm *tfm,
2451 				    const char *base_hash_name)
2452 {
2453 	struct artpec6_hashalg_context *tfm_ctx = crypto_tfm_ctx(tfm);
2454 
2455 	crypto_ahash_set_reqsize(__crypto_ahash_cast(tfm),
2456 				 sizeof(struct artpec6_hash_request_context));
2457 	memset(tfm_ctx, 0, sizeof(*tfm_ctx));
2458 
2459 	if (base_hash_name) {
2460 		struct crypto_shash *child;
2461 
2462 		child = crypto_alloc_shash(base_hash_name, 0,
2463 					   CRYPTO_ALG_NEED_FALLBACK);
2464 
2465 		if (IS_ERR(child))
2466 			return PTR_ERR(child);
2467 
2468 		tfm_ctx->child_hash = child;
2469 	}
2470 
2471 	return 0;
2472 }
2473 
2474 static int artpec6_crypto_ahash_init(struct crypto_tfm *tfm)
2475 {
2476 	return artpec6_crypto_ahash_init_common(tfm, NULL);
2477 }
2478 
2479 static int artpec6_crypto_ahash_init_hmac_sha256(struct crypto_tfm *tfm)
2480 {
2481 	return artpec6_crypto_ahash_init_common(tfm, "sha256");
2482 }
2483 
2484 static int __maybe_unused
2485 artpec6_crypto_ahash_init_hmac_sha384(struct crypto_tfm *tfm)
2486 {
2487 	return artpec6_crypto_ahash_init_common(tfm, "sha384");
2488 }
2489 
2490 static int artpec6_crypto_ahash_init_hmac_sha512(struct crypto_tfm *tfm)
2491 {
2492 	return artpec6_crypto_ahash_init_common(tfm, "sha512");
2493 }
2494 
2495 static void artpec6_crypto_ahash_exit(struct crypto_tfm *tfm)
2496 {
2497 	struct artpec6_hashalg_context *tfm_ctx = crypto_tfm_ctx(tfm);
2498 
2499 	if (tfm_ctx->child_hash)
2500 		crypto_free_shash(tfm_ctx->child_hash);
2501 
2502 	memset(tfm_ctx->hmac_key, 0, sizeof(tfm_ctx->hmac_key));
2503 	tfm_ctx->hmac_key_length = 0;
2504 }
2505 
2506 static int artpec6_crypto_hash_export(struct ahash_request *req, void *out)
2507 {
2508 	const struct artpec6_hash_request_context *ctx = ahash_request_ctx(req);
2509 	struct artpec6_hash_export_state *state = out;
2510 	struct artpec6_crypto *ac = dev_get_drvdata(artpec6_crypto_dev);
2511 	enum artpec6_crypto_variant variant = ac->variant;
2512 
2513 	BUILD_BUG_ON(sizeof(state->partial_buffer) !=
2514 		     sizeof(ctx->partial_buffer));
2515 	BUILD_BUG_ON(sizeof(state->digeststate) != sizeof(ctx->digeststate));
2516 
2517 	state->digcnt = ctx->digcnt;
2518 	state->partial_bytes = ctx->partial_bytes;
2519 	state->hash_flags = ctx->hash_flags;
2520 
2521 	if (variant == ARTPEC6_CRYPTO)
2522 		state->oper = FIELD_GET(A6_CRY_MD_OPER, ctx->hash_md);
2523 	else
2524 		state->oper = FIELD_GET(A7_CRY_MD_OPER, ctx->hash_md);
2525 
2526 	memcpy(state->partial_buffer, ctx->partial_buffer,
2527 	       sizeof(state->partial_buffer));
2528 	memcpy(state->digeststate, ctx->digeststate,
2529 	       sizeof(state->digeststate));
2530 
2531 	return 0;
2532 }
2533 
2534 static int artpec6_crypto_hash_import(struct ahash_request *req, const void *in)
2535 {
2536 	struct artpec6_hash_request_context *ctx = ahash_request_ctx(req);
2537 	const struct artpec6_hash_export_state *state = in;
2538 	struct artpec6_crypto *ac = dev_get_drvdata(artpec6_crypto_dev);
2539 	enum artpec6_crypto_variant variant = ac->variant;
2540 
2541 	memset(ctx, 0, sizeof(*ctx));
2542 
2543 	ctx->digcnt = state->digcnt;
2544 	ctx->partial_bytes = state->partial_bytes;
2545 	ctx->hash_flags = state->hash_flags;
2546 
2547 	if (variant == ARTPEC6_CRYPTO)
2548 		ctx->hash_md = FIELD_PREP(A6_CRY_MD_OPER, state->oper);
2549 	else
2550 		ctx->hash_md = FIELD_PREP(A7_CRY_MD_OPER, state->oper);
2551 
2552 	memcpy(ctx->partial_buffer, state->partial_buffer,
2553 	       sizeof(state->partial_buffer));
2554 	memcpy(ctx->digeststate, state->digeststate,
2555 	       sizeof(state->digeststate));
2556 
2557 	return 0;
2558 }
2559 
2560 static int init_crypto_hw(struct artpec6_crypto *ac)
2561 {
2562 	enum artpec6_crypto_variant variant = ac->variant;
2563 	void __iomem *base = ac->base;
2564 	u32 out_descr_buf_size;
2565 	u32 out_data_buf_size;
2566 	u32 in_data_buf_size;
2567 	u32 in_descr_buf_size;
2568 	u32 in_stat_buf_size;
2569 	u32 in, out;
2570 
2571 	/*
2572 	 * The PDMA unit contains 1984 bytes of internal memory for the OUT
2573 	 * channels and 1024 bytes for the IN channel. This is an elastic
2574 	 * memory used to internally store the descriptors and data. The values
2575 	 * ares specified in 64 byte incremements.  Trustzone buffers are not
2576 	 * used at this stage.
2577 	 */
2578 	out_data_buf_size = 16;  /* 1024 bytes for data */
2579 	out_descr_buf_size = 15; /* 960 bytes for descriptors */
2580 	in_data_buf_size = 8;    /* 512 bytes for data */
2581 	in_descr_buf_size = 4;   /* 256 bytes for descriptors */
2582 	in_stat_buf_size = 4;   /* 256 bytes for stat descrs */
2583 
2584 	BUILD_BUG_ON_MSG((out_data_buf_size
2585 				+ out_descr_buf_size) * 64 > 1984,
2586 			  "Invalid OUT configuration");
2587 
2588 	BUILD_BUG_ON_MSG((in_data_buf_size
2589 				+ in_descr_buf_size
2590 				+ in_stat_buf_size) * 64 > 1024,
2591 			  "Invalid IN configuration");
2592 
2593 	in = FIELD_PREP(PDMA_IN_BUF_CFG_DATA_BUF_SIZE, in_data_buf_size) |
2594 	     FIELD_PREP(PDMA_IN_BUF_CFG_DESCR_BUF_SIZE, in_descr_buf_size) |
2595 	     FIELD_PREP(PDMA_IN_BUF_CFG_STAT_BUF_SIZE, in_stat_buf_size);
2596 
2597 	out = FIELD_PREP(PDMA_OUT_BUF_CFG_DATA_BUF_SIZE, out_data_buf_size) |
2598 	      FIELD_PREP(PDMA_OUT_BUF_CFG_DESCR_BUF_SIZE, out_descr_buf_size);
2599 
2600 	writel_relaxed(out, base + PDMA_OUT_BUF_CFG);
2601 	writel_relaxed(PDMA_OUT_CFG_EN, base + PDMA_OUT_CFG);
2602 
2603 	if (variant == ARTPEC6_CRYPTO) {
2604 		writel_relaxed(in, base + A6_PDMA_IN_BUF_CFG);
2605 		writel_relaxed(PDMA_IN_CFG_EN, base + A6_PDMA_IN_CFG);
2606 		writel_relaxed(A6_PDMA_INTR_MASK_IN_DATA |
2607 			       A6_PDMA_INTR_MASK_IN_EOP_FLUSH,
2608 			       base + A6_PDMA_INTR_MASK);
2609 	} else {
2610 		writel_relaxed(in, base + A7_PDMA_IN_BUF_CFG);
2611 		writel_relaxed(PDMA_IN_CFG_EN, base + A7_PDMA_IN_CFG);
2612 		writel_relaxed(A7_PDMA_INTR_MASK_IN_DATA |
2613 			       A7_PDMA_INTR_MASK_IN_EOP_FLUSH,
2614 			       base + A7_PDMA_INTR_MASK);
2615 	}
2616 
2617 	return 0;
2618 }
2619 
2620 static void artpec6_crypto_disable_hw(struct artpec6_crypto *ac)
2621 {
2622 	enum artpec6_crypto_variant variant = ac->variant;
2623 	void __iomem *base = ac->base;
2624 
2625 	if (variant == ARTPEC6_CRYPTO) {
2626 		writel_relaxed(A6_PDMA_IN_CMD_STOP, base + A6_PDMA_IN_CMD);
2627 		writel_relaxed(0, base + A6_PDMA_IN_CFG);
2628 		writel_relaxed(A6_PDMA_OUT_CMD_STOP, base + PDMA_OUT_CMD);
2629 	} else {
2630 		writel_relaxed(A7_PDMA_IN_CMD_STOP, base + A7_PDMA_IN_CMD);
2631 		writel_relaxed(0, base + A7_PDMA_IN_CFG);
2632 		writel_relaxed(A7_PDMA_OUT_CMD_STOP, base + PDMA_OUT_CMD);
2633 	}
2634 
2635 	writel_relaxed(0, base + PDMA_OUT_CFG);
2636 
2637 }
2638 
2639 static irqreturn_t artpec6_crypto_irq(int irq, void *dev_id)
2640 {
2641 	struct artpec6_crypto *ac = dev_id;
2642 	enum artpec6_crypto_variant variant = ac->variant;
2643 	void __iomem *base = ac->base;
2644 	u32 mask_in_data, mask_in_eop_flush;
2645 	u32 in_cmd_flush_stat, in_cmd_reg;
2646 	u32 ack_intr_reg;
2647 	u32 ack = 0;
2648 	u32 intr;
2649 
2650 	if (variant == ARTPEC6_CRYPTO) {
2651 		intr = readl_relaxed(base + A6_PDMA_MASKED_INTR);
2652 		mask_in_data = A6_PDMA_INTR_MASK_IN_DATA;
2653 		mask_in_eop_flush = A6_PDMA_INTR_MASK_IN_EOP_FLUSH;
2654 		in_cmd_flush_stat = A6_PDMA_IN_CMD_FLUSH_STAT;
2655 		in_cmd_reg = A6_PDMA_IN_CMD;
2656 		ack_intr_reg = A6_PDMA_ACK_INTR;
2657 	} else {
2658 		intr = readl_relaxed(base + A7_PDMA_MASKED_INTR);
2659 		mask_in_data = A7_PDMA_INTR_MASK_IN_DATA;
2660 		mask_in_eop_flush = A7_PDMA_INTR_MASK_IN_EOP_FLUSH;
2661 		in_cmd_flush_stat = A7_PDMA_IN_CMD_FLUSH_STAT;
2662 		in_cmd_reg = A7_PDMA_IN_CMD;
2663 		ack_intr_reg = A7_PDMA_ACK_INTR;
2664 	}
2665 
2666 	/* We get two interrupt notifications from each job.
2667 	 * The in_data means all data was sent to memory and then
2668 	 * we request a status flush command to write the per-job
2669 	 * status to its status vector. This ensures that the
2670 	 * tasklet can detect exactly how many submitted jobs
2671 	 * that have finished.
2672 	 */
2673 	if (intr & mask_in_data)
2674 		ack |= mask_in_data;
2675 
2676 	if (intr & mask_in_eop_flush)
2677 		ack |= mask_in_eop_flush;
2678 	else
2679 		writel_relaxed(in_cmd_flush_stat, base + in_cmd_reg);
2680 
2681 	writel_relaxed(ack, base + ack_intr_reg);
2682 
2683 	if (intr & mask_in_eop_flush)
2684 		tasklet_schedule(&ac->task);
2685 
2686 	return IRQ_HANDLED;
2687 }
2688 
2689 /*------------------- Algorithm definitions ----------------------------------*/
2690 
2691 /* Hashes */
2692 static struct ahash_alg hash_algos[] = {
2693 	/* SHA-1 */
2694 	{
2695 		.init = artpec6_crypto_sha1_init,
2696 		.update = artpec6_crypto_hash_update,
2697 		.final = artpec6_crypto_hash_final,
2698 		.digest = artpec6_crypto_sha1_digest,
2699 		.import = artpec6_crypto_hash_import,
2700 		.export = artpec6_crypto_hash_export,
2701 		.halg.digestsize = SHA1_DIGEST_SIZE,
2702 		.halg.statesize = sizeof(struct artpec6_hash_export_state),
2703 		.halg.base = {
2704 			.cra_name = "sha1",
2705 			.cra_driver_name = "artpec-sha1",
2706 			.cra_priority = 300,
2707 			.cra_flags = CRYPTO_ALG_ASYNC,
2708 			.cra_blocksize = SHA1_BLOCK_SIZE,
2709 			.cra_ctxsize = sizeof(struct artpec6_hashalg_context),
2710 			.cra_alignmask = 3,
2711 			.cra_module = THIS_MODULE,
2712 			.cra_init = artpec6_crypto_ahash_init,
2713 			.cra_exit = artpec6_crypto_ahash_exit,
2714 		}
2715 	},
2716 	/* SHA-256 */
2717 	{
2718 		.init = artpec6_crypto_sha256_init,
2719 		.update = artpec6_crypto_hash_update,
2720 		.final = artpec6_crypto_hash_final,
2721 		.digest = artpec6_crypto_sha256_digest,
2722 		.import = artpec6_crypto_hash_import,
2723 		.export = artpec6_crypto_hash_export,
2724 		.halg.digestsize = SHA256_DIGEST_SIZE,
2725 		.halg.statesize = sizeof(struct artpec6_hash_export_state),
2726 		.halg.base = {
2727 			.cra_name = "sha256",
2728 			.cra_driver_name = "artpec-sha256",
2729 			.cra_priority = 300,
2730 			.cra_flags = CRYPTO_ALG_ASYNC,
2731 			.cra_blocksize = SHA256_BLOCK_SIZE,
2732 			.cra_ctxsize = sizeof(struct artpec6_hashalg_context),
2733 			.cra_alignmask = 3,
2734 			.cra_module = THIS_MODULE,
2735 			.cra_init = artpec6_crypto_ahash_init,
2736 			.cra_exit = artpec6_crypto_ahash_exit,
2737 		}
2738 	},
2739 	/* HMAC SHA-256 */
2740 	{
2741 		.init = artpec6_crypto_hmac_sha256_init,
2742 		.update = artpec6_crypto_hash_update,
2743 		.final = artpec6_crypto_hash_final,
2744 		.digest = artpec6_crypto_hmac_sha256_digest,
2745 		.import = artpec6_crypto_hash_import,
2746 		.export = artpec6_crypto_hash_export,
2747 		.setkey = artpec6_crypto_hash_set_key,
2748 		.halg.digestsize = SHA256_DIGEST_SIZE,
2749 		.halg.statesize = sizeof(struct artpec6_hash_export_state),
2750 		.halg.base = {
2751 			.cra_name = "hmac(sha256)",
2752 			.cra_driver_name = "artpec-hmac-sha256",
2753 			.cra_priority = 300,
2754 			.cra_flags = CRYPTO_ALG_ASYNC,
2755 			.cra_blocksize = SHA256_BLOCK_SIZE,
2756 			.cra_ctxsize = sizeof(struct artpec6_hashalg_context),
2757 			.cra_alignmask = 3,
2758 			.cra_module = THIS_MODULE,
2759 			.cra_init = artpec6_crypto_ahash_init_hmac_sha256,
2760 			.cra_exit = artpec6_crypto_ahash_exit,
2761 		}
2762 	},
2763 };
2764 
2765 static struct ahash_alg artpec7_hash_algos[] = {
2766 	/* SHA-384 */
2767 	{
2768 		.init = artpec6_crypto_sha384_init,
2769 		.update = artpec6_crypto_hash_update,
2770 		.final = artpec6_crypto_hash_final,
2771 		.digest = artpec6_crypto_sha384_digest,
2772 		.import = artpec6_crypto_hash_import,
2773 		.export = artpec6_crypto_hash_export,
2774 		.halg.digestsize = SHA384_DIGEST_SIZE,
2775 		.halg.statesize = sizeof(struct artpec6_hash_export_state),
2776 		.halg.base = {
2777 			.cra_name = "sha384",
2778 			.cra_driver_name = "artpec-sha384",
2779 			.cra_priority = 300,
2780 			.cra_flags = CRYPTO_ALG_ASYNC,
2781 			.cra_blocksize = SHA384_BLOCK_SIZE,
2782 			.cra_ctxsize = sizeof(struct artpec6_hashalg_context),
2783 			.cra_alignmask = 3,
2784 			.cra_module = THIS_MODULE,
2785 			.cra_init = artpec6_crypto_ahash_init,
2786 			.cra_exit = artpec6_crypto_ahash_exit,
2787 		}
2788 	},
2789 	/* HMAC SHA-384 */
2790 	{
2791 		.init = artpec6_crypto_hmac_sha384_init,
2792 		.update = artpec6_crypto_hash_update,
2793 		.final = artpec6_crypto_hash_final,
2794 		.digest = artpec6_crypto_hmac_sha384_digest,
2795 		.import = artpec6_crypto_hash_import,
2796 		.export = artpec6_crypto_hash_export,
2797 		.setkey = artpec6_crypto_hash_set_key,
2798 		.halg.digestsize = SHA384_DIGEST_SIZE,
2799 		.halg.statesize = sizeof(struct artpec6_hash_export_state),
2800 		.halg.base = {
2801 			.cra_name = "hmac(sha384)",
2802 			.cra_driver_name = "artpec-hmac-sha384",
2803 			.cra_priority = 300,
2804 			.cra_flags = CRYPTO_ALG_ASYNC,
2805 			.cra_blocksize = SHA384_BLOCK_SIZE,
2806 			.cra_ctxsize = sizeof(struct artpec6_hashalg_context),
2807 			.cra_alignmask = 3,
2808 			.cra_module = THIS_MODULE,
2809 			.cra_init = artpec6_crypto_ahash_init_hmac_sha384,
2810 			.cra_exit = artpec6_crypto_ahash_exit,
2811 		}
2812 	},
2813 	/* SHA-512 */
2814 	{
2815 		.init = artpec6_crypto_sha512_init,
2816 		.update = artpec6_crypto_hash_update,
2817 		.final = artpec6_crypto_hash_final,
2818 		.digest = artpec6_crypto_sha512_digest,
2819 		.import = artpec6_crypto_hash_import,
2820 		.export = artpec6_crypto_hash_export,
2821 		.halg.digestsize = SHA512_DIGEST_SIZE,
2822 		.halg.statesize = sizeof(struct artpec6_hash_export_state),
2823 		.halg.base = {
2824 			.cra_name = "sha512",
2825 			.cra_driver_name = "artpec-sha512",
2826 			.cra_priority = 300,
2827 			.cra_flags = CRYPTO_ALG_ASYNC,
2828 			.cra_blocksize = SHA512_BLOCK_SIZE,
2829 			.cra_ctxsize = sizeof(struct artpec6_hashalg_context),
2830 			.cra_alignmask = 3,
2831 			.cra_module = THIS_MODULE,
2832 			.cra_init = artpec6_crypto_ahash_init,
2833 			.cra_exit = artpec6_crypto_ahash_exit,
2834 		}
2835 	},
2836 	/* HMAC SHA-512 */
2837 	{
2838 		.init = artpec6_crypto_hmac_sha512_init,
2839 		.update = artpec6_crypto_hash_update,
2840 		.final = artpec6_crypto_hash_final,
2841 		.digest = artpec6_crypto_hmac_sha512_digest,
2842 		.import = artpec6_crypto_hash_import,
2843 		.export = artpec6_crypto_hash_export,
2844 		.setkey = artpec6_crypto_hash_set_key,
2845 		.halg.digestsize = SHA512_DIGEST_SIZE,
2846 		.halg.statesize = sizeof(struct artpec6_hash_export_state),
2847 		.halg.base = {
2848 			.cra_name = "hmac(sha512)",
2849 			.cra_driver_name = "artpec-hmac-sha512",
2850 			.cra_priority = 300,
2851 			.cra_flags = CRYPTO_ALG_ASYNC,
2852 			.cra_blocksize = SHA512_BLOCK_SIZE,
2853 			.cra_ctxsize = sizeof(struct artpec6_hashalg_context),
2854 			.cra_alignmask = 3,
2855 			.cra_module = THIS_MODULE,
2856 			.cra_init = artpec6_crypto_ahash_init_hmac_sha512,
2857 			.cra_exit = artpec6_crypto_ahash_exit,
2858 		}
2859 	},
2860 };
2861 
2862 /* Crypto */
2863 static struct skcipher_alg crypto_algos[] = {
2864 	/* AES - ECB */
2865 	{
2866 		.base = {
2867 			.cra_name = "ecb(aes)",
2868 			.cra_driver_name = "artpec6-ecb-aes",
2869 			.cra_priority = 300,
2870 			.cra_flags = CRYPTO_ALG_ASYNC,
2871 			.cra_blocksize = AES_BLOCK_SIZE,
2872 			.cra_ctxsize = sizeof(struct artpec6_cryptotfm_context),
2873 			.cra_alignmask = 3,
2874 			.cra_module = THIS_MODULE,
2875 		},
2876 		.min_keysize = AES_MIN_KEY_SIZE,
2877 		.max_keysize = AES_MAX_KEY_SIZE,
2878 		.setkey = artpec6_crypto_cipher_set_key,
2879 		.encrypt = artpec6_crypto_encrypt,
2880 		.decrypt = artpec6_crypto_decrypt,
2881 		.init = artpec6_crypto_aes_ecb_init,
2882 		.exit = artpec6_crypto_aes_exit,
2883 	},
2884 	/* AES - CTR */
2885 	{
2886 		.base = {
2887 			.cra_name = "ctr(aes)",
2888 			.cra_driver_name = "artpec6-ctr-aes",
2889 			.cra_priority = 300,
2890 			.cra_flags = CRYPTO_ALG_ASYNC |
2891 				     CRYPTO_ALG_NEED_FALLBACK,
2892 			.cra_blocksize = 1,
2893 			.cra_ctxsize = sizeof(struct artpec6_cryptotfm_context),
2894 			.cra_alignmask = 3,
2895 			.cra_module = THIS_MODULE,
2896 		},
2897 		.min_keysize = AES_MIN_KEY_SIZE,
2898 		.max_keysize = AES_MAX_KEY_SIZE,
2899 		.ivsize = AES_BLOCK_SIZE,
2900 		.setkey = artpec6_crypto_cipher_set_key,
2901 		.encrypt = artpec6_crypto_ctr_encrypt,
2902 		.decrypt = artpec6_crypto_ctr_decrypt,
2903 		.init = artpec6_crypto_aes_ctr_init,
2904 		.exit = artpec6_crypto_aes_ctr_exit,
2905 	},
2906 	/* AES - CBC */
2907 	{
2908 		.base = {
2909 			.cra_name = "cbc(aes)",
2910 			.cra_driver_name = "artpec6-cbc-aes",
2911 			.cra_priority = 300,
2912 			.cra_flags = CRYPTO_ALG_ASYNC,
2913 			.cra_blocksize = AES_BLOCK_SIZE,
2914 			.cra_ctxsize = sizeof(struct artpec6_cryptotfm_context),
2915 			.cra_alignmask = 3,
2916 			.cra_module = THIS_MODULE,
2917 		},
2918 		.min_keysize = AES_MIN_KEY_SIZE,
2919 		.max_keysize = AES_MAX_KEY_SIZE,
2920 		.ivsize = AES_BLOCK_SIZE,
2921 		.setkey = artpec6_crypto_cipher_set_key,
2922 		.encrypt = artpec6_crypto_encrypt,
2923 		.decrypt = artpec6_crypto_decrypt,
2924 		.init = artpec6_crypto_aes_cbc_init,
2925 		.exit = artpec6_crypto_aes_exit
2926 	},
2927 	/* AES - XTS */
2928 	{
2929 		.base = {
2930 			.cra_name = "xts(aes)",
2931 			.cra_driver_name = "artpec6-xts-aes",
2932 			.cra_priority = 300,
2933 			.cra_flags = CRYPTO_ALG_ASYNC,
2934 			.cra_blocksize = 1,
2935 			.cra_ctxsize = sizeof(struct artpec6_cryptotfm_context),
2936 			.cra_alignmask = 3,
2937 			.cra_module = THIS_MODULE,
2938 		},
2939 		.min_keysize = 2*AES_MIN_KEY_SIZE,
2940 		.max_keysize = 2*AES_MAX_KEY_SIZE,
2941 		.ivsize = 16,
2942 		.setkey = artpec6_crypto_xts_set_key,
2943 		.encrypt = artpec6_crypto_encrypt,
2944 		.decrypt = artpec6_crypto_decrypt,
2945 		.init = artpec6_crypto_aes_xts_init,
2946 		.exit = artpec6_crypto_aes_exit,
2947 	},
2948 };
2949 
2950 static struct aead_alg aead_algos[] = {
2951 	{
2952 		.init   = artpec6_crypto_aead_init,
2953 		.setkey = artpec6_crypto_aead_set_key,
2954 		.encrypt = artpec6_crypto_aead_encrypt,
2955 		.decrypt = artpec6_crypto_aead_decrypt,
2956 		.ivsize = GCM_AES_IV_SIZE,
2957 		.maxauthsize = AES_BLOCK_SIZE,
2958 
2959 		.base = {
2960 			.cra_name = "gcm(aes)",
2961 			.cra_driver_name = "artpec-gcm-aes",
2962 			.cra_priority = 300,
2963 			.cra_flags = CRYPTO_ALG_ASYNC |
2964 				     CRYPTO_ALG_KERN_DRIVER_ONLY,
2965 			.cra_blocksize = 1,
2966 			.cra_ctxsize = sizeof(struct artpec6_cryptotfm_context),
2967 			.cra_alignmask = 3,
2968 			.cra_module = THIS_MODULE,
2969 		},
2970 	}
2971 };
2972 
2973 #ifdef CONFIG_DEBUG_FS
2974 
2975 struct dbgfs_u32 {
2976 	char *name;
2977 	mode_t mode;
2978 	u32 *flag;
2979 	char *desc;
2980 };
2981 
2982 static struct dentry *dbgfs_root;
2983 
2984 static void artpec6_crypto_init_debugfs(void)
2985 {
2986 	dbgfs_root = debugfs_create_dir("artpec6_crypto", NULL);
2987 
2988 	if (!dbgfs_root || IS_ERR(dbgfs_root)) {
2989 		dbgfs_root = NULL;
2990 		pr_err("%s: Could not initialise debugfs!\n", MODULE_NAME);
2991 		return;
2992 	}
2993 
2994 #ifdef CONFIG_FAULT_INJECTION
2995 	fault_create_debugfs_attr("fail_status_read", dbgfs_root,
2996 				  &artpec6_crypto_fail_status_read);
2997 
2998 	fault_create_debugfs_attr("fail_dma_array_full", dbgfs_root,
2999 				  &artpec6_crypto_fail_dma_array_full);
3000 #endif
3001 }
3002 
3003 static void artpec6_crypto_free_debugfs(void)
3004 {
3005 	if (!dbgfs_root)
3006 		return;
3007 
3008 	debugfs_remove_recursive(dbgfs_root);
3009 	dbgfs_root = NULL;
3010 }
3011 #endif
3012 
3013 static const struct of_device_id artpec6_crypto_of_match[] = {
3014 	{ .compatible = "axis,artpec6-crypto", .data = (void *)ARTPEC6_CRYPTO },
3015 	{ .compatible = "axis,artpec7-crypto", .data = (void *)ARTPEC7_CRYPTO },
3016 	{}
3017 };
3018 MODULE_DEVICE_TABLE(of, artpec6_crypto_of_match);
3019 
3020 static int artpec6_crypto_probe(struct platform_device *pdev)
3021 {
3022 	const struct of_device_id *match;
3023 	enum artpec6_crypto_variant variant;
3024 	struct artpec6_crypto *ac;
3025 	struct device *dev = &pdev->dev;
3026 	void __iomem *base;
3027 	struct resource *res;
3028 	int irq;
3029 	int err;
3030 
3031 	if (artpec6_crypto_dev)
3032 		return -ENODEV;
3033 
3034 	match = of_match_node(artpec6_crypto_of_match, dev->of_node);
3035 	if (!match)
3036 		return -EINVAL;
3037 
3038 	variant = (enum artpec6_crypto_variant)match->data;
3039 
3040 	res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
3041 	base = devm_ioremap_resource(&pdev->dev, res);
3042 	if (IS_ERR(base))
3043 		return PTR_ERR(base);
3044 
3045 	irq = platform_get_irq(pdev, 0);
3046 	if (irq < 0)
3047 		return -ENODEV;
3048 
3049 	ac = devm_kzalloc(&pdev->dev, sizeof(struct artpec6_crypto),
3050 			  GFP_KERNEL);
3051 	if (!ac)
3052 		return -ENOMEM;
3053 
3054 	platform_set_drvdata(pdev, ac);
3055 	ac->variant = variant;
3056 
3057 	spin_lock_init(&ac->queue_lock);
3058 	INIT_LIST_HEAD(&ac->queue);
3059 	INIT_LIST_HEAD(&ac->pending);
3060 	timer_setup(&ac->timer, artpec6_crypto_timeout, 0);
3061 
3062 	ac->base = base;
3063 
3064 	ac->dma_cache = kmem_cache_create("artpec6_crypto_dma",
3065 		sizeof(struct artpec6_crypto_dma_descriptors),
3066 		64,
3067 		0,
3068 		NULL);
3069 	if (!ac->dma_cache)
3070 		return -ENOMEM;
3071 
3072 #ifdef CONFIG_DEBUG_FS
3073 	artpec6_crypto_init_debugfs();
3074 #endif
3075 
3076 	tasklet_init(&ac->task, artpec6_crypto_task,
3077 		     (unsigned long)ac);
3078 
3079 	ac->pad_buffer = devm_kzalloc(&pdev->dev, 2 * ARTPEC_CACHE_LINE_MAX,
3080 				      GFP_KERNEL);
3081 	if (!ac->pad_buffer)
3082 		return -ENOMEM;
3083 	ac->pad_buffer = PTR_ALIGN(ac->pad_buffer, ARTPEC_CACHE_LINE_MAX);
3084 
3085 	ac->zero_buffer = devm_kzalloc(&pdev->dev, 2 * ARTPEC_CACHE_LINE_MAX,
3086 				      GFP_KERNEL);
3087 	if (!ac->zero_buffer)
3088 		return -ENOMEM;
3089 	ac->zero_buffer = PTR_ALIGN(ac->zero_buffer, ARTPEC_CACHE_LINE_MAX);
3090 
3091 	err = init_crypto_hw(ac);
3092 	if (err)
3093 		goto free_cache;
3094 
3095 	err = devm_request_irq(&pdev->dev, irq, artpec6_crypto_irq, 0,
3096 			       "artpec6-crypto", ac);
3097 	if (err)
3098 		goto disable_hw;
3099 
3100 	artpec6_crypto_dev = &pdev->dev;
3101 
3102 	err = crypto_register_ahashes(hash_algos, ARRAY_SIZE(hash_algos));
3103 	if (err) {
3104 		dev_err(dev, "Failed to register ahashes\n");
3105 		goto disable_hw;
3106 	}
3107 
3108 	if (variant != ARTPEC6_CRYPTO) {
3109 		err = crypto_register_ahashes(artpec7_hash_algos,
3110 					      ARRAY_SIZE(artpec7_hash_algos));
3111 		if (err) {
3112 			dev_err(dev, "Failed to register ahashes\n");
3113 			goto unregister_ahashes;
3114 		}
3115 	}
3116 
3117 	err = crypto_register_skciphers(crypto_algos, ARRAY_SIZE(crypto_algos));
3118 	if (err) {
3119 		dev_err(dev, "Failed to register ciphers\n");
3120 		goto unregister_a7_ahashes;
3121 	}
3122 
3123 	err = crypto_register_aeads(aead_algos, ARRAY_SIZE(aead_algos));
3124 	if (err) {
3125 		dev_err(dev, "Failed to register aeads\n");
3126 		goto unregister_algs;
3127 	}
3128 
3129 	return 0;
3130 
3131 unregister_algs:
3132 	crypto_unregister_skciphers(crypto_algos, ARRAY_SIZE(crypto_algos));
3133 unregister_a7_ahashes:
3134 	if (variant != ARTPEC6_CRYPTO)
3135 		crypto_unregister_ahashes(artpec7_hash_algos,
3136 					  ARRAY_SIZE(artpec7_hash_algos));
3137 unregister_ahashes:
3138 	crypto_unregister_ahashes(hash_algos, ARRAY_SIZE(hash_algos));
3139 disable_hw:
3140 	artpec6_crypto_disable_hw(ac);
3141 free_cache:
3142 	kmem_cache_destroy(ac->dma_cache);
3143 	return err;
3144 }
3145 
3146 static int artpec6_crypto_remove(struct platform_device *pdev)
3147 {
3148 	struct artpec6_crypto *ac = platform_get_drvdata(pdev);
3149 	int irq = platform_get_irq(pdev, 0);
3150 
3151 	crypto_unregister_ahashes(hash_algos, ARRAY_SIZE(hash_algos));
3152 	if (ac->variant != ARTPEC6_CRYPTO)
3153 		crypto_unregister_ahashes(artpec7_hash_algos,
3154 					  ARRAY_SIZE(artpec7_hash_algos));
3155 	crypto_unregister_skciphers(crypto_algos, ARRAY_SIZE(crypto_algos));
3156 	crypto_unregister_aeads(aead_algos, ARRAY_SIZE(aead_algos));
3157 
3158 	tasklet_disable(&ac->task);
3159 	devm_free_irq(&pdev->dev, irq, ac);
3160 	tasklet_kill(&ac->task);
3161 	del_timer_sync(&ac->timer);
3162 
3163 	artpec6_crypto_disable_hw(ac);
3164 
3165 	kmem_cache_destroy(ac->dma_cache);
3166 #ifdef CONFIG_DEBUG_FS
3167 	artpec6_crypto_free_debugfs();
3168 #endif
3169 	return 0;
3170 }
3171 
3172 static struct platform_driver artpec6_crypto_driver = {
3173 	.probe   = artpec6_crypto_probe,
3174 	.remove  = artpec6_crypto_remove,
3175 	.driver  = {
3176 		.name  = "artpec6-crypto",
3177 		.owner = THIS_MODULE,
3178 		.of_match_table = artpec6_crypto_of_match,
3179 	},
3180 };
3181 
3182 module_platform_driver(artpec6_crypto_driver);
3183 
3184 MODULE_AUTHOR("Axis Communications AB");
3185 MODULE_DESCRIPTION("ARTPEC-6 Crypto driver");
3186 MODULE_LICENSE("GPL");
3187