1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * talitos - Freescale Integrated Security Engine (SEC) device driver
5 * Copyright (c) 2008-2011 Freescale Semiconductor, Inc.
7 * Scatterlist Crypto API glue code copied from files with the following:
8 * Copyright (c) 2006-2007 Herbert Xu <herbert@gondor.apana.org.au>
10 * Crypto algorithm registration code copied from hifn driver:
11 * 2007+ Copyright (c) Evgeniy Polyakov <johnpol@2ka.mipt.ru>
12 * All rights reserved.
15 #include <linux/kernel.h>
16 #include <linux/module.h>
17 #include <linux/mod_devicetable.h>
18 #include <linux/device.h>
19 #include <linux/interrupt.h>
20 #include <linux/crypto.h>
21 #include <linux/hw_random.h>
23 #include <linux/of_irq.h>
24 #include <linux/platform_device.h>
25 #include <linux/dma-mapping.h>
27 #include <linux/spinlock.h>
28 #include <linux/rtnetlink.h>
29 #include <linux/slab.h>
31 #include <crypto/algapi.h>
32 #include <crypto/aes.h>
33 #include <crypto/internal/des.h>
34 #include <crypto/sha1.h>
35 #include <crypto/sha2.h>
36 #include <crypto/md5.h>
37 #include <crypto/internal/aead.h>
38 #include <crypto/authenc.h>
39 #include <crypto/internal/skcipher.h>
40 #include <crypto/hash.h>
41 #include <crypto/internal/hash.h>
42 #include <crypto/scatterwalk.h>
46 static void to_talitos_ptr(struct talitos_ptr
*ptr
, dma_addr_t dma_addr
,
47 unsigned int len
, bool is_sec1
)
49 ptr
->ptr
= cpu_to_be32(lower_32_bits(dma_addr
));
51 ptr
->len1
= cpu_to_be16(len
);
53 ptr
->len
= cpu_to_be16(len
);
54 ptr
->eptr
= upper_32_bits(dma_addr
);
58 static void copy_talitos_ptr(struct talitos_ptr
*dst_ptr
,
59 struct talitos_ptr
*src_ptr
, bool is_sec1
)
61 dst_ptr
->ptr
= src_ptr
->ptr
;
63 dst_ptr
->len1
= src_ptr
->len1
;
65 dst_ptr
->len
= src_ptr
->len
;
66 dst_ptr
->eptr
= src_ptr
->eptr
;
70 static unsigned short from_talitos_ptr_len(struct talitos_ptr
*ptr
,
74 return be16_to_cpu(ptr
->len1
);
76 return be16_to_cpu(ptr
->len
);
79 static void to_talitos_ptr_ext_set(struct talitos_ptr
*ptr
, u8 val
,
86 static void to_talitos_ptr_ext_or(struct talitos_ptr
*ptr
, u8 val
, bool is_sec1
)
93 * map virtual single (contiguous) pointer to h/w descriptor pointer
95 static void __map_single_talitos_ptr(struct device
*dev
,
96 struct talitos_ptr
*ptr
,
97 unsigned int len
, void *data
,
98 enum dma_data_direction dir
,
101 dma_addr_t dma_addr
= dma_map_single_attrs(dev
, data
, len
, dir
, attrs
);
102 struct talitos_private
*priv
= dev_get_drvdata(dev
);
103 bool is_sec1
= has_ftr_sec1(priv
);
105 to_talitos_ptr(ptr
, dma_addr
, len
, is_sec1
);
108 static void map_single_talitos_ptr(struct device
*dev
,
109 struct talitos_ptr
*ptr
,
110 unsigned int len
, void *data
,
111 enum dma_data_direction dir
)
113 __map_single_talitos_ptr(dev
, ptr
, len
, data
, dir
, 0);
116 static void map_single_talitos_ptr_nosync(struct device
*dev
,
117 struct talitos_ptr
*ptr
,
118 unsigned int len
, void *data
,
119 enum dma_data_direction dir
)
121 __map_single_talitos_ptr(dev
, ptr
, len
, data
, dir
,
122 DMA_ATTR_SKIP_CPU_SYNC
);
126 * unmap bus single (contiguous) h/w descriptor pointer
128 static void unmap_single_talitos_ptr(struct device
*dev
,
129 struct talitos_ptr
*ptr
,
130 enum dma_data_direction dir
)
132 struct talitos_private
*priv
= dev_get_drvdata(dev
);
133 bool is_sec1
= has_ftr_sec1(priv
);
135 dma_unmap_single(dev
, be32_to_cpu(ptr
->ptr
),
136 from_talitos_ptr_len(ptr
, is_sec1
), dir
);
139 static int reset_channel(struct device
*dev
, int ch
)
141 struct talitos_private
*priv
= dev_get_drvdata(dev
);
142 unsigned int timeout
= TALITOS_TIMEOUT
;
143 bool is_sec1
= has_ftr_sec1(priv
);
146 setbits32(priv
->chan
[ch
].reg
+ TALITOS_CCCR_LO
,
147 TALITOS1_CCCR_LO_RESET
);
149 while ((in_be32(priv
->chan
[ch
].reg
+ TALITOS_CCCR_LO
) &
150 TALITOS1_CCCR_LO_RESET
) && --timeout
)
153 setbits32(priv
->chan
[ch
].reg
+ TALITOS_CCCR
,
154 TALITOS2_CCCR_RESET
);
156 while ((in_be32(priv
->chan
[ch
].reg
+ TALITOS_CCCR
) &
157 TALITOS2_CCCR_RESET
) && --timeout
)
162 dev_err(dev
, "failed to reset channel %d\n", ch
);
166 /* set 36-bit addressing, done writeback enable and done IRQ enable */
167 setbits32(priv
->chan
[ch
].reg
+ TALITOS_CCCR_LO
, TALITOS_CCCR_LO_EAE
|
168 TALITOS_CCCR_LO_CDWE
| TALITOS_CCCR_LO_CDIE
);
169 /* enable chaining descriptors */
171 setbits32(priv
->chan
[ch
].reg
+ TALITOS_CCCR_LO
,
174 /* and ICCR writeback, if available */
175 if (priv
->features
& TALITOS_FTR_HW_AUTH_CHECK
)
176 setbits32(priv
->chan
[ch
].reg
+ TALITOS_CCCR_LO
,
177 TALITOS_CCCR_LO_IWSE
);
182 static int reset_device(struct device
*dev
)
184 struct talitos_private
*priv
= dev_get_drvdata(dev
);
185 unsigned int timeout
= TALITOS_TIMEOUT
;
186 bool is_sec1
= has_ftr_sec1(priv
);
187 u32 mcr
= is_sec1
? TALITOS1_MCR_SWR
: TALITOS2_MCR_SWR
;
189 setbits32(priv
->reg
+ TALITOS_MCR
, mcr
);
191 while ((in_be32(priv
->reg
+ TALITOS_MCR
) & mcr
)
196 mcr
= TALITOS_MCR_RCA1
| TALITOS_MCR_RCA3
;
197 setbits32(priv
->reg
+ TALITOS_MCR
, mcr
);
201 dev_err(dev
, "failed to reset device\n");
209 * Reset and initialize the device
211 static int init_device(struct device
*dev
)
213 struct talitos_private
*priv
= dev_get_drvdata(dev
);
215 bool is_sec1
= has_ftr_sec1(priv
);
219 * errata documentation: warning: certain SEC interrupts
220 * are not fully cleared by writing the MCR:SWR bit,
221 * set bit twice to completely reset
223 err
= reset_device(dev
);
227 err
= reset_device(dev
);
232 for (ch
= 0; ch
< priv
->num_channels
; ch
++) {
233 err
= reset_channel(dev
, ch
);
238 /* enable channel done and error interrupts */
240 clrbits32(priv
->reg
+ TALITOS_IMR
, TALITOS1_IMR_INIT
);
241 clrbits32(priv
->reg
+ TALITOS_IMR_LO
, TALITOS1_IMR_LO_INIT
);
242 /* disable parity error check in DEU (erroneous? test vect.) */
243 setbits32(priv
->reg_deu
+ TALITOS_EUICR
, TALITOS1_DEUICR_KPE
);
245 setbits32(priv
->reg
+ TALITOS_IMR
, TALITOS2_IMR_INIT
);
246 setbits32(priv
->reg
+ TALITOS_IMR_LO
, TALITOS2_IMR_LO_INIT
);
249 /* disable integrity check error interrupts (use writeback instead) */
250 if (priv
->features
& TALITOS_FTR_HW_AUTH_CHECK
)
251 setbits32(priv
->reg_mdeu
+ TALITOS_EUICR_LO
,
252 TALITOS_MDEUICR_LO_ICE
);
258 * talitos_submit - submits a descriptor to the device for processing
259 * @dev: the SEC device to be used
260 * @ch: the SEC device channel to be used
261 * @desc: the descriptor to be processed by the device
262 * @callback: whom to call when processing is complete
263 * @context: a handle for use by caller (optional)
265 * desc must contain valid dma-mapped (bus physical) address pointers.
266 * callback must check err and feedback in descriptor header
267 * for device processing status.
269 static int talitos_submit(struct device
*dev
, int ch
, struct talitos_desc
*desc
,
270 void (*callback
)(struct device
*dev
,
271 struct talitos_desc
*desc
,
272 void *context
, int error
),
275 struct talitos_private
*priv
= dev_get_drvdata(dev
);
276 struct talitos_request
*request
;
279 bool is_sec1
= has_ftr_sec1(priv
);
281 spin_lock_irqsave(&priv
->chan
[ch
].head_lock
, flags
);
283 if (!atomic_inc_not_zero(&priv
->chan
[ch
].submit_count
)) {
284 /* h/w fifo is full */
285 spin_unlock_irqrestore(&priv
->chan
[ch
].head_lock
, flags
);
289 head
= priv
->chan
[ch
].head
;
290 request
= &priv
->chan
[ch
].fifo
[head
];
292 /* map descriptor and save caller data */
294 desc
->hdr1
= desc
->hdr
;
295 request
->dma_desc
= dma_map_single(dev
, &desc
->hdr1
,
299 request
->dma_desc
= dma_map_single(dev
, desc
,
303 request
->callback
= callback
;
304 request
->context
= context
;
306 /* increment fifo head */
307 priv
->chan
[ch
].head
= (priv
->chan
[ch
].head
+ 1) & (priv
->fifo_len
- 1);
310 request
->desc
= desc
;
314 out_be32(priv
->chan
[ch
].reg
+ TALITOS_FF
,
315 upper_32_bits(request
->dma_desc
));
316 out_be32(priv
->chan
[ch
].reg
+ TALITOS_FF_LO
,
317 lower_32_bits(request
->dma_desc
));
319 spin_unlock_irqrestore(&priv
->chan
[ch
].head_lock
, flags
);
324 static __be32
get_request_hdr(struct talitos_request
*request
, bool is_sec1
)
326 struct talitos_edesc
*edesc
;
329 return request
->desc
->hdr
;
331 if (!request
->desc
->next_desc
)
332 return request
->desc
->hdr1
;
334 edesc
= container_of(request
->desc
, struct talitos_edesc
, desc
);
336 return ((struct talitos_desc
*)(edesc
->buf
+ edesc
->dma_len
))->hdr1
;
340 * process what was done, notify callback of error if not
342 static void flush_channel(struct device
*dev
, int ch
, int error
, int reset_ch
)
344 struct talitos_private
*priv
= dev_get_drvdata(dev
);
345 struct talitos_request
*request
, saved_req
;
348 bool is_sec1
= has_ftr_sec1(priv
);
350 spin_lock_irqsave(&priv
->chan
[ch
].tail_lock
, flags
);
352 tail
= priv
->chan
[ch
].tail
;
353 while (priv
->chan
[ch
].fifo
[tail
].desc
) {
356 request
= &priv
->chan
[ch
].fifo
[tail
];
358 /* descriptors with their done bits set don't get the error */
360 hdr
= get_request_hdr(request
, is_sec1
);
362 if ((hdr
& DESC_HDR_DONE
) == DESC_HDR_DONE
)
370 dma_unmap_single(dev
, request
->dma_desc
,
374 /* copy entries so we can call callback outside lock */
375 saved_req
.desc
= request
->desc
;
376 saved_req
.callback
= request
->callback
;
377 saved_req
.context
= request
->context
;
379 /* release request entry in fifo */
381 request
->desc
= NULL
;
383 /* increment fifo tail */
384 priv
->chan
[ch
].tail
= (tail
+ 1) & (priv
->fifo_len
- 1);
386 spin_unlock_irqrestore(&priv
->chan
[ch
].tail_lock
, flags
);
388 atomic_dec(&priv
->chan
[ch
].submit_count
);
390 saved_req
.callback(dev
, saved_req
.desc
, saved_req
.context
,
392 /* channel may resume processing in single desc error case */
393 if (error
&& !reset_ch
&& status
== error
)
395 spin_lock_irqsave(&priv
->chan
[ch
].tail_lock
, flags
);
396 tail
= priv
->chan
[ch
].tail
;
399 spin_unlock_irqrestore(&priv
->chan
[ch
].tail_lock
, flags
);
403 * process completed requests for channels that have done status
405 #define DEF_TALITOS1_DONE(name, ch_done_mask) \
406 static void talitos1_done_##name(unsigned long data) \
408 struct device *dev = (struct device *)data; \
409 struct talitos_private *priv = dev_get_drvdata(dev); \
410 unsigned long flags; \
412 if (ch_done_mask & 0x10000000) \
413 flush_channel(dev, 0, 0, 0); \
414 if (ch_done_mask & 0x40000000) \
415 flush_channel(dev, 1, 0, 0); \
416 if (ch_done_mask & 0x00010000) \
417 flush_channel(dev, 2, 0, 0); \
418 if (ch_done_mask & 0x00040000) \
419 flush_channel(dev, 3, 0, 0); \
421 /* At this point, all completed channels have been processed */ \
422 /* Unmask done interrupts for channels completed later on. */ \
423 spin_lock_irqsave(&priv->reg_lock, flags); \
424 clrbits32(priv->reg + TALITOS_IMR, ch_done_mask); \
425 clrbits32(priv->reg + TALITOS_IMR_LO, TALITOS1_IMR_LO_INIT); \
426 spin_unlock_irqrestore(&priv->reg_lock, flags); \
429 DEF_TALITOS1_DONE(4ch
, TALITOS1_ISR_4CHDONE
)
430 DEF_TALITOS1_DONE(ch0
, TALITOS1_ISR_CH_0_DONE
)
432 #define DEF_TALITOS2_DONE(name, ch_done_mask) \
433 static void talitos2_done_##name(unsigned long data) \
435 struct device *dev = (struct device *)data; \
436 struct talitos_private *priv = dev_get_drvdata(dev); \
437 unsigned long flags; \
439 if (ch_done_mask & 1) \
440 flush_channel(dev, 0, 0, 0); \
441 if (ch_done_mask & (1 << 2)) \
442 flush_channel(dev, 1, 0, 0); \
443 if (ch_done_mask & (1 << 4)) \
444 flush_channel(dev, 2, 0, 0); \
445 if (ch_done_mask & (1 << 6)) \
446 flush_channel(dev, 3, 0, 0); \
448 /* At this point, all completed channels have been processed */ \
449 /* Unmask done interrupts for channels completed later on. */ \
450 spin_lock_irqsave(&priv->reg_lock, flags); \
451 setbits32(priv->reg + TALITOS_IMR, ch_done_mask); \
452 setbits32(priv->reg + TALITOS_IMR_LO, TALITOS2_IMR_LO_INIT); \
453 spin_unlock_irqrestore(&priv->reg_lock, flags); \
456 DEF_TALITOS2_DONE(4ch
, TALITOS2_ISR_4CHDONE
)
457 DEF_TALITOS2_DONE(ch0
, TALITOS2_ISR_CH_0_DONE
)
458 DEF_TALITOS2_DONE(ch0_2
, TALITOS2_ISR_CH_0_2_DONE
)
459 DEF_TALITOS2_DONE(ch1_3
, TALITOS2_ISR_CH_1_3_DONE
)
462 * locate current (offending) descriptor
464 static __be32
current_desc_hdr(struct device
*dev
, int ch
)
466 struct talitos_private
*priv
= dev_get_drvdata(dev
);
470 cur_desc
= ((u64
)in_be32(priv
->chan
[ch
].reg
+ TALITOS_CDPR
)) << 32;
471 cur_desc
|= in_be32(priv
->chan
[ch
].reg
+ TALITOS_CDPR_LO
);
474 dev_err(dev
, "CDPR is NULL, giving up search for offending descriptor\n");
478 tail
= priv
->chan
[ch
].tail
;
481 while (priv
->chan
[ch
].fifo
[iter
].dma_desc
!= cur_desc
&&
482 priv
->chan
[ch
].fifo
[iter
].desc
->next_desc
!= cpu_to_be32(cur_desc
)) {
483 iter
= (iter
+ 1) & (priv
->fifo_len
- 1);
485 dev_err(dev
, "couldn't locate current descriptor\n");
490 if (priv
->chan
[ch
].fifo
[iter
].desc
->next_desc
== cpu_to_be32(cur_desc
)) {
491 struct talitos_edesc
*edesc
;
493 edesc
= container_of(priv
->chan
[ch
].fifo
[iter
].desc
,
494 struct talitos_edesc
, desc
);
495 return ((struct talitos_desc
*)
496 (edesc
->buf
+ edesc
->dma_len
))->hdr
;
499 return priv
->chan
[ch
].fifo
[iter
].desc
->hdr
;
503 * user diagnostics; report root cause of error based on execution unit status
505 static void report_eu_error(struct device
*dev
, int ch
, __be32 desc_hdr
)
507 struct talitos_private
*priv
= dev_get_drvdata(dev
);
511 desc_hdr
= cpu_to_be32(in_be32(priv
->chan
[ch
].reg
+ TALITOS_DESCBUF
));
513 switch (desc_hdr
& DESC_HDR_SEL0_MASK
) {
514 case DESC_HDR_SEL0_AFEU
:
515 dev_err(dev
, "AFEUISR 0x%08x_%08x\n",
516 in_be32(priv
->reg_afeu
+ TALITOS_EUISR
),
517 in_be32(priv
->reg_afeu
+ TALITOS_EUISR_LO
));
519 case DESC_HDR_SEL0_DEU
:
520 dev_err(dev
, "DEUISR 0x%08x_%08x\n",
521 in_be32(priv
->reg_deu
+ TALITOS_EUISR
),
522 in_be32(priv
->reg_deu
+ TALITOS_EUISR_LO
));
524 case DESC_HDR_SEL0_MDEUA
:
525 case DESC_HDR_SEL0_MDEUB
:
526 dev_err(dev
, "MDEUISR 0x%08x_%08x\n",
527 in_be32(priv
->reg_mdeu
+ TALITOS_EUISR
),
528 in_be32(priv
->reg_mdeu
+ TALITOS_EUISR_LO
));
530 case DESC_HDR_SEL0_RNG
:
531 dev_err(dev
, "RNGUISR 0x%08x_%08x\n",
532 in_be32(priv
->reg_rngu
+ TALITOS_ISR
),
533 in_be32(priv
->reg_rngu
+ TALITOS_ISR_LO
));
535 case DESC_HDR_SEL0_PKEU
:
536 dev_err(dev
, "PKEUISR 0x%08x_%08x\n",
537 in_be32(priv
->reg_pkeu
+ TALITOS_EUISR
),
538 in_be32(priv
->reg_pkeu
+ TALITOS_EUISR_LO
));
540 case DESC_HDR_SEL0_AESU
:
541 dev_err(dev
, "AESUISR 0x%08x_%08x\n",
542 in_be32(priv
->reg_aesu
+ TALITOS_EUISR
),
543 in_be32(priv
->reg_aesu
+ TALITOS_EUISR_LO
));
545 case DESC_HDR_SEL0_CRCU
:
546 dev_err(dev
, "CRCUISR 0x%08x_%08x\n",
547 in_be32(priv
->reg_crcu
+ TALITOS_EUISR
),
548 in_be32(priv
->reg_crcu
+ TALITOS_EUISR_LO
));
550 case DESC_HDR_SEL0_KEU
:
551 dev_err(dev
, "KEUISR 0x%08x_%08x\n",
552 in_be32(priv
->reg_pkeu
+ TALITOS_EUISR
),
553 in_be32(priv
->reg_pkeu
+ TALITOS_EUISR_LO
));
557 switch (desc_hdr
& DESC_HDR_SEL1_MASK
) {
558 case DESC_HDR_SEL1_MDEUA
:
559 case DESC_HDR_SEL1_MDEUB
:
560 dev_err(dev
, "MDEUISR 0x%08x_%08x\n",
561 in_be32(priv
->reg_mdeu
+ TALITOS_EUISR
),
562 in_be32(priv
->reg_mdeu
+ TALITOS_EUISR_LO
));
564 case DESC_HDR_SEL1_CRCU
:
565 dev_err(dev
, "CRCUISR 0x%08x_%08x\n",
566 in_be32(priv
->reg_crcu
+ TALITOS_EUISR
),
567 in_be32(priv
->reg_crcu
+ TALITOS_EUISR_LO
));
571 for (i
= 0; i
< 8; i
++)
572 dev_err(dev
, "DESCBUF 0x%08x_%08x\n",
573 in_be32(priv
->chan
[ch
].reg
+ TALITOS_DESCBUF
+ 8*i
),
574 in_be32(priv
->chan
[ch
].reg
+ TALITOS_DESCBUF_LO
+ 8*i
));
578 * recover from error interrupts
580 static void talitos_error(struct device
*dev
, u32 isr
, u32 isr_lo
)
582 struct talitos_private
*priv
= dev_get_drvdata(dev
);
583 unsigned int timeout
= TALITOS_TIMEOUT
;
584 int ch
, error
, reset_dev
= 0;
586 bool is_sec1
= has_ftr_sec1(priv
);
587 int reset_ch
= is_sec1
? 1 : 0; /* only SEC2 supports continuation */
589 for (ch
= 0; ch
< priv
->num_channels
; ch
++) {
590 /* skip channels without errors */
592 /* bits 29, 31, 17, 19 */
593 if (!(isr
& (1 << (29 + (ch
& 1) * 2 - (ch
& 2) * 6))))
596 if (!(isr
& (1 << (ch
* 2 + 1))))
602 v_lo
= in_be32(priv
->chan
[ch
].reg
+ TALITOS_CCPSR_LO
);
604 if (v_lo
& TALITOS_CCPSR_LO_DOF
) {
605 dev_err(dev
, "double fetch fifo overflow error\n");
609 if (v_lo
& TALITOS_CCPSR_LO_SOF
) {
610 /* h/w dropped descriptor */
611 dev_err(dev
, "single fetch fifo overflow error\n");
614 if (v_lo
& TALITOS_CCPSR_LO_MDTE
)
615 dev_err(dev
, "master data transfer error\n");
616 if (v_lo
& TALITOS_CCPSR_LO_SGDLZ
)
617 dev_err(dev
, is_sec1
? "pointer not complete error\n"
618 : "s/g data length zero error\n");
619 if (v_lo
& TALITOS_CCPSR_LO_FPZ
)
620 dev_err(dev
, is_sec1
? "parity error\n"
621 : "fetch pointer zero error\n");
622 if (v_lo
& TALITOS_CCPSR_LO_IDH
)
623 dev_err(dev
, "illegal descriptor header error\n");
624 if (v_lo
& TALITOS_CCPSR_LO_IEU
)
625 dev_err(dev
, is_sec1
? "static assignment error\n"
626 : "invalid exec unit error\n");
627 if (v_lo
& TALITOS_CCPSR_LO_EU
)
628 report_eu_error(dev
, ch
, current_desc_hdr(dev
, ch
));
630 if (v_lo
& TALITOS_CCPSR_LO_GB
)
631 dev_err(dev
, "gather boundary error\n");
632 if (v_lo
& TALITOS_CCPSR_LO_GRL
)
633 dev_err(dev
, "gather return/length error\n");
634 if (v_lo
& TALITOS_CCPSR_LO_SB
)
635 dev_err(dev
, "scatter boundary error\n");
636 if (v_lo
& TALITOS_CCPSR_LO_SRL
)
637 dev_err(dev
, "scatter return/length error\n");
640 flush_channel(dev
, ch
, error
, reset_ch
);
643 reset_channel(dev
, ch
);
645 setbits32(priv
->chan
[ch
].reg
+ TALITOS_CCCR
,
647 setbits32(priv
->chan
[ch
].reg
+ TALITOS_CCCR_LO
, 0);
648 while ((in_be32(priv
->chan
[ch
].reg
+ TALITOS_CCCR
) &
649 TALITOS2_CCCR_CONT
) && --timeout
)
652 dev_err(dev
, "failed to restart channel %d\n",
658 if (reset_dev
|| (is_sec1
&& isr
& ~TALITOS1_ISR_4CHERR
) ||
659 (!is_sec1
&& isr
& ~TALITOS2_ISR_4CHERR
) || isr_lo
) {
660 if (is_sec1
&& (isr_lo
& TALITOS1_ISR_TEA_ERR
))
661 dev_err(dev
, "TEA error: ISR 0x%08x_%08x\n",
664 dev_err(dev
, "done overflow, internal time out, or "
665 "rngu error: ISR 0x%08x_%08x\n", isr
, isr_lo
);
667 /* purge request queues */
668 for (ch
= 0; ch
< priv
->num_channels
; ch
++)
669 flush_channel(dev
, ch
, -EIO
, 1);
671 /* reset and reinitialize the device */
676 #define DEF_TALITOS1_INTERRUPT(name, ch_done_mask, ch_err_mask, tlet) \
677 static irqreturn_t talitos1_interrupt_##name(int irq, void *data) \
679 struct device *dev = data; \
680 struct talitos_private *priv = dev_get_drvdata(dev); \
682 unsigned long flags; \
684 spin_lock_irqsave(&priv->reg_lock, flags); \
685 isr = in_be32(priv->reg + TALITOS_ISR); \
686 isr_lo = in_be32(priv->reg + TALITOS_ISR_LO); \
687 /* Acknowledge interrupt */ \
688 out_be32(priv->reg + TALITOS_ICR, isr & (ch_done_mask | ch_err_mask)); \
689 out_be32(priv->reg + TALITOS_ICR_LO, isr_lo); \
691 if (unlikely(isr & ch_err_mask || isr_lo & TALITOS1_IMR_LO_INIT)) { \
692 spin_unlock_irqrestore(&priv->reg_lock, flags); \
693 talitos_error(dev, isr & ch_err_mask, isr_lo); \
696 if (likely(isr & ch_done_mask)) { \
697 /* mask further done interrupts. */ \
698 setbits32(priv->reg + TALITOS_IMR, ch_done_mask); \
699 /* done_task will unmask done interrupts at exit */ \
700 tasklet_schedule(&priv->done_task[tlet]); \
702 spin_unlock_irqrestore(&priv->reg_lock, flags); \
705 return (isr & (ch_done_mask | ch_err_mask) || isr_lo) ? IRQ_HANDLED : \
709 DEF_TALITOS1_INTERRUPT(4ch
, TALITOS1_ISR_4CHDONE
, TALITOS1_ISR_4CHERR
, 0)
711 #define DEF_TALITOS2_INTERRUPT(name, ch_done_mask, ch_err_mask, tlet) \
712 static irqreturn_t talitos2_interrupt_##name(int irq, void *data) \
714 struct device *dev = data; \
715 struct talitos_private *priv = dev_get_drvdata(dev); \
717 unsigned long flags; \
719 spin_lock_irqsave(&priv->reg_lock, flags); \
720 isr = in_be32(priv->reg + TALITOS_ISR); \
721 isr_lo = in_be32(priv->reg + TALITOS_ISR_LO); \
722 /* Acknowledge interrupt */ \
723 out_be32(priv->reg + TALITOS_ICR, isr & (ch_done_mask | ch_err_mask)); \
724 out_be32(priv->reg + TALITOS_ICR_LO, isr_lo); \
726 if (unlikely(isr & ch_err_mask || isr_lo)) { \
727 spin_unlock_irqrestore(&priv->reg_lock, flags); \
728 talitos_error(dev, isr & ch_err_mask, isr_lo); \
731 if (likely(isr & ch_done_mask)) { \
732 /* mask further done interrupts. */ \
733 clrbits32(priv->reg + TALITOS_IMR, ch_done_mask); \
734 /* done_task will unmask done interrupts at exit */ \
735 tasklet_schedule(&priv->done_task[tlet]); \
737 spin_unlock_irqrestore(&priv->reg_lock, flags); \
740 return (isr & (ch_done_mask | ch_err_mask) || isr_lo) ? IRQ_HANDLED : \
744 DEF_TALITOS2_INTERRUPT(4ch
, TALITOS2_ISR_4CHDONE
, TALITOS2_ISR_4CHERR
, 0)
745 DEF_TALITOS2_INTERRUPT(ch0_2
, TALITOS2_ISR_CH_0_2_DONE
, TALITOS2_ISR_CH_0_2_ERR
,
747 DEF_TALITOS2_INTERRUPT(ch1_3
, TALITOS2_ISR_CH_1_3_DONE
, TALITOS2_ISR_CH_1_3_ERR
,
753 static int talitos_rng_data_present(struct hwrng
*rng
, int wait
)
755 struct device
*dev
= (struct device
*)rng
->priv
;
756 struct talitos_private
*priv
= dev_get_drvdata(dev
);
760 for (i
= 0; i
< 20; i
++) {
761 ofl
= in_be32(priv
->reg_rngu
+ TALITOS_EUSR_LO
) &
762 TALITOS_RNGUSR_LO_OFL
;
771 static int talitos_rng_data_read(struct hwrng
*rng
, u32
*data
)
773 struct device
*dev
= (struct device
*)rng
->priv
;
774 struct talitos_private
*priv
= dev_get_drvdata(dev
);
776 /* rng fifo requires 64-bit accesses */
777 *data
= in_be32(priv
->reg_rngu
+ TALITOS_EU_FIFO
);
778 *data
= in_be32(priv
->reg_rngu
+ TALITOS_EU_FIFO_LO
);
783 static int talitos_rng_init(struct hwrng
*rng
)
785 struct device
*dev
= (struct device
*)rng
->priv
;
786 struct talitos_private
*priv
= dev_get_drvdata(dev
);
787 unsigned int timeout
= TALITOS_TIMEOUT
;
789 setbits32(priv
->reg_rngu
+ TALITOS_EURCR_LO
, TALITOS_RNGURCR_LO_SR
);
790 while (!(in_be32(priv
->reg_rngu
+ TALITOS_EUSR_LO
)
791 & TALITOS_RNGUSR_LO_RD
)
795 dev_err(dev
, "failed to reset rng hw\n");
799 /* start generating */
800 setbits32(priv
->reg_rngu
+ TALITOS_EUDSR_LO
, 0);
805 static int talitos_register_rng(struct device
*dev
)
807 struct talitos_private
*priv
= dev_get_drvdata(dev
);
810 priv
->rng
.name
= dev_driver_string(dev
);
811 priv
->rng
.init
= talitos_rng_init
;
812 priv
->rng
.data_present
= talitos_rng_data_present
;
813 priv
->rng
.data_read
= talitos_rng_data_read
;
814 priv
->rng
.priv
= (unsigned long)dev
;
816 err
= hwrng_register(&priv
->rng
);
818 priv
->rng_registered
= true;
823 static void talitos_unregister_rng(struct device
*dev
)
825 struct talitos_private
*priv
= dev_get_drvdata(dev
);
827 if (!priv
->rng_registered
)
830 hwrng_unregister(&priv
->rng
);
831 priv
->rng_registered
= false;
837 #define TALITOS_CRA_PRIORITY 3000
839 * Defines a priority for doing AEAD with descriptors type
840 * HMAC_SNOOP_NO_AFEA (HSNA) instead of type IPSEC_ESP
842 #define TALITOS_CRA_PRIORITY_AEAD_HSNA (TALITOS_CRA_PRIORITY - 1)
843 #ifdef CONFIG_CRYPTO_DEV_TALITOS2
844 #define TALITOS_MAX_KEY_SIZE (AES_MAX_KEY_SIZE + SHA512_BLOCK_SIZE)
846 #define TALITOS_MAX_KEY_SIZE (AES_MAX_KEY_SIZE + SHA256_BLOCK_SIZE)
848 #define TALITOS_MAX_IV_LENGTH 16 /* max of AES_BLOCK_SIZE, DES3_EDE_BLOCK_SIZE */
853 __be32 desc_hdr_template
;
854 u8 key
[TALITOS_MAX_KEY_SIZE
];
855 u8 iv
[TALITOS_MAX_IV_LENGTH
];
858 unsigned int enckeylen
;
859 unsigned int authkeylen
;
862 #define HASH_MAX_BLOCK_SIZE SHA512_BLOCK_SIZE
863 #define TALITOS_MDEU_MAX_CONTEXT_SIZE TALITOS_MDEU_CONTEXT_SIZE_SHA384_SHA512
865 struct talitos_ahash_req_ctx
{
866 u32 hw_context
[TALITOS_MDEU_MAX_CONTEXT_SIZE
/ sizeof(u32
)];
867 unsigned int hw_context_size
;
868 u8 buf
[2][HASH_MAX_BLOCK_SIZE
];
873 unsigned int to_hash_later
;
875 struct scatterlist bufsl
[2];
876 struct scatterlist
*psrc
;
879 struct talitos_export_state
{
880 u32 hw_context
[TALITOS_MDEU_MAX_CONTEXT_SIZE
/ sizeof(u32
)];
881 u8 buf
[HASH_MAX_BLOCK_SIZE
];
885 unsigned int to_hash_later
;
889 static int aead_setkey(struct crypto_aead
*authenc
,
890 const u8
*key
, unsigned int keylen
)
892 struct talitos_ctx
*ctx
= crypto_aead_ctx(authenc
);
893 struct device
*dev
= ctx
->dev
;
894 struct crypto_authenc_keys keys
;
896 if (crypto_authenc_extractkeys(&keys
, key
, keylen
) != 0)
899 if (keys
.authkeylen
+ keys
.enckeylen
> TALITOS_MAX_KEY_SIZE
)
903 dma_unmap_single(dev
, ctx
->dma_key
, ctx
->keylen
, DMA_TO_DEVICE
);
905 memcpy(ctx
->key
, keys
.authkey
, keys
.authkeylen
);
906 memcpy(&ctx
->key
[keys
.authkeylen
], keys
.enckey
, keys
.enckeylen
);
908 ctx
->keylen
= keys
.authkeylen
+ keys
.enckeylen
;
909 ctx
->enckeylen
= keys
.enckeylen
;
910 ctx
->authkeylen
= keys
.authkeylen
;
911 ctx
->dma_key
= dma_map_single(dev
, ctx
->key
, ctx
->keylen
,
914 memzero_explicit(&keys
, sizeof(keys
));
918 memzero_explicit(&keys
, sizeof(keys
));
922 static int aead_des3_setkey(struct crypto_aead
*authenc
,
923 const u8
*key
, unsigned int keylen
)
925 struct talitos_ctx
*ctx
= crypto_aead_ctx(authenc
);
926 struct device
*dev
= ctx
->dev
;
927 struct crypto_authenc_keys keys
;
930 err
= crypto_authenc_extractkeys(&keys
, key
, keylen
);
935 if (keys
.authkeylen
+ keys
.enckeylen
> TALITOS_MAX_KEY_SIZE
)
938 err
= verify_aead_des3_key(authenc
, keys
.enckey
, keys
.enckeylen
);
943 dma_unmap_single(dev
, ctx
->dma_key
, ctx
->keylen
, DMA_TO_DEVICE
);
945 memcpy(ctx
->key
, keys
.authkey
, keys
.authkeylen
);
946 memcpy(&ctx
->key
[keys
.authkeylen
], keys
.enckey
, keys
.enckeylen
);
948 ctx
->keylen
= keys
.authkeylen
+ keys
.enckeylen
;
949 ctx
->enckeylen
= keys
.enckeylen
;
950 ctx
->authkeylen
= keys
.authkeylen
;
951 ctx
->dma_key
= dma_map_single(dev
, ctx
->key
, ctx
->keylen
,
955 memzero_explicit(&keys
, sizeof(keys
));
959 static void talitos_sg_unmap(struct device
*dev
,
960 struct talitos_edesc
*edesc
,
961 struct scatterlist
*src
,
962 struct scatterlist
*dst
,
963 unsigned int len
, unsigned int offset
)
965 struct talitos_private
*priv
= dev_get_drvdata(dev
);
966 bool is_sec1
= has_ftr_sec1(priv
);
967 unsigned int src_nents
= edesc
->src_nents
? : 1;
968 unsigned int dst_nents
= edesc
->dst_nents
? : 1;
970 if (is_sec1
&& dst
&& dst_nents
> 1) {
971 dma_sync_single_for_device(dev
, edesc
->dma_link_tbl
+ offset
,
972 len
, DMA_FROM_DEVICE
);
973 sg_pcopy_from_buffer(dst
, dst_nents
, edesc
->buf
+ offset
, len
,
977 if (src_nents
== 1 || !is_sec1
)
978 dma_unmap_sg(dev
, src
, src_nents
, DMA_TO_DEVICE
);
980 if (dst
&& (dst_nents
== 1 || !is_sec1
))
981 dma_unmap_sg(dev
, dst
, dst_nents
, DMA_FROM_DEVICE
);
982 } else if (src_nents
== 1 || !is_sec1
) {
983 dma_unmap_sg(dev
, src
, src_nents
, DMA_BIDIRECTIONAL
);
987 static void ipsec_esp_unmap(struct device
*dev
,
988 struct talitos_edesc
*edesc
,
989 struct aead_request
*areq
, bool encrypt
)
991 struct crypto_aead
*aead
= crypto_aead_reqtfm(areq
);
992 struct talitos_ctx
*ctx
= crypto_aead_ctx(aead
);
993 unsigned int ivsize
= crypto_aead_ivsize(aead
);
994 unsigned int authsize
= crypto_aead_authsize(aead
);
995 unsigned int cryptlen
= areq
->cryptlen
- (encrypt
? 0 : authsize
);
996 bool is_ipsec_esp
= edesc
->desc
.hdr
& DESC_HDR_TYPE_IPSEC_ESP
;
997 struct talitos_ptr
*civ_ptr
= &edesc
->desc
.ptr
[is_ipsec_esp
? 2 : 3];
1000 unmap_single_talitos_ptr(dev
, &edesc
->desc
.ptr
[6],
1002 unmap_single_talitos_ptr(dev
, civ_ptr
, DMA_TO_DEVICE
);
1004 talitos_sg_unmap(dev
, edesc
, areq
->src
, areq
->dst
,
1005 cryptlen
+ authsize
, areq
->assoclen
);
1008 dma_unmap_single(dev
, edesc
->dma_link_tbl
, edesc
->dma_len
,
1011 if (!is_ipsec_esp
) {
1012 unsigned int dst_nents
= edesc
->dst_nents
? : 1;
1014 sg_pcopy_to_buffer(areq
->dst
, dst_nents
, ctx
->iv
, ivsize
,
1015 areq
->assoclen
+ cryptlen
- ivsize
);
1020 * ipsec_esp descriptor callbacks
1022 static void ipsec_esp_encrypt_done(struct device
*dev
,
1023 struct talitos_desc
*desc
, void *context
,
1026 struct aead_request
*areq
= context
;
1027 struct crypto_aead
*authenc
= crypto_aead_reqtfm(areq
);
1028 unsigned int ivsize
= crypto_aead_ivsize(authenc
);
1029 struct talitos_edesc
*edesc
;
1031 edesc
= container_of(desc
, struct talitos_edesc
, desc
);
1033 ipsec_esp_unmap(dev
, edesc
, areq
, true);
1035 dma_unmap_single(dev
, edesc
->iv_dma
, ivsize
, DMA_TO_DEVICE
);
1039 aead_request_complete(areq
, err
);
1042 static void ipsec_esp_decrypt_swauth_done(struct device
*dev
,
1043 struct talitos_desc
*desc
,
1044 void *context
, int err
)
1046 struct aead_request
*req
= context
;
1047 struct crypto_aead
*authenc
= crypto_aead_reqtfm(req
);
1048 unsigned int authsize
= crypto_aead_authsize(authenc
);
1049 struct talitos_edesc
*edesc
;
1052 edesc
= container_of(desc
, struct talitos_edesc
, desc
);
1054 ipsec_esp_unmap(dev
, edesc
, req
, false);
1058 oicv
= edesc
->buf
+ edesc
->dma_len
;
1059 icv
= oicv
- authsize
;
1061 err
= crypto_memneq(oicv
, icv
, authsize
) ? -EBADMSG
: 0;
1066 aead_request_complete(req
, err
);
1069 static void ipsec_esp_decrypt_hwauth_done(struct device
*dev
,
1070 struct talitos_desc
*desc
,
1071 void *context
, int err
)
1073 struct aead_request
*req
= context
;
1074 struct talitos_edesc
*edesc
;
1076 edesc
= container_of(desc
, struct talitos_edesc
, desc
);
1078 ipsec_esp_unmap(dev
, edesc
, req
, false);
1080 /* check ICV auth status */
1081 if (!err
&& ((desc
->hdr_lo
& DESC_HDR_LO_ICCR1_MASK
) !=
1082 DESC_HDR_LO_ICCR1_PASS
))
1087 aead_request_complete(req
, err
);
1091 * convert scatterlist to SEC h/w link table format
1092 * stop at cryptlen bytes
1094 static int sg_to_link_tbl_offset(struct scatterlist
*sg
, int sg_count
,
1095 unsigned int offset
, int datalen
, int elen
,
1096 struct talitos_ptr
*link_tbl_ptr
, int align
)
1098 int n_sg
= elen
? sg_count
+ 1 : sg_count
;
1100 int cryptlen
= datalen
+ elen
;
1101 int padding
= ALIGN(cryptlen
, align
) - cryptlen
;
1103 while (cryptlen
&& sg
&& n_sg
--) {
1104 unsigned int len
= sg_dma_len(sg
);
1106 if (offset
>= len
) {
1116 if (datalen
> 0 && len
> datalen
) {
1117 to_talitos_ptr(link_tbl_ptr
+ count
,
1118 sg_dma_address(sg
) + offset
, datalen
, 0);
1119 to_talitos_ptr_ext_set(link_tbl_ptr
+ count
, 0, 0);
1124 to_talitos_ptr(link_tbl_ptr
+ count
,
1125 sg_dma_address(sg
) + offset
, sg_next(sg
) ? len
: len
+ padding
, 0);
1126 to_talitos_ptr_ext_set(link_tbl_ptr
+ count
, 0, 0);
1136 /* tag end of link table */
1138 to_talitos_ptr_ext_set(link_tbl_ptr
+ count
- 1,
1139 DESC_PTR_LNKTBL_RET
, 0);
1144 static int talitos_sg_map_ext(struct device
*dev
, struct scatterlist
*src
,
1145 unsigned int len
, struct talitos_edesc
*edesc
,
1146 struct talitos_ptr
*ptr
, int sg_count
,
1147 unsigned int offset
, int tbl_off
, int elen
,
1148 bool force
, int align
)
1150 struct talitos_private
*priv
= dev_get_drvdata(dev
);
1151 bool is_sec1
= has_ftr_sec1(priv
);
1152 int aligned_len
= ALIGN(len
, align
);
1155 to_talitos_ptr(ptr
, 0, 0, is_sec1
);
1158 to_talitos_ptr_ext_set(ptr
, elen
, is_sec1
);
1159 if (sg_count
== 1 && !force
) {
1160 to_talitos_ptr(ptr
, sg_dma_address(src
) + offset
, aligned_len
, is_sec1
);
1164 to_talitos_ptr(ptr
, edesc
->dma_link_tbl
+ offset
, aligned_len
, is_sec1
);
1167 sg_count
= sg_to_link_tbl_offset(src
, sg_count
, offset
, len
, elen
,
1168 &edesc
->link_tbl
[tbl_off
], align
);
1169 if (sg_count
== 1 && !force
) {
1170 /* Only one segment now, so no link tbl needed*/
1171 copy_talitos_ptr(ptr
, &edesc
->link_tbl
[tbl_off
], is_sec1
);
1174 to_talitos_ptr(ptr
, edesc
->dma_link_tbl
+
1175 tbl_off
* sizeof(struct talitos_ptr
), aligned_len
, is_sec1
);
1176 to_talitos_ptr_ext_or(ptr
, DESC_PTR_LNKTBL_JUMP
, is_sec1
);
1181 static int talitos_sg_map(struct device
*dev
, struct scatterlist
*src
,
1182 unsigned int len
, struct talitos_edesc
*edesc
,
1183 struct talitos_ptr
*ptr
, int sg_count
,
1184 unsigned int offset
, int tbl_off
)
1186 return talitos_sg_map_ext(dev
, src
, len
, edesc
, ptr
, sg_count
, offset
,
1187 tbl_off
, 0, false, 1);
1191 * fill in and submit ipsec_esp descriptor
1193 static int ipsec_esp(struct talitos_edesc
*edesc
, struct aead_request
*areq
,
1195 void (*callback
)(struct device
*dev
,
1196 struct talitos_desc
*desc
,
1197 void *context
, int error
))
1199 struct crypto_aead
*aead
= crypto_aead_reqtfm(areq
);
1200 unsigned int authsize
= crypto_aead_authsize(aead
);
1201 struct talitos_ctx
*ctx
= crypto_aead_ctx(aead
);
1202 struct device
*dev
= ctx
->dev
;
1203 struct talitos_desc
*desc
= &edesc
->desc
;
1204 unsigned int cryptlen
= areq
->cryptlen
- (encrypt
? 0 : authsize
);
1205 unsigned int ivsize
= crypto_aead_ivsize(aead
);
1209 bool sync_needed
= false;
1210 struct talitos_private
*priv
= dev_get_drvdata(dev
);
1211 bool is_sec1
= has_ftr_sec1(priv
);
1212 bool is_ipsec_esp
= desc
->hdr
& DESC_HDR_TYPE_IPSEC_ESP
;
1213 struct talitos_ptr
*civ_ptr
= &desc
->ptr
[is_ipsec_esp
? 2 : 3];
1214 struct talitos_ptr
*ckey_ptr
= &desc
->ptr
[is_ipsec_esp
? 3 : 2];
1215 dma_addr_t dma_icv
= edesc
->dma_link_tbl
+ edesc
->dma_len
- authsize
;
1218 to_talitos_ptr(&desc
->ptr
[0], ctx
->dma_key
, ctx
->authkeylen
, is_sec1
);
1220 sg_count
= edesc
->src_nents
?: 1;
1221 if (is_sec1
&& sg_count
> 1)
1222 sg_copy_to_buffer(areq
->src
, sg_count
, edesc
->buf
,
1223 areq
->assoclen
+ cryptlen
);
1225 sg_count
= dma_map_sg(dev
, areq
->src
, sg_count
,
1226 (areq
->src
== areq
->dst
) ?
1227 DMA_BIDIRECTIONAL
: DMA_TO_DEVICE
);
1230 ret
= talitos_sg_map(dev
, areq
->src
, areq
->assoclen
, edesc
,
1231 &desc
->ptr
[1], sg_count
, 0, tbl_off
);
1239 to_talitos_ptr(civ_ptr
, edesc
->iv_dma
, ivsize
, is_sec1
);
1242 to_talitos_ptr(ckey_ptr
, ctx
->dma_key
+ ctx
->authkeylen
,
1243 ctx
->enckeylen
, is_sec1
);
1247 * map and adjust cipher len to aead request cryptlen.
1248 * extent is bytes of HMAC postpended to ciphertext,
1249 * typically 12 for ipsec
1251 if (is_ipsec_esp
&& (desc
->hdr
& DESC_HDR_MODE1_MDEU_CICV
))
1254 ret
= talitos_sg_map_ext(dev
, areq
->src
, cryptlen
, edesc
, &desc
->ptr
[4],
1255 sg_count
, areq
->assoclen
, tbl_off
, elen
,
1264 if (areq
->src
!= areq
->dst
) {
1265 sg_count
= edesc
->dst_nents
? : 1;
1266 if (!is_sec1
|| sg_count
== 1)
1267 dma_map_sg(dev
, areq
->dst
, sg_count
, DMA_FROM_DEVICE
);
1270 if (is_ipsec_esp
&& encrypt
)
1274 ret
= talitos_sg_map_ext(dev
, areq
->dst
, cryptlen
, edesc
, &desc
->ptr
[5],
1275 sg_count
, areq
->assoclen
, tbl_off
, elen
,
1276 is_ipsec_esp
&& !encrypt
, 1);
1279 if (!encrypt
&& is_ipsec_esp
) {
1280 struct talitos_ptr
*tbl_ptr
= &edesc
->link_tbl
[tbl_off
];
1282 /* Add an entry to the link table for ICV data */
1283 to_talitos_ptr_ext_set(tbl_ptr
- 1, 0, is_sec1
);
1284 to_talitos_ptr_ext_set(tbl_ptr
, DESC_PTR_LNKTBL_RET
, is_sec1
);
1286 /* icv data follows link tables */
1287 to_talitos_ptr(tbl_ptr
, dma_icv
, authsize
, is_sec1
);
1288 to_talitos_ptr_ext_or(&desc
->ptr
[5], authsize
, is_sec1
);
1290 } else if (!encrypt
) {
1291 to_talitos_ptr(&desc
->ptr
[6], dma_icv
, authsize
, is_sec1
);
1293 } else if (!is_ipsec_esp
) {
1294 talitos_sg_map(dev
, areq
->dst
, authsize
, edesc
, &desc
->ptr
[6],
1295 sg_count
, areq
->assoclen
+ cryptlen
, tbl_off
);
1300 map_single_talitos_ptr(dev
, &desc
->ptr
[6], ivsize
, ctx
->iv
,
1304 dma_sync_single_for_device(dev
, edesc
->dma_link_tbl
,
1308 ret
= talitos_submit(dev
, ctx
->ch
, desc
, callback
, areq
);
1309 if (ret
!= -EINPROGRESS
) {
1310 ipsec_esp_unmap(dev
, edesc
, areq
, encrypt
);
1317 * allocate and map the extended descriptor
1319 static struct talitos_edesc
*talitos_edesc_alloc(struct device
*dev
,
1320 struct scatterlist
*src
,
1321 struct scatterlist
*dst
,
1323 unsigned int assoclen
,
1324 unsigned int cryptlen
,
1325 unsigned int authsize
,
1326 unsigned int ivsize
,
1331 struct talitos_edesc
*edesc
;
1332 int src_nents
, dst_nents
, alloc_len
, dma_len
, src_len
, dst_len
;
1333 dma_addr_t iv_dma
= 0;
1334 gfp_t flags
= cryptoflags
& CRYPTO_TFM_REQ_MAY_SLEEP
? GFP_KERNEL
:
1336 struct talitos_private
*priv
= dev_get_drvdata(dev
);
1337 bool is_sec1
= has_ftr_sec1(priv
);
1338 int max_len
= is_sec1
? TALITOS1_MAX_DATA_LEN
: TALITOS2_MAX_DATA_LEN
;
1340 if (cryptlen
+ authsize
> max_len
) {
1341 dev_err(dev
, "length exceeds h/w max limit\n");
1342 return ERR_PTR(-EINVAL
);
1345 if (!dst
|| dst
== src
) {
1346 src_len
= assoclen
+ cryptlen
+ authsize
;
1347 src_nents
= sg_nents_for_len(src
, src_len
);
1348 if (src_nents
< 0) {
1349 dev_err(dev
, "Invalid number of src SG.\n");
1350 return ERR_PTR(-EINVAL
);
1352 src_nents
= (src_nents
== 1) ? 0 : src_nents
;
1353 dst_nents
= dst
? src_nents
: 0;
1355 } else { /* dst && dst != src*/
1356 src_len
= assoclen
+ cryptlen
+ (encrypt
? 0 : authsize
);
1357 src_nents
= sg_nents_for_len(src
, src_len
);
1358 if (src_nents
< 0) {
1359 dev_err(dev
, "Invalid number of src SG.\n");
1360 return ERR_PTR(-EINVAL
);
1362 src_nents
= (src_nents
== 1) ? 0 : src_nents
;
1363 dst_len
= assoclen
+ cryptlen
+ (encrypt
? authsize
: 0);
1364 dst_nents
= sg_nents_for_len(dst
, dst_len
);
1365 if (dst_nents
< 0) {
1366 dev_err(dev
, "Invalid number of dst SG.\n");
1367 return ERR_PTR(-EINVAL
);
1369 dst_nents
= (dst_nents
== 1) ? 0 : dst_nents
;
1373 * allocate space for base edesc plus the link tables,
1374 * allowing for two separate entries for AD and generated ICV (+ 2),
1375 * and space for two sets of ICVs (stashed and generated)
1377 alloc_len
= sizeof(struct talitos_edesc
);
1378 if (src_nents
|| dst_nents
|| !encrypt
) {
1380 dma_len
= (src_nents
? src_len
: 0) +
1381 (dst_nents
? dst_len
: 0) + authsize
;
1383 dma_len
= (src_nents
+ dst_nents
+ 2) *
1384 sizeof(struct talitos_ptr
) + authsize
;
1385 alloc_len
+= dma_len
;
1389 alloc_len
+= icv_stashing
? authsize
: 0;
1391 /* if its a ahash, add space for a second desc next to the first one */
1392 if (is_sec1
&& !dst
)
1393 alloc_len
+= sizeof(struct talitos_desc
);
1394 alloc_len
+= ivsize
;
1396 edesc
= kmalloc(ALIGN(alloc_len
, dma_get_cache_alignment()), flags
);
1398 return ERR_PTR(-ENOMEM
);
1400 iv
= memcpy(((u8
*)edesc
) + alloc_len
- ivsize
, iv
, ivsize
);
1401 iv_dma
= dma_map_single(dev
, iv
, ivsize
, DMA_TO_DEVICE
);
1403 memset(&edesc
->desc
, 0, sizeof(edesc
->desc
));
1405 edesc
->src_nents
= src_nents
;
1406 edesc
->dst_nents
= dst_nents
;
1407 edesc
->iv_dma
= iv_dma
;
1408 edesc
->dma_len
= dma_len
;
1410 edesc
->dma_link_tbl
= dma_map_single(dev
, &edesc
->link_tbl
[0],
1417 static struct talitos_edesc
*aead_edesc_alloc(struct aead_request
*areq
, u8
*iv
,
1418 int icv_stashing
, bool encrypt
)
1420 struct crypto_aead
*authenc
= crypto_aead_reqtfm(areq
);
1421 unsigned int authsize
= crypto_aead_authsize(authenc
);
1422 struct talitos_ctx
*ctx
= crypto_aead_ctx(authenc
);
1423 unsigned int ivsize
= crypto_aead_ivsize(authenc
);
1424 unsigned int cryptlen
= areq
->cryptlen
- (encrypt
? 0 : authsize
);
1426 return talitos_edesc_alloc(ctx
->dev
, areq
->src
, areq
->dst
,
1427 iv
, areq
->assoclen
, cryptlen
,
1428 authsize
, ivsize
, icv_stashing
,
1429 areq
->base
.flags
, encrypt
);
1432 static int aead_encrypt(struct aead_request
*req
)
1434 struct crypto_aead
*authenc
= crypto_aead_reqtfm(req
);
1435 struct talitos_ctx
*ctx
= crypto_aead_ctx(authenc
);
1436 struct talitos_edesc
*edesc
;
1438 /* allocate extended descriptor */
1439 edesc
= aead_edesc_alloc(req
, req
->iv
, 0, true);
1441 return PTR_ERR(edesc
);
1444 edesc
->desc
.hdr
= ctx
->desc_hdr_template
| DESC_HDR_MODE0_ENCRYPT
;
1446 return ipsec_esp(edesc
, req
, true, ipsec_esp_encrypt_done
);
1449 static int aead_decrypt(struct aead_request
*req
)
1451 struct crypto_aead
*authenc
= crypto_aead_reqtfm(req
);
1452 unsigned int authsize
= crypto_aead_authsize(authenc
);
1453 struct talitos_ctx
*ctx
= crypto_aead_ctx(authenc
);
1454 struct talitos_private
*priv
= dev_get_drvdata(ctx
->dev
);
1455 struct talitos_edesc
*edesc
;
1458 /* allocate extended descriptor */
1459 edesc
= aead_edesc_alloc(req
, req
->iv
, 1, false);
1461 return PTR_ERR(edesc
);
1463 if ((edesc
->desc
.hdr
& DESC_HDR_TYPE_IPSEC_ESP
) &&
1464 (priv
->features
& TALITOS_FTR_HW_AUTH_CHECK
) &&
1465 ((!edesc
->src_nents
&& !edesc
->dst_nents
) ||
1466 priv
->features
& TALITOS_FTR_SRC_LINK_TBL_LEN_INCLUDES_EXTENT
)) {
1468 /* decrypt and check the ICV */
1469 edesc
->desc
.hdr
= ctx
->desc_hdr_template
|
1470 DESC_HDR_DIR_INBOUND
|
1471 DESC_HDR_MODE1_MDEU_CICV
;
1473 /* reset integrity check result bits */
1475 return ipsec_esp(edesc
, req
, false,
1476 ipsec_esp_decrypt_hwauth_done
);
1479 /* Have to check the ICV with software */
1480 edesc
->desc
.hdr
= ctx
->desc_hdr_template
| DESC_HDR_DIR_INBOUND
;
1482 /* stash incoming ICV for later cmp with ICV generated by the h/w */
1483 icvdata
= edesc
->buf
+ edesc
->dma_len
;
1485 sg_pcopy_to_buffer(req
->src
, edesc
->src_nents
? : 1, icvdata
, authsize
,
1486 req
->assoclen
+ req
->cryptlen
- authsize
);
1488 return ipsec_esp(edesc
, req
, false, ipsec_esp_decrypt_swauth_done
);
1491 static int skcipher_setkey(struct crypto_skcipher
*cipher
,
1492 const u8
*key
, unsigned int keylen
)
1494 struct talitos_ctx
*ctx
= crypto_skcipher_ctx(cipher
);
1495 struct device
*dev
= ctx
->dev
;
1498 dma_unmap_single(dev
, ctx
->dma_key
, ctx
->keylen
, DMA_TO_DEVICE
);
1500 memcpy(&ctx
->key
, key
, keylen
);
1501 ctx
->keylen
= keylen
;
1503 ctx
->dma_key
= dma_map_single(dev
, ctx
->key
, keylen
, DMA_TO_DEVICE
);
1508 static int skcipher_des_setkey(struct crypto_skcipher
*cipher
,
1509 const u8
*key
, unsigned int keylen
)
1511 return verify_skcipher_des_key(cipher
, key
) ?:
1512 skcipher_setkey(cipher
, key
, keylen
);
1515 static int skcipher_des3_setkey(struct crypto_skcipher
*cipher
,
1516 const u8
*key
, unsigned int keylen
)
1518 return verify_skcipher_des3_key(cipher
, key
) ?:
1519 skcipher_setkey(cipher
, key
, keylen
);
1522 static int skcipher_aes_setkey(struct crypto_skcipher
*cipher
,
1523 const u8
*key
, unsigned int keylen
)
1525 if (keylen
== AES_KEYSIZE_128
|| keylen
== AES_KEYSIZE_192
||
1526 keylen
== AES_KEYSIZE_256
)
1527 return skcipher_setkey(cipher
, key
, keylen
);
1532 static void common_nonsnoop_unmap(struct device
*dev
,
1533 struct talitos_edesc
*edesc
,
1534 struct skcipher_request
*areq
)
1536 unmap_single_talitos_ptr(dev
, &edesc
->desc
.ptr
[5], DMA_FROM_DEVICE
);
1538 talitos_sg_unmap(dev
, edesc
, areq
->src
, areq
->dst
, areq
->cryptlen
, 0);
1539 unmap_single_talitos_ptr(dev
, &edesc
->desc
.ptr
[1], DMA_TO_DEVICE
);
1542 dma_unmap_single(dev
, edesc
->dma_link_tbl
, edesc
->dma_len
,
1546 static void skcipher_done(struct device
*dev
,
1547 struct talitos_desc
*desc
, void *context
,
1550 struct skcipher_request
*areq
= context
;
1551 struct crypto_skcipher
*cipher
= crypto_skcipher_reqtfm(areq
);
1552 struct talitos_ctx
*ctx
= crypto_skcipher_ctx(cipher
);
1553 unsigned int ivsize
= crypto_skcipher_ivsize(cipher
);
1554 struct talitos_edesc
*edesc
;
1556 edesc
= container_of(desc
, struct talitos_edesc
, desc
);
1558 common_nonsnoop_unmap(dev
, edesc
, areq
);
1559 memcpy(areq
->iv
, ctx
->iv
, ivsize
);
1563 skcipher_request_complete(areq
, err
);
1566 static int common_nonsnoop(struct talitos_edesc
*edesc
,
1567 struct skcipher_request
*areq
,
1568 void (*callback
) (struct device
*dev
,
1569 struct talitos_desc
*desc
,
1570 void *context
, int error
))
1572 struct crypto_skcipher
*cipher
= crypto_skcipher_reqtfm(areq
);
1573 struct talitos_ctx
*ctx
= crypto_skcipher_ctx(cipher
);
1574 struct device
*dev
= ctx
->dev
;
1575 struct talitos_desc
*desc
= &edesc
->desc
;
1576 unsigned int cryptlen
= areq
->cryptlen
;
1577 unsigned int ivsize
= crypto_skcipher_ivsize(cipher
);
1579 bool sync_needed
= false;
1580 struct talitos_private
*priv
= dev_get_drvdata(dev
);
1581 bool is_sec1
= has_ftr_sec1(priv
);
1582 bool is_ctr
= (desc
->hdr
& DESC_HDR_SEL0_MASK
) == DESC_HDR_SEL0_AESU
&&
1583 (desc
->hdr
& DESC_HDR_MODE0_AESU_MASK
) == DESC_HDR_MODE0_AESU_CTR
;
1585 /* first DWORD empty */
1588 to_talitos_ptr(&desc
->ptr
[1], edesc
->iv_dma
, ivsize
, is_sec1
);
1591 to_talitos_ptr(&desc
->ptr
[2], ctx
->dma_key
, ctx
->keylen
, is_sec1
);
1593 sg_count
= edesc
->src_nents
?: 1;
1594 if (is_sec1
&& sg_count
> 1)
1595 sg_copy_to_buffer(areq
->src
, sg_count
, edesc
->buf
,
1598 sg_count
= dma_map_sg(dev
, areq
->src
, sg_count
,
1599 (areq
->src
== areq
->dst
) ?
1600 DMA_BIDIRECTIONAL
: DMA_TO_DEVICE
);
1604 sg_count
= talitos_sg_map_ext(dev
, areq
->src
, cryptlen
, edesc
, &desc
->ptr
[3],
1605 sg_count
, 0, 0, 0, false, is_ctr
? 16 : 1);
1610 if (areq
->src
!= areq
->dst
) {
1611 sg_count
= edesc
->dst_nents
? : 1;
1612 if (!is_sec1
|| sg_count
== 1)
1613 dma_map_sg(dev
, areq
->dst
, sg_count
, DMA_FROM_DEVICE
);
1616 ret
= talitos_sg_map(dev
, areq
->dst
, cryptlen
, edesc
, &desc
->ptr
[4],
1617 sg_count
, 0, (edesc
->src_nents
+ 1));
1622 map_single_talitos_ptr(dev
, &desc
->ptr
[5], ivsize
, ctx
->iv
,
1625 /* last DWORD empty */
1628 dma_sync_single_for_device(dev
, edesc
->dma_link_tbl
,
1629 edesc
->dma_len
, DMA_BIDIRECTIONAL
);
1631 ret
= talitos_submit(dev
, ctx
->ch
, desc
, callback
, areq
);
1632 if (ret
!= -EINPROGRESS
) {
1633 common_nonsnoop_unmap(dev
, edesc
, areq
);
1639 static struct talitos_edesc
*skcipher_edesc_alloc(struct skcipher_request
*
1642 struct crypto_skcipher
*cipher
= crypto_skcipher_reqtfm(areq
);
1643 struct talitos_ctx
*ctx
= crypto_skcipher_ctx(cipher
);
1644 unsigned int ivsize
= crypto_skcipher_ivsize(cipher
);
1646 return talitos_edesc_alloc(ctx
->dev
, areq
->src
, areq
->dst
,
1647 areq
->iv
, 0, areq
->cryptlen
, 0, ivsize
, 0,
1648 areq
->base
.flags
, encrypt
);
1651 static int skcipher_encrypt(struct skcipher_request
*areq
)
1653 struct crypto_skcipher
*cipher
= crypto_skcipher_reqtfm(areq
);
1654 struct talitos_ctx
*ctx
= crypto_skcipher_ctx(cipher
);
1655 struct talitos_edesc
*edesc
;
1656 unsigned int blocksize
=
1657 crypto_tfm_alg_blocksize(crypto_skcipher_tfm(cipher
));
1659 if (!areq
->cryptlen
)
1662 if (areq
->cryptlen
% blocksize
)
1665 /* allocate extended descriptor */
1666 edesc
= skcipher_edesc_alloc(areq
, true);
1668 return PTR_ERR(edesc
);
1671 edesc
->desc
.hdr
= ctx
->desc_hdr_template
| DESC_HDR_MODE0_ENCRYPT
;
1673 return common_nonsnoop(edesc
, areq
, skcipher_done
);
1676 static int skcipher_decrypt(struct skcipher_request
*areq
)
1678 struct crypto_skcipher
*cipher
= crypto_skcipher_reqtfm(areq
);
1679 struct talitos_ctx
*ctx
= crypto_skcipher_ctx(cipher
);
1680 struct talitos_edesc
*edesc
;
1681 unsigned int blocksize
=
1682 crypto_tfm_alg_blocksize(crypto_skcipher_tfm(cipher
));
1684 if (!areq
->cryptlen
)
1687 if (areq
->cryptlen
% blocksize
)
1690 /* allocate extended descriptor */
1691 edesc
= skcipher_edesc_alloc(areq
, false);
1693 return PTR_ERR(edesc
);
1695 edesc
->desc
.hdr
= ctx
->desc_hdr_template
| DESC_HDR_DIR_INBOUND
;
1697 return common_nonsnoop(edesc
, areq
, skcipher_done
);
1700 static void common_nonsnoop_hash_unmap(struct device
*dev
,
1701 struct talitos_edesc
*edesc
,
1702 struct ahash_request
*areq
)
1704 struct talitos_ahash_req_ctx
*req_ctx
= ahash_request_ctx(areq
);
1705 struct crypto_ahash
*tfm
= crypto_ahash_reqtfm(areq
);
1706 struct talitos_private
*priv
= dev_get_drvdata(dev
);
1707 bool is_sec1
= has_ftr_sec1(priv
);
1708 struct talitos_desc
*desc
= &edesc
->desc
;
1709 struct talitos_desc
*desc2
= (struct talitos_desc
*)
1710 (edesc
->buf
+ edesc
->dma_len
);
1712 unmap_single_talitos_ptr(dev
, &desc
->ptr
[5], DMA_FROM_DEVICE
);
1713 if (desc
->next_desc
&&
1714 desc
->ptr
[5].ptr
!= desc2
->ptr
[5].ptr
)
1715 unmap_single_talitos_ptr(dev
, &desc2
->ptr
[5], DMA_FROM_DEVICE
);
1717 memcpy(areq
->result
, req_ctx
->hw_context
,
1718 crypto_ahash_digestsize(tfm
));
1721 talitos_sg_unmap(dev
, edesc
, req_ctx
->psrc
, NULL
, 0, 0);
1723 /* When using hashctx-in, must unmap it. */
1724 if (from_talitos_ptr_len(&desc
->ptr
[1], is_sec1
))
1725 unmap_single_talitos_ptr(dev
, &desc
->ptr
[1],
1727 else if (desc
->next_desc
)
1728 unmap_single_talitos_ptr(dev
, &desc2
->ptr
[1],
1731 if (is_sec1
&& req_ctx
->nbuf
)
1732 unmap_single_talitos_ptr(dev
, &desc
->ptr
[3],
1736 dma_unmap_single(dev
, edesc
->dma_link_tbl
, edesc
->dma_len
,
1739 if (desc
->next_desc
)
1740 dma_unmap_single(dev
, be32_to_cpu(desc
->next_desc
),
1741 TALITOS_DESC_SIZE
, DMA_BIDIRECTIONAL
);
1744 static void ahash_done(struct device
*dev
,
1745 struct talitos_desc
*desc
, void *context
,
1748 struct ahash_request
*areq
= context
;
1749 struct talitos_edesc
*edesc
=
1750 container_of(desc
, struct talitos_edesc
, desc
);
1751 struct talitos_ahash_req_ctx
*req_ctx
= ahash_request_ctx(areq
);
1753 if (!req_ctx
->last
&& req_ctx
->to_hash_later
) {
1754 /* Position any partial block for next update/final/finup */
1755 req_ctx
->buf_idx
= (req_ctx
->buf_idx
+ 1) & 1;
1756 req_ctx
->nbuf
= req_ctx
->to_hash_later
;
1758 common_nonsnoop_hash_unmap(dev
, edesc
, areq
);
1762 ahash_request_complete(areq
, err
);
1766 * SEC1 doesn't like hashing of 0 sized message, so we do the padding
1767 * ourself and submit a padded block
1769 static void talitos_handle_buggy_hash(struct talitos_ctx
*ctx
,
1770 struct talitos_edesc
*edesc
,
1771 struct talitos_ptr
*ptr
)
1773 static u8 padded_hash
[64] = {
1774 0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
1775 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
1776 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
1777 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
1780 pr_err_once("Bug in SEC1, padding ourself\n");
1781 edesc
->desc
.hdr
&= ~DESC_HDR_MODE0_MDEU_PAD
;
1782 map_single_talitos_ptr(ctx
->dev
, ptr
, sizeof(padded_hash
),
1783 (char *)padded_hash
, DMA_TO_DEVICE
);
1786 static int common_nonsnoop_hash(struct talitos_edesc
*edesc
,
1787 struct ahash_request
*areq
, unsigned int length
,
1788 void (*callback
) (struct device
*dev
,
1789 struct talitos_desc
*desc
,
1790 void *context
, int error
))
1792 struct crypto_ahash
*tfm
= crypto_ahash_reqtfm(areq
);
1793 struct talitos_ctx
*ctx
= crypto_ahash_ctx(tfm
);
1794 struct talitos_ahash_req_ctx
*req_ctx
= ahash_request_ctx(areq
);
1795 struct device
*dev
= ctx
->dev
;
1796 struct talitos_desc
*desc
= &edesc
->desc
;
1798 bool sync_needed
= false;
1799 struct talitos_private
*priv
= dev_get_drvdata(dev
);
1800 bool is_sec1
= has_ftr_sec1(priv
);
1803 /* first DWORD empty */
1805 /* hash context in */
1806 if (!req_ctx
->first
|| req_ctx
->swinit
) {
1807 map_single_talitos_ptr_nosync(dev
, &desc
->ptr
[1],
1808 req_ctx
->hw_context_size
,
1809 req_ctx
->hw_context
,
1811 req_ctx
->swinit
= 0;
1813 /* Indicate next op is not the first. */
1818 to_talitos_ptr(&desc
->ptr
[2], ctx
->dma_key
, ctx
->keylen
,
1821 if (is_sec1
&& req_ctx
->nbuf
)
1822 length
-= req_ctx
->nbuf
;
1824 sg_count
= edesc
->src_nents
?: 1;
1825 if (is_sec1
&& sg_count
> 1)
1826 sg_copy_to_buffer(req_ctx
->psrc
, sg_count
, edesc
->buf
, length
);
1828 sg_count
= dma_map_sg(dev
, req_ctx
->psrc
, sg_count
,
1833 if (is_sec1
&& req_ctx
->nbuf
) {
1834 map_single_talitos_ptr(dev
, &desc
->ptr
[3], req_ctx
->nbuf
,
1835 req_ctx
->buf
[req_ctx
->buf_idx
],
1838 sg_count
= talitos_sg_map(dev
, req_ctx
->psrc
, length
, edesc
,
1839 &desc
->ptr
[3], sg_count
, 0, 0);
1844 /* fifth DWORD empty */
1846 /* hash/HMAC out -or- hash context out */
1848 map_single_talitos_ptr(dev
, &desc
->ptr
[5],
1849 crypto_ahash_digestsize(tfm
),
1850 req_ctx
->hw_context
, DMA_FROM_DEVICE
);
1852 map_single_talitos_ptr_nosync(dev
, &desc
->ptr
[5],
1853 req_ctx
->hw_context_size
,
1854 req_ctx
->hw_context
,
1857 /* last DWORD empty */
1859 if (is_sec1
&& from_talitos_ptr_len(&desc
->ptr
[3], true) == 0)
1860 talitos_handle_buggy_hash(ctx
, edesc
, &desc
->ptr
[3]);
1862 if (is_sec1
&& req_ctx
->nbuf
&& length
) {
1863 struct talitos_desc
*desc2
= (struct talitos_desc
*)
1864 (edesc
->buf
+ edesc
->dma_len
);
1865 dma_addr_t next_desc
;
1867 memset(desc2
, 0, sizeof(*desc2
));
1868 desc2
->hdr
= desc
->hdr
;
1869 desc2
->hdr
&= ~DESC_HDR_MODE0_MDEU_INIT
;
1870 desc2
->hdr1
= desc2
->hdr
;
1871 desc
->hdr
&= ~DESC_HDR_MODE0_MDEU_PAD
;
1872 desc
->hdr
|= DESC_HDR_MODE0_MDEU_CONT
;
1873 desc
->hdr
&= ~DESC_HDR_DONE_NOTIFY
;
1875 if (desc
->ptr
[1].ptr
)
1876 copy_talitos_ptr(&desc2
->ptr
[1], &desc
->ptr
[1],
1879 map_single_talitos_ptr_nosync(dev
, &desc2
->ptr
[1],
1880 req_ctx
->hw_context_size
,
1881 req_ctx
->hw_context
,
1883 copy_talitos_ptr(&desc2
->ptr
[2], &desc
->ptr
[2], is_sec1
);
1884 sg_count
= talitos_sg_map(dev
, req_ctx
->psrc
, length
, edesc
,
1885 &desc2
->ptr
[3], sg_count
, 0, 0);
1888 copy_talitos_ptr(&desc2
->ptr
[5], &desc
->ptr
[5], is_sec1
);
1890 map_single_talitos_ptr_nosync(dev
, &desc
->ptr
[5],
1891 req_ctx
->hw_context_size
,
1892 req_ctx
->hw_context
,
1895 next_desc
= dma_map_single(dev
, &desc2
->hdr1
, TALITOS_DESC_SIZE
,
1897 desc
->next_desc
= cpu_to_be32(next_desc
);
1901 dma_sync_single_for_device(dev
, edesc
->dma_link_tbl
,
1902 edesc
->dma_len
, DMA_BIDIRECTIONAL
);
1904 ret
= talitos_submit(dev
, ctx
->ch
, desc
, callback
, areq
);
1905 if (ret
!= -EINPROGRESS
) {
1906 common_nonsnoop_hash_unmap(dev
, edesc
, areq
);
1912 static struct talitos_edesc
*ahash_edesc_alloc(struct ahash_request
*areq
,
1913 unsigned int nbytes
)
1915 struct crypto_ahash
*tfm
= crypto_ahash_reqtfm(areq
);
1916 struct talitos_ctx
*ctx
= crypto_ahash_ctx(tfm
);
1917 struct talitos_ahash_req_ctx
*req_ctx
= ahash_request_ctx(areq
);
1918 struct talitos_private
*priv
= dev_get_drvdata(ctx
->dev
);
1919 bool is_sec1
= has_ftr_sec1(priv
);
1922 nbytes
-= req_ctx
->nbuf
;
1924 return talitos_edesc_alloc(ctx
->dev
, req_ctx
->psrc
, NULL
, NULL
, 0,
1925 nbytes
, 0, 0, 0, areq
->base
.flags
, false);
1928 static int ahash_init(struct ahash_request
*areq
)
1930 struct crypto_ahash
*tfm
= crypto_ahash_reqtfm(areq
);
1931 struct talitos_ctx
*ctx
= crypto_ahash_ctx(tfm
);
1932 struct device
*dev
= ctx
->dev
;
1933 struct talitos_ahash_req_ctx
*req_ctx
= ahash_request_ctx(areq
);
1937 /* Initialize the context */
1938 req_ctx
->buf_idx
= 0;
1940 req_ctx
->first
= 1; /* first indicates h/w must init its context */
1941 req_ctx
->swinit
= 0; /* assume h/w init of context */
1942 size
= (crypto_ahash_digestsize(tfm
) <= SHA256_DIGEST_SIZE
)
1943 ? TALITOS_MDEU_CONTEXT_SIZE_MD5_SHA1_SHA256
1944 : TALITOS_MDEU_CONTEXT_SIZE_SHA384_SHA512
;
1945 req_ctx
->hw_context_size
= size
;
1947 dma
= dma_map_single(dev
, req_ctx
->hw_context
, req_ctx
->hw_context_size
,
1949 dma_unmap_single(dev
, dma
, req_ctx
->hw_context_size
, DMA_TO_DEVICE
);
1955 * on h/w without explicit sha224 support, we initialize h/w context
1956 * manually with sha224 constants, and tell it to run sha256.
1958 static int ahash_init_sha224_swinit(struct ahash_request
*areq
)
1960 struct talitos_ahash_req_ctx
*req_ctx
= ahash_request_ctx(areq
);
1962 req_ctx
->hw_context
[0] = SHA224_H0
;
1963 req_ctx
->hw_context
[1] = SHA224_H1
;
1964 req_ctx
->hw_context
[2] = SHA224_H2
;
1965 req_ctx
->hw_context
[3] = SHA224_H3
;
1966 req_ctx
->hw_context
[4] = SHA224_H4
;
1967 req_ctx
->hw_context
[5] = SHA224_H5
;
1968 req_ctx
->hw_context
[6] = SHA224_H6
;
1969 req_ctx
->hw_context
[7] = SHA224_H7
;
1971 /* init 64-bit count */
1972 req_ctx
->hw_context
[8] = 0;
1973 req_ctx
->hw_context
[9] = 0;
1976 req_ctx
->swinit
= 1;/* prevent h/w initting context with sha256 values*/
1981 static int ahash_process_req(struct ahash_request
*areq
, unsigned int nbytes
)
1983 struct crypto_ahash
*tfm
= crypto_ahash_reqtfm(areq
);
1984 struct talitos_ctx
*ctx
= crypto_ahash_ctx(tfm
);
1985 struct talitos_ahash_req_ctx
*req_ctx
= ahash_request_ctx(areq
);
1986 struct talitos_edesc
*edesc
;
1987 unsigned int blocksize
=
1988 crypto_tfm_alg_blocksize(crypto_ahash_tfm(tfm
));
1989 unsigned int nbytes_to_hash
;
1990 unsigned int to_hash_later
;
1993 struct device
*dev
= ctx
->dev
;
1994 struct talitos_private
*priv
= dev_get_drvdata(dev
);
1995 bool is_sec1
= has_ftr_sec1(priv
);
1996 u8
*ctx_buf
= req_ctx
->buf
[req_ctx
->buf_idx
];
1998 if (!req_ctx
->last
&& (nbytes
+ req_ctx
->nbuf
<= blocksize
)) {
1999 /* Buffer up to one whole block */
2000 nents
= sg_nents_for_len(areq
->src
, nbytes
);
2002 dev_err(dev
, "Invalid number of src SG.\n");
2005 sg_copy_to_buffer(areq
->src
, nents
,
2006 ctx_buf
+ req_ctx
->nbuf
, nbytes
);
2007 req_ctx
->nbuf
+= nbytes
;
2011 /* At least (blocksize + 1) bytes are available to hash */
2012 nbytes_to_hash
= nbytes
+ req_ctx
->nbuf
;
2013 to_hash_later
= nbytes_to_hash
& (blocksize
- 1);
2017 else if (to_hash_later
)
2018 /* There is a partial block. Hash the full block(s) now */
2019 nbytes_to_hash
-= to_hash_later
;
2021 /* Keep one block buffered */
2022 nbytes_to_hash
-= blocksize
;
2023 to_hash_later
= blocksize
;
2026 /* Chain in any previously buffered data */
2027 if (!is_sec1
&& req_ctx
->nbuf
) {
2028 nsg
= (req_ctx
->nbuf
< nbytes_to_hash
) ? 2 : 1;
2029 sg_init_table(req_ctx
->bufsl
, nsg
);
2030 sg_set_buf(req_ctx
->bufsl
, ctx_buf
, req_ctx
->nbuf
);
2032 sg_chain(req_ctx
->bufsl
, 2, areq
->src
);
2033 req_ctx
->psrc
= req_ctx
->bufsl
;
2034 } else if (is_sec1
&& req_ctx
->nbuf
&& req_ctx
->nbuf
< blocksize
) {
2037 if (nbytes_to_hash
> blocksize
)
2038 offset
= blocksize
- req_ctx
->nbuf
;
2040 offset
= nbytes_to_hash
- req_ctx
->nbuf
;
2041 nents
= sg_nents_for_len(areq
->src
, offset
);
2043 dev_err(dev
, "Invalid number of src SG.\n");
2046 sg_copy_to_buffer(areq
->src
, nents
,
2047 ctx_buf
+ req_ctx
->nbuf
, offset
);
2048 req_ctx
->nbuf
+= offset
;
2049 req_ctx
->psrc
= scatterwalk_ffwd(req_ctx
->bufsl
, areq
->src
,
2052 req_ctx
->psrc
= areq
->src
;
2054 if (to_hash_later
) {
2055 nents
= sg_nents_for_len(areq
->src
, nbytes
);
2057 dev_err(dev
, "Invalid number of src SG.\n");
2060 sg_pcopy_to_buffer(areq
->src
, nents
,
2061 req_ctx
->buf
[(req_ctx
->buf_idx
+ 1) & 1],
2063 nbytes
- to_hash_later
);
2065 req_ctx
->to_hash_later
= to_hash_later
;
2067 /* Allocate extended descriptor */
2068 edesc
= ahash_edesc_alloc(areq
, nbytes_to_hash
);
2070 return PTR_ERR(edesc
);
2072 edesc
->desc
.hdr
= ctx
->desc_hdr_template
;
2074 /* On last one, request SEC to pad; otherwise continue */
2076 edesc
->desc
.hdr
|= DESC_HDR_MODE0_MDEU_PAD
;
2078 edesc
->desc
.hdr
|= DESC_HDR_MODE0_MDEU_CONT
;
2080 /* request SEC to INIT hash. */
2081 if (req_ctx
->first
&& !req_ctx
->swinit
)
2082 edesc
->desc
.hdr
|= DESC_HDR_MODE0_MDEU_INIT
;
2084 /* When the tfm context has a keylen, it's an HMAC.
2085 * A first or last (ie. not middle) descriptor must request HMAC.
2087 if (ctx
->keylen
&& (req_ctx
->first
|| req_ctx
->last
))
2088 edesc
->desc
.hdr
|= DESC_HDR_MODE0_MDEU_HMAC
;
2090 return common_nonsnoop_hash(edesc
, areq
, nbytes_to_hash
, ahash_done
);
2093 static int ahash_update(struct ahash_request
*areq
)
2095 struct talitos_ahash_req_ctx
*req_ctx
= ahash_request_ctx(areq
);
2099 return ahash_process_req(areq
, areq
->nbytes
);
2102 static int ahash_final(struct ahash_request
*areq
)
2104 struct talitos_ahash_req_ctx
*req_ctx
= ahash_request_ctx(areq
);
2108 return ahash_process_req(areq
, 0);
2111 static int ahash_finup(struct ahash_request
*areq
)
2113 struct talitos_ahash_req_ctx
*req_ctx
= ahash_request_ctx(areq
);
2117 return ahash_process_req(areq
, areq
->nbytes
);
2120 static int ahash_digest(struct ahash_request
*areq
)
2123 return ahash_finup(areq
);
2126 static int ahash_digest_sha224_swinit(struct ahash_request
*areq
)
2128 ahash_init_sha224_swinit(areq
);
2129 return ahash_finup(areq
);
2132 static int ahash_export(struct ahash_request
*areq
, void *out
)
2134 struct talitos_ahash_req_ctx
*req_ctx
= ahash_request_ctx(areq
);
2135 struct talitos_export_state
*export
= out
;
2136 struct crypto_ahash
*tfm
= crypto_ahash_reqtfm(areq
);
2137 struct talitos_ctx
*ctx
= crypto_ahash_ctx(tfm
);
2138 struct device
*dev
= ctx
->dev
;
2141 dma
= dma_map_single(dev
, req_ctx
->hw_context
, req_ctx
->hw_context_size
,
2143 dma_unmap_single(dev
, dma
, req_ctx
->hw_context_size
, DMA_FROM_DEVICE
);
2145 memcpy(export
->hw_context
, req_ctx
->hw_context
,
2146 req_ctx
->hw_context_size
);
2147 memcpy(export
->buf
, req_ctx
->buf
[req_ctx
->buf_idx
], req_ctx
->nbuf
);
2148 export
->swinit
= req_ctx
->swinit
;
2149 export
->first
= req_ctx
->first
;
2150 export
->last
= req_ctx
->last
;
2151 export
->to_hash_later
= req_ctx
->to_hash_later
;
2152 export
->nbuf
= req_ctx
->nbuf
;
2157 static int ahash_import(struct ahash_request
*areq
, const void *in
)
2159 struct talitos_ahash_req_ctx
*req_ctx
= ahash_request_ctx(areq
);
2160 struct crypto_ahash
*tfm
= crypto_ahash_reqtfm(areq
);
2161 struct talitos_ctx
*ctx
= crypto_ahash_ctx(tfm
);
2162 struct device
*dev
= ctx
->dev
;
2163 const struct talitos_export_state
*export
= in
;
2167 memset(req_ctx
, 0, sizeof(*req_ctx
));
2168 size
= (crypto_ahash_digestsize(tfm
) <= SHA256_DIGEST_SIZE
)
2169 ? TALITOS_MDEU_CONTEXT_SIZE_MD5_SHA1_SHA256
2170 : TALITOS_MDEU_CONTEXT_SIZE_SHA384_SHA512
;
2171 req_ctx
->hw_context_size
= size
;
2172 memcpy(req_ctx
->hw_context
, export
->hw_context
, size
);
2173 memcpy(req_ctx
->buf
[0], export
->buf
, export
->nbuf
);
2174 req_ctx
->swinit
= export
->swinit
;
2175 req_ctx
->first
= export
->first
;
2176 req_ctx
->last
= export
->last
;
2177 req_ctx
->to_hash_later
= export
->to_hash_later
;
2178 req_ctx
->nbuf
= export
->nbuf
;
2180 dma
= dma_map_single(dev
, req_ctx
->hw_context
, req_ctx
->hw_context_size
,
2182 dma_unmap_single(dev
, dma
, req_ctx
->hw_context_size
, DMA_TO_DEVICE
);
2187 static int keyhash(struct crypto_ahash
*tfm
, const u8
*key
, unsigned int keylen
,
2190 struct talitos_ctx
*ctx
= crypto_tfm_ctx(crypto_ahash_tfm(tfm
));
2192 struct scatterlist sg
[1];
2193 struct ahash_request
*req
;
2194 struct crypto_wait wait
;
2197 crypto_init_wait(&wait
);
2199 req
= ahash_request_alloc(tfm
, GFP_KERNEL
);
2203 /* Keep tfm keylen == 0 during hash of the long key */
2205 ahash_request_set_callback(req
, CRYPTO_TFM_REQ_MAY_BACKLOG
,
2206 crypto_req_done
, &wait
);
2208 sg_init_one(&sg
[0], key
, keylen
);
2210 ahash_request_set_crypt(req
, sg
, hash
, keylen
);
2211 ret
= crypto_wait_req(crypto_ahash_digest(req
), &wait
);
2213 ahash_request_free(req
);
2218 static int ahash_setkey(struct crypto_ahash
*tfm
, const u8
*key
,
2219 unsigned int keylen
)
2221 struct talitos_ctx
*ctx
= crypto_tfm_ctx(crypto_ahash_tfm(tfm
));
2222 struct device
*dev
= ctx
->dev
;
2223 unsigned int blocksize
=
2224 crypto_tfm_alg_blocksize(crypto_ahash_tfm(tfm
));
2225 unsigned int digestsize
= crypto_ahash_digestsize(tfm
);
2226 unsigned int keysize
= keylen
;
2227 u8 hash
[SHA512_DIGEST_SIZE
];
2230 if (keylen
<= blocksize
)
2231 memcpy(ctx
->key
, key
, keysize
);
2233 /* Must get the hash of the long key */
2234 ret
= keyhash(tfm
, key
, keylen
, hash
);
2239 keysize
= digestsize
;
2240 memcpy(ctx
->key
, hash
, digestsize
);
2244 dma_unmap_single(dev
, ctx
->dma_key
, ctx
->keylen
, DMA_TO_DEVICE
);
2246 ctx
->keylen
= keysize
;
2247 ctx
->dma_key
= dma_map_single(dev
, ctx
->key
, keysize
, DMA_TO_DEVICE
);
2253 struct talitos_alg_template
{
2257 struct skcipher_alg skcipher
;
2258 struct ahash_alg hash
;
2259 struct aead_alg aead
;
2261 __be32 desc_hdr_template
;
2264 static struct talitos_alg_template driver_algs
[] = {
2265 /* AEAD algorithms. These use a single-pass ipsec_esp descriptor */
2266 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2269 .cra_name
= "authenc(hmac(sha1),cbc(aes))",
2270 .cra_driver_name
= "authenc-hmac-sha1-"
2272 .cra_blocksize
= AES_BLOCK_SIZE
,
2273 .cra_flags
= CRYPTO_ALG_ASYNC
|
2274 CRYPTO_ALG_ALLOCATES_MEMORY
,
2276 .ivsize
= AES_BLOCK_SIZE
,
2277 .maxauthsize
= SHA1_DIGEST_SIZE
,
2279 .desc_hdr_template
= DESC_HDR_TYPE_IPSEC_ESP
|
2280 DESC_HDR_SEL0_AESU
|
2281 DESC_HDR_MODE0_AESU_CBC
|
2282 DESC_HDR_SEL1_MDEUA
|
2283 DESC_HDR_MODE1_MDEU_INIT
|
2284 DESC_HDR_MODE1_MDEU_PAD
|
2285 DESC_HDR_MODE1_MDEU_SHA1_HMAC
,
2287 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2288 .priority
= TALITOS_CRA_PRIORITY_AEAD_HSNA
,
2291 .cra_name
= "authenc(hmac(sha1),cbc(aes))",
2292 .cra_driver_name
= "authenc-hmac-sha1-"
2293 "cbc-aes-talitos-hsna",
2294 .cra_blocksize
= AES_BLOCK_SIZE
,
2295 .cra_flags
= CRYPTO_ALG_ASYNC
|
2296 CRYPTO_ALG_ALLOCATES_MEMORY
,
2298 .ivsize
= AES_BLOCK_SIZE
,
2299 .maxauthsize
= SHA1_DIGEST_SIZE
,
2301 .desc_hdr_template
= DESC_HDR_TYPE_HMAC_SNOOP_NO_AFEU
|
2302 DESC_HDR_SEL0_AESU
|
2303 DESC_HDR_MODE0_AESU_CBC
|
2304 DESC_HDR_SEL1_MDEUA
|
2305 DESC_HDR_MODE1_MDEU_INIT
|
2306 DESC_HDR_MODE1_MDEU_PAD
|
2307 DESC_HDR_MODE1_MDEU_SHA1_HMAC
,
2309 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2312 .cra_name
= "authenc(hmac(sha1),"
2314 .cra_driver_name
= "authenc-hmac-sha1-"
2316 .cra_blocksize
= DES3_EDE_BLOCK_SIZE
,
2317 .cra_flags
= CRYPTO_ALG_ASYNC
|
2318 CRYPTO_ALG_ALLOCATES_MEMORY
,
2320 .ivsize
= DES3_EDE_BLOCK_SIZE
,
2321 .maxauthsize
= SHA1_DIGEST_SIZE
,
2322 .setkey
= aead_des3_setkey
,
2324 .desc_hdr_template
= DESC_HDR_TYPE_IPSEC_ESP
|
2326 DESC_HDR_MODE0_DEU_CBC
|
2327 DESC_HDR_MODE0_DEU_3DES
|
2328 DESC_HDR_SEL1_MDEUA
|
2329 DESC_HDR_MODE1_MDEU_INIT
|
2330 DESC_HDR_MODE1_MDEU_PAD
|
2331 DESC_HDR_MODE1_MDEU_SHA1_HMAC
,
2333 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2334 .priority
= TALITOS_CRA_PRIORITY_AEAD_HSNA
,
2337 .cra_name
= "authenc(hmac(sha1),"
2339 .cra_driver_name
= "authenc-hmac-sha1-"
2340 "cbc-3des-talitos-hsna",
2341 .cra_blocksize
= DES3_EDE_BLOCK_SIZE
,
2342 .cra_flags
= CRYPTO_ALG_ASYNC
|
2343 CRYPTO_ALG_ALLOCATES_MEMORY
,
2345 .ivsize
= DES3_EDE_BLOCK_SIZE
,
2346 .maxauthsize
= SHA1_DIGEST_SIZE
,
2347 .setkey
= aead_des3_setkey
,
2349 .desc_hdr_template
= DESC_HDR_TYPE_HMAC_SNOOP_NO_AFEU
|
2351 DESC_HDR_MODE0_DEU_CBC
|
2352 DESC_HDR_MODE0_DEU_3DES
|
2353 DESC_HDR_SEL1_MDEUA
|
2354 DESC_HDR_MODE1_MDEU_INIT
|
2355 DESC_HDR_MODE1_MDEU_PAD
|
2356 DESC_HDR_MODE1_MDEU_SHA1_HMAC
,
2358 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2361 .cra_name
= "authenc(hmac(sha224),cbc(aes))",
2362 .cra_driver_name
= "authenc-hmac-sha224-"
2364 .cra_blocksize
= AES_BLOCK_SIZE
,
2365 .cra_flags
= CRYPTO_ALG_ASYNC
|
2366 CRYPTO_ALG_ALLOCATES_MEMORY
,
2368 .ivsize
= AES_BLOCK_SIZE
,
2369 .maxauthsize
= SHA224_DIGEST_SIZE
,
2371 .desc_hdr_template
= DESC_HDR_TYPE_IPSEC_ESP
|
2372 DESC_HDR_SEL0_AESU
|
2373 DESC_HDR_MODE0_AESU_CBC
|
2374 DESC_HDR_SEL1_MDEUA
|
2375 DESC_HDR_MODE1_MDEU_INIT
|
2376 DESC_HDR_MODE1_MDEU_PAD
|
2377 DESC_HDR_MODE1_MDEU_SHA224_HMAC
,
2379 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2380 .priority
= TALITOS_CRA_PRIORITY_AEAD_HSNA
,
2383 .cra_name
= "authenc(hmac(sha224),cbc(aes))",
2384 .cra_driver_name
= "authenc-hmac-sha224-"
2385 "cbc-aes-talitos-hsna",
2386 .cra_blocksize
= AES_BLOCK_SIZE
,
2387 .cra_flags
= CRYPTO_ALG_ASYNC
|
2388 CRYPTO_ALG_ALLOCATES_MEMORY
,
2390 .ivsize
= AES_BLOCK_SIZE
,
2391 .maxauthsize
= SHA224_DIGEST_SIZE
,
2393 .desc_hdr_template
= DESC_HDR_TYPE_HMAC_SNOOP_NO_AFEU
|
2394 DESC_HDR_SEL0_AESU
|
2395 DESC_HDR_MODE0_AESU_CBC
|
2396 DESC_HDR_SEL1_MDEUA
|
2397 DESC_HDR_MODE1_MDEU_INIT
|
2398 DESC_HDR_MODE1_MDEU_PAD
|
2399 DESC_HDR_MODE1_MDEU_SHA224_HMAC
,
2401 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2404 .cra_name
= "authenc(hmac(sha224),"
2406 .cra_driver_name
= "authenc-hmac-sha224-"
2408 .cra_blocksize
= DES3_EDE_BLOCK_SIZE
,
2409 .cra_flags
= CRYPTO_ALG_ASYNC
|
2410 CRYPTO_ALG_ALLOCATES_MEMORY
,
2412 .ivsize
= DES3_EDE_BLOCK_SIZE
,
2413 .maxauthsize
= SHA224_DIGEST_SIZE
,
2414 .setkey
= aead_des3_setkey
,
2416 .desc_hdr_template
= DESC_HDR_TYPE_IPSEC_ESP
|
2418 DESC_HDR_MODE0_DEU_CBC
|
2419 DESC_HDR_MODE0_DEU_3DES
|
2420 DESC_HDR_SEL1_MDEUA
|
2421 DESC_HDR_MODE1_MDEU_INIT
|
2422 DESC_HDR_MODE1_MDEU_PAD
|
2423 DESC_HDR_MODE1_MDEU_SHA224_HMAC
,
2425 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2426 .priority
= TALITOS_CRA_PRIORITY_AEAD_HSNA
,
2429 .cra_name
= "authenc(hmac(sha224),"
2431 .cra_driver_name
= "authenc-hmac-sha224-"
2432 "cbc-3des-talitos-hsna",
2433 .cra_blocksize
= DES3_EDE_BLOCK_SIZE
,
2434 .cra_flags
= CRYPTO_ALG_ASYNC
|
2435 CRYPTO_ALG_ALLOCATES_MEMORY
,
2437 .ivsize
= DES3_EDE_BLOCK_SIZE
,
2438 .maxauthsize
= SHA224_DIGEST_SIZE
,
2439 .setkey
= aead_des3_setkey
,
2441 .desc_hdr_template
= DESC_HDR_TYPE_HMAC_SNOOP_NO_AFEU
|
2443 DESC_HDR_MODE0_DEU_CBC
|
2444 DESC_HDR_MODE0_DEU_3DES
|
2445 DESC_HDR_SEL1_MDEUA
|
2446 DESC_HDR_MODE1_MDEU_INIT
|
2447 DESC_HDR_MODE1_MDEU_PAD
|
2448 DESC_HDR_MODE1_MDEU_SHA224_HMAC
,
2450 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2453 .cra_name
= "authenc(hmac(sha256),cbc(aes))",
2454 .cra_driver_name
= "authenc-hmac-sha256-"
2456 .cra_blocksize
= AES_BLOCK_SIZE
,
2457 .cra_flags
= CRYPTO_ALG_ASYNC
|
2458 CRYPTO_ALG_ALLOCATES_MEMORY
,
2460 .ivsize
= AES_BLOCK_SIZE
,
2461 .maxauthsize
= SHA256_DIGEST_SIZE
,
2463 .desc_hdr_template
= DESC_HDR_TYPE_IPSEC_ESP
|
2464 DESC_HDR_SEL0_AESU
|
2465 DESC_HDR_MODE0_AESU_CBC
|
2466 DESC_HDR_SEL1_MDEUA
|
2467 DESC_HDR_MODE1_MDEU_INIT
|
2468 DESC_HDR_MODE1_MDEU_PAD
|
2469 DESC_HDR_MODE1_MDEU_SHA256_HMAC
,
2471 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2472 .priority
= TALITOS_CRA_PRIORITY_AEAD_HSNA
,
2475 .cra_name
= "authenc(hmac(sha256),cbc(aes))",
2476 .cra_driver_name
= "authenc-hmac-sha256-"
2477 "cbc-aes-talitos-hsna",
2478 .cra_blocksize
= AES_BLOCK_SIZE
,
2479 .cra_flags
= CRYPTO_ALG_ASYNC
|
2480 CRYPTO_ALG_ALLOCATES_MEMORY
,
2482 .ivsize
= AES_BLOCK_SIZE
,
2483 .maxauthsize
= SHA256_DIGEST_SIZE
,
2485 .desc_hdr_template
= DESC_HDR_TYPE_HMAC_SNOOP_NO_AFEU
|
2486 DESC_HDR_SEL0_AESU
|
2487 DESC_HDR_MODE0_AESU_CBC
|
2488 DESC_HDR_SEL1_MDEUA
|
2489 DESC_HDR_MODE1_MDEU_INIT
|
2490 DESC_HDR_MODE1_MDEU_PAD
|
2491 DESC_HDR_MODE1_MDEU_SHA256_HMAC
,
2493 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2496 .cra_name
= "authenc(hmac(sha256),"
2498 .cra_driver_name
= "authenc-hmac-sha256-"
2500 .cra_blocksize
= DES3_EDE_BLOCK_SIZE
,
2501 .cra_flags
= CRYPTO_ALG_ASYNC
|
2502 CRYPTO_ALG_ALLOCATES_MEMORY
,
2504 .ivsize
= DES3_EDE_BLOCK_SIZE
,
2505 .maxauthsize
= SHA256_DIGEST_SIZE
,
2506 .setkey
= aead_des3_setkey
,
2508 .desc_hdr_template
= DESC_HDR_TYPE_IPSEC_ESP
|
2510 DESC_HDR_MODE0_DEU_CBC
|
2511 DESC_HDR_MODE0_DEU_3DES
|
2512 DESC_HDR_SEL1_MDEUA
|
2513 DESC_HDR_MODE1_MDEU_INIT
|
2514 DESC_HDR_MODE1_MDEU_PAD
|
2515 DESC_HDR_MODE1_MDEU_SHA256_HMAC
,
2517 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2518 .priority
= TALITOS_CRA_PRIORITY_AEAD_HSNA
,
2521 .cra_name
= "authenc(hmac(sha256),"
2523 .cra_driver_name
= "authenc-hmac-sha256-"
2524 "cbc-3des-talitos-hsna",
2525 .cra_blocksize
= DES3_EDE_BLOCK_SIZE
,
2526 .cra_flags
= CRYPTO_ALG_ASYNC
|
2527 CRYPTO_ALG_ALLOCATES_MEMORY
,
2529 .ivsize
= DES3_EDE_BLOCK_SIZE
,
2530 .maxauthsize
= SHA256_DIGEST_SIZE
,
2531 .setkey
= aead_des3_setkey
,
2533 .desc_hdr_template
= DESC_HDR_TYPE_HMAC_SNOOP_NO_AFEU
|
2535 DESC_HDR_MODE0_DEU_CBC
|
2536 DESC_HDR_MODE0_DEU_3DES
|
2537 DESC_HDR_SEL1_MDEUA
|
2538 DESC_HDR_MODE1_MDEU_INIT
|
2539 DESC_HDR_MODE1_MDEU_PAD
|
2540 DESC_HDR_MODE1_MDEU_SHA256_HMAC
,
2542 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2545 .cra_name
= "authenc(hmac(sha384),cbc(aes))",
2546 .cra_driver_name
= "authenc-hmac-sha384-"
2548 .cra_blocksize
= AES_BLOCK_SIZE
,
2549 .cra_flags
= CRYPTO_ALG_ASYNC
|
2550 CRYPTO_ALG_ALLOCATES_MEMORY
,
2552 .ivsize
= AES_BLOCK_SIZE
,
2553 .maxauthsize
= SHA384_DIGEST_SIZE
,
2555 .desc_hdr_template
= DESC_HDR_TYPE_IPSEC_ESP
|
2556 DESC_HDR_SEL0_AESU
|
2557 DESC_HDR_MODE0_AESU_CBC
|
2558 DESC_HDR_SEL1_MDEUB
|
2559 DESC_HDR_MODE1_MDEU_INIT
|
2560 DESC_HDR_MODE1_MDEU_PAD
|
2561 DESC_HDR_MODE1_MDEUB_SHA384_HMAC
,
2563 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2566 .cra_name
= "authenc(hmac(sha384),"
2568 .cra_driver_name
= "authenc-hmac-sha384-"
2570 .cra_blocksize
= DES3_EDE_BLOCK_SIZE
,
2571 .cra_flags
= CRYPTO_ALG_ASYNC
|
2572 CRYPTO_ALG_ALLOCATES_MEMORY
,
2574 .ivsize
= DES3_EDE_BLOCK_SIZE
,
2575 .maxauthsize
= SHA384_DIGEST_SIZE
,
2576 .setkey
= aead_des3_setkey
,
2578 .desc_hdr_template
= DESC_HDR_TYPE_IPSEC_ESP
|
2580 DESC_HDR_MODE0_DEU_CBC
|
2581 DESC_HDR_MODE0_DEU_3DES
|
2582 DESC_HDR_SEL1_MDEUB
|
2583 DESC_HDR_MODE1_MDEU_INIT
|
2584 DESC_HDR_MODE1_MDEU_PAD
|
2585 DESC_HDR_MODE1_MDEUB_SHA384_HMAC
,
2587 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2590 .cra_name
= "authenc(hmac(sha512),cbc(aes))",
2591 .cra_driver_name
= "authenc-hmac-sha512-"
2593 .cra_blocksize
= AES_BLOCK_SIZE
,
2594 .cra_flags
= CRYPTO_ALG_ASYNC
|
2595 CRYPTO_ALG_ALLOCATES_MEMORY
,
2597 .ivsize
= AES_BLOCK_SIZE
,
2598 .maxauthsize
= SHA512_DIGEST_SIZE
,
2600 .desc_hdr_template
= DESC_HDR_TYPE_IPSEC_ESP
|
2601 DESC_HDR_SEL0_AESU
|
2602 DESC_HDR_MODE0_AESU_CBC
|
2603 DESC_HDR_SEL1_MDEUB
|
2604 DESC_HDR_MODE1_MDEU_INIT
|
2605 DESC_HDR_MODE1_MDEU_PAD
|
2606 DESC_HDR_MODE1_MDEUB_SHA512_HMAC
,
2608 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2611 .cra_name
= "authenc(hmac(sha512),"
2613 .cra_driver_name
= "authenc-hmac-sha512-"
2615 .cra_blocksize
= DES3_EDE_BLOCK_SIZE
,
2616 .cra_flags
= CRYPTO_ALG_ASYNC
|
2617 CRYPTO_ALG_ALLOCATES_MEMORY
,
2619 .ivsize
= DES3_EDE_BLOCK_SIZE
,
2620 .maxauthsize
= SHA512_DIGEST_SIZE
,
2621 .setkey
= aead_des3_setkey
,
2623 .desc_hdr_template
= DESC_HDR_TYPE_IPSEC_ESP
|
2625 DESC_HDR_MODE0_DEU_CBC
|
2626 DESC_HDR_MODE0_DEU_3DES
|
2627 DESC_HDR_SEL1_MDEUB
|
2628 DESC_HDR_MODE1_MDEU_INIT
|
2629 DESC_HDR_MODE1_MDEU_PAD
|
2630 DESC_HDR_MODE1_MDEUB_SHA512_HMAC
,
2632 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2635 .cra_name
= "authenc(hmac(md5),cbc(aes))",
2636 .cra_driver_name
= "authenc-hmac-md5-"
2638 .cra_blocksize
= AES_BLOCK_SIZE
,
2639 .cra_flags
= CRYPTO_ALG_ASYNC
|
2640 CRYPTO_ALG_ALLOCATES_MEMORY
,
2642 .ivsize
= AES_BLOCK_SIZE
,
2643 .maxauthsize
= MD5_DIGEST_SIZE
,
2645 .desc_hdr_template
= DESC_HDR_TYPE_IPSEC_ESP
|
2646 DESC_HDR_SEL0_AESU
|
2647 DESC_HDR_MODE0_AESU_CBC
|
2648 DESC_HDR_SEL1_MDEUA
|
2649 DESC_HDR_MODE1_MDEU_INIT
|
2650 DESC_HDR_MODE1_MDEU_PAD
|
2651 DESC_HDR_MODE1_MDEU_MD5_HMAC
,
2653 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2654 .priority
= TALITOS_CRA_PRIORITY_AEAD_HSNA
,
2657 .cra_name
= "authenc(hmac(md5),cbc(aes))",
2658 .cra_driver_name
= "authenc-hmac-md5-"
2659 "cbc-aes-talitos-hsna",
2660 .cra_blocksize
= AES_BLOCK_SIZE
,
2661 .cra_flags
= CRYPTO_ALG_ASYNC
|
2662 CRYPTO_ALG_ALLOCATES_MEMORY
,
2664 .ivsize
= AES_BLOCK_SIZE
,
2665 .maxauthsize
= MD5_DIGEST_SIZE
,
2667 .desc_hdr_template
= DESC_HDR_TYPE_HMAC_SNOOP_NO_AFEU
|
2668 DESC_HDR_SEL0_AESU
|
2669 DESC_HDR_MODE0_AESU_CBC
|
2670 DESC_HDR_SEL1_MDEUA
|
2671 DESC_HDR_MODE1_MDEU_INIT
|
2672 DESC_HDR_MODE1_MDEU_PAD
|
2673 DESC_HDR_MODE1_MDEU_MD5_HMAC
,
2675 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2678 .cra_name
= "authenc(hmac(md5),cbc(des3_ede))",
2679 .cra_driver_name
= "authenc-hmac-md5-"
2681 .cra_blocksize
= DES3_EDE_BLOCK_SIZE
,
2682 .cra_flags
= CRYPTO_ALG_ASYNC
|
2683 CRYPTO_ALG_ALLOCATES_MEMORY
,
2685 .ivsize
= DES3_EDE_BLOCK_SIZE
,
2686 .maxauthsize
= MD5_DIGEST_SIZE
,
2687 .setkey
= aead_des3_setkey
,
2689 .desc_hdr_template
= DESC_HDR_TYPE_IPSEC_ESP
|
2691 DESC_HDR_MODE0_DEU_CBC
|
2692 DESC_HDR_MODE0_DEU_3DES
|
2693 DESC_HDR_SEL1_MDEUA
|
2694 DESC_HDR_MODE1_MDEU_INIT
|
2695 DESC_HDR_MODE1_MDEU_PAD
|
2696 DESC_HDR_MODE1_MDEU_MD5_HMAC
,
2698 { .type
= CRYPTO_ALG_TYPE_AEAD
,
2699 .priority
= TALITOS_CRA_PRIORITY_AEAD_HSNA
,
2702 .cra_name
= "authenc(hmac(md5),cbc(des3_ede))",
2703 .cra_driver_name
= "authenc-hmac-md5-"
2704 "cbc-3des-talitos-hsna",
2705 .cra_blocksize
= DES3_EDE_BLOCK_SIZE
,
2706 .cra_flags
= CRYPTO_ALG_ASYNC
|
2707 CRYPTO_ALG_ALLOCATES_MEMORY
,
2709 .ivsize
= DES3_EDE_BLOCK_SIZE
,
2710 .maxauthsize
= MD5_DIGEST_SIZE
,
2711 .setkey
= aead_des3_setkey
,
2713 .desc_hdr_template
= DESC_HDR_TYPE_HMAC_SNOOP_NO_AFEU
|
2715 DESC_HDR_MODE0_DEU_CBC
|
2716 DESC_HDR_MODE0_DEU_3DES
|
2717 DESC_HDR_SEL1_MDEUA
|
2718 DESC_HDR_MODE1_MDEU_INIT
|
2719 DESC_HDR_MODE1_MDEU_PAD
|
2720 DESC_HDR_MODE1_MDEU_MD5_HMAC
,
2722 /* SKCIPHER algorithms. */
2723 { .type
= CRYPTO_ALG_TYPE_SKCIPHER
,
2725 .base
.cra_name
= "ecb(aes)",
2726 .base
.cra_driver_name
= "ecb-aes-talitos",
2727 .base
.cra_blocksize
= AES_BLOCK_SIZE
,
2728 .base
.cra_flags
= CRYPTO_ALG_ASYNC
|
2729 CRYPTO_ALG_ALLOCATES_MEMORY
,
2730 .min_keysize
= AES_MIN_KEY_SIZE
,
2731 .max_keysize
= AES_MAX_KEY_SIZE
,
2732 .setkey
= skcipher_aes_setkey
,
2734 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2737 { .type
= CRYPTO_ALG_TYPE_SKCIPHER
,
2739 .base
.cra_name
= "cbc(aes)",
2740 .base
.cra_driver_name
= "cbc-aes-talitos",
2741 .base
.cra_blocksize
= AES_BLOCK_SIZE
,
2742 .base
.cra_flags
= CRYPTO_ALG_ASYNC
|
2743 CRYPTO_ALG_ALLOCATES_MEMORY
,
2744 .min_keysize
= AES_MIN_KEY_SIZE
,
2745 .max_keysize
= AES_MAX_KEY_SIZE
,
2746 .ivsize
= AES_BLOCK_SIZE
,
2747 .setkey
= skcipher_aes_setkey
,
2749 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2750 DESC_HDR_SEL0_AESU
|
2751 DESC_HDR_MODE0_AESU_CBC
,
2753 { .type
= CRYPTO_ALG_TYPE_SKCIPHER
,
2755 .base
.cra_name
= "ctr(aes)",
2756 .base
.cra_driver_name
= "ctr-aes-talitos",
2757 .base
.cra_blocksize
= 1,
2758 .base
.cra_flags
= CRYPTO_ALG_ASYNC
|
2759 CRYPTO_ALG_ALLOCATES_MEMORY
,
2760 .min_keysize
= AES_MIN_KEY_SIZE
,
2761 .max_keysize
= AES_MAX_KEY_SIZE
,
2762 .ivsize
= AES_BLOCK_SIZE
,
2763 .setkey
= skcipher_aes_setkey
,
2765 .desc_hdr_template
= DESC_HDR_TYPE_AESU_CTR_NONSNOOP
|
2766 DESC_HDR_SEL0_AESU
|
2767 DESC_HDR_MODE0_AESU_CTR
,
2769 { .type
= CRYPTO_ALG_TYPE_SKCIPHER
,
2771 .base
.cra_name
= "ctr(aes)",
2772 .base
.cra_driver_name
= "ctr-aes-talitos",
2773 .base
.cra_blocksize
= 1,
2774 .base
.cra_flags
= CRYPTO_ALG_ASYNC
|
2775 CRYPTO_ALG_ALLOCATES_MEMORY
,
2776 .min_keysize
= AES_MIN_KEY_SIZE
,
2777 .max_keysize
= AES_MAX_KEY_SIZE
,
2778 .ivsize
= AES_BLOCK_SIZE
,
2779 .setkey
= skcipher_aes_setkey
,
2781 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2782 DESC_HDR_SEL0_AESU
|
2783 DESC_HDR_MODE0_AESU_CTR
,
2785 { .type
= CRYPTO_ALG_TYPE_SKCIPHER
,
2787 .base
.cra_name
= "ecb(des)",
2788 .base
.cra_driver_name
= "ecb-des-talitos",
2789 .base
.cra_blocksize
= DES_BLOCK_SIZE
,
2790 .base
.cra_flags
= CRYPTO_ALG_ASYNC
|
2791 CRYPTO_ALG_ALLOCATES_MEMORY
,
2792 .min_keysize
= DES_KEY_SIZE
,
2793 .max_keysize
= DES_KEY_SIZE
,
2794 .setkey
= skcipher_des_setkey
,
2796 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2799 { .type
= CRYPTO_ALG_TYPE_SKCIPHER
,
2801 .base
.cra_name
= "cbc(des)",
2802 .base
.cra_driver_name
= "cbc-des-talitos",
2803 .base
.cra_blocksize
= DES_BLOCK_SIZE
,
2804 .base
.cra_flags
= CRYPTO_ALG_ASYNC
|
2805 CRYPTO_ALG_ALLOCATES_MEMORY
,
2806 .min_keysize
= DES_KEY_SIZE
,
2807 .max_keysize
= DES_KEY_SIZE
,
2808 .ivsize
= DES_BLOCK_SIZE
,
2809 .setkey
= skcipher_des_setkey
,
2811 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2813 DESC_HDR_MODE0_DEU_CBC
,
2815 { .type
= CRYPTO_ALG_TYPE_SKCIPHER
,
2817 .base
.cra_name
= "ecb(des3_ede)",
2818 .base
.cra_driver_name
= "ecb-3des-talitos",
2819 .base
.cra_blocksize
= DES3_EDE_BLOCK_SIZE
,
2820 .base
.cra_flags
= CRYPTO_ALG_ASYNC
|
2821 CRYPTO_ALG_ALLOCATES_MEMORY
,
2822 .min_keysize
= DES3_EDE_KEY_SIZE
,
2823 .max_keysize
= DES3_EDE_KEY_SIZE
,
2824 .setkey
= skcipher_des3_setkey
,
2826 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2828 DESC_HDR_MODE0_DEU_3DES
,
2830 { .type
= CRYPTO_ALG_TYPE_SKCIPHER
,
2832 .base
.cra_name
= "cbc(des3_ede)",
2833 .base
.cra_driver_name
= "cbc-3des-talitos",
2834 .base
.cra_blocksize
= DES3_EDE_BLOCK_SIZE
,
2835 .base
.cra_flags
= CRYPTO_ALG_ASYNC
|
2836 CRYPTO_ALG_ALLOCATES_MEMORY
,
2837 .min_keysize
= DES3_EDE_KEY_SIZE
,
2838 .max_keysize
= DES3_EDE_KEY_SIZE
,
2839 .ivsize
= DES3_EDE_BLOCK_SIZE
,
2840 .setkey
= skcipher_des3_setkey
,
2842 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2844 DESC_HDR_MODE0_DEU_CBC
|
2845 DESC_HDR_MODE0_DEU_3DES
,
2847 /* AHASH algorithms. */
2848 { .type
= CRYPTO_ALG_TYPE_AHASH
,
2850 .halg
.digestsize
= MD5_DIGEST_SIZE
,
2851 .halg
.statesize
= sizeof(struct talitos_export_state
),
2854 .cra_driver_name
= "md5-talitos",
2855 .cra_blocksize
= MD5_HMAC_BLOCK_SIZE
,
2856 .cra_flags
= CRYPTO_ALG_ASYNC
|
2857 CRYPTO_ALG_ALLOCATES_MEMORY
,
2860 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2861 DESC_HDR_SEL0_MDEUA
|
2862 DESC_HDR_MODE0_MDEU_MD5
,
2864 { .type
= CRYPTO_ALG_TYPE_AHASH
,
2866 .halg
.digestsize
= SHA1_DIGEST_SIZE
,
2867 .halg
.statesize
= sizeof(struct talitos_export_state
),
2870 .cra_driver_name
= "sha1-talitos",
2871 .cra_blocksize
= SHA1_BLOCK_SIZE
,
2872 .cra_flags
= CRYPTO_ALG_ASYNC
|
2873 CRYPTO_ALG_ALLOCATES_MEMORY
,
2876 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2877 DESC_HDR_SEL0_MDEUA
|
2878 DESC_HDR_MODE0_MDEU_SHA1
,
2880 { .type
= CRYPTO_ALG_TYPE_AHASH
,
2882 .halg
.digestsize
= SHA224_DIGEST_SIZE
,
2883 .halg
.statesize
= sizeof(struct talitos_export_state
),
2885 .cra_name
= "sha224",
2886 .cra_driver_name
= "sha224-talitos",
2887 .cra_blocksize
= SHA224_BLOCK_SIZE
,
2888 .cra_flags
= CRYPTO_ALG_ASYNC
|
2889 CRYPTO_ALG_ALLOCATES_MEMORY
,
2892 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2893 DESC_HDR_SEL0_MDEUA
|
2894 DESC_HDR_MODE0_MDEU_SHA224
,
2896 { .type
= CRYPTO_ALG_TYPE_AHASH
,
2898 .halg
.digestsize
= SHA256_DIGEST_SIZE
,
2899 .halg
.statesize
= sizeof(struct talitos_export_state
),
2901 .cra_name
= "sha256",
2902 .cra_driver_name
= "sha256-talitos",
2903 .cra_blocksize
= SHA256_BLOCK_SIZE
,
2904 .cra_flags
= CRYPTO_ALG_ASYNC
|
2905 CRYPTO_ALG_ALLOCATES_MEMORY
,
2908 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2909 DESC_HDR_SEL0_MDEUA
|
2910 DESC_HDR_MODE0_MDEU_SHA256
,
2912 { .type
= CRYPTO_ALG_TYPE_AHASH
,
2914 .halg
.digestsize
= SHA384_DIGEST_SIZE
,
2915 .halg
.statesize
= sizeof(struct talitos_export_state
),
2917 .cra_name
= "sha384",
2918 .cra_driver_name
= "sha384-talitos",
2919 .cra_blocksize
= SHA384_BLOCK_SIZE
,
2920 .cra_flags
= CRYPTO_ALG_ASYNC
|
2921 CRYPTO_ALG_ALLOCATES_MEMORY
,
2924 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2925 DESC_HDR_SEL0_MDEUB
|
2926 DESC_HDR_MODE0_MDEUB_SHA384
,
2928 { .type
= CRYPTO_ALG_TYPE_AHASH
,
2930 .halg
.digestsize
= SHA512_DIGEST_SIZE
,
2931 .halg
.statesize
= sizeof(struct talitos_export_state
),
2933 .cra_name
= "sha512",
2934 .cra_driver_name
= "sha512-talitos",
2935 .cra_blocksize
= SHA512_BLOCK_SIZE
,
2936 .cra_flags
= CRYPTO_ALG_ASYNC
|
2937 CRYPTO_ALG_ALLOCATES_MEMORY
,
2940 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2941 DESC_HDR_SEL0_MDEUB
|
2942 DESC_HDR_MODE0_MDEUB_SHA512
,
2944 { .type
= CRYPTO_ALG_TYPE_AHASH
,
2946 .halg
.digestsize
= MD5_DIGEST_SIZE
,
2947 .halg
.statesize
= sizeof(struct talitos_export_state
),
2949 .cra_name
= "hmac(md5)",
2950 .cra_driver_name
= "hmac-md5-talitos",
2951 .cra_blocksize
= MD5_HMAC_BLOCK_SIZE
,
2952 .cra_flags
= CRYPTO_ALG_ASYNC
|
2953 CRYPTO_ALG_ALLOCATES_MEMORY
,
2956 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2957 DESC_HDR_SEL0_MDEUA
|
2958 DESC_HDR_MODE0_MDEU_MD5
,
2960 { .type
= CRYPTO_ALG_TYPE_AHASH
,
2962 .halg
.digestsize
= SHA1_DIGEST_SIZE
,
2963 .halg
.statesize
= sizeof(struct talitos_export_state
),
2965 .cra_name
= "hmac(sha1)",
2966 .cra_driver_name
= "hmac-sha1-talitos",
2967 .cra_blocksize
= SHA1_BLOCK_SIZE
,
2968 .cra_flags
= CRYPTO_ALG_ASYNC
|
2969 CRYPTO_ALG_ALLOCATES_MEMORY
,
2972 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2973 DESC_HDR_SEL0_MDEUA
|
2974 DESC_HDR_MODE0_MDEU_SHA1
,
2976 { .type
= CRYPTO_ALG_TYPE_AHASH
,
2978 .halg
.digestsize
= SHA224_DIGEST_SIZE
,
2979 .halg
.statesize
= sizeof(struct talitos_export_state
),
2981 .cra_name
= "hmac(sha224)",
2982 .cra_driver_name
= "hmac-sha224-talitos",
2983 .cra_blocksize
= SHA224_BLOCK_SIZE
,
2984 .cra_flags
= CRYPTO_ALG_ASYNC
|
2985 CRYPTO_ALG_ALLOCATES_MEMORY
,
2988 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
2989 DESC_HDR_SEL0_MDEUA
|
2990 DESC_HDR_MODE0_MDEU_SHA224
,
2992 { .type
= CRYPTO_ALG_TYPE_AHASH
,
2994 .halg
.digestsize
= SHA256_DIGEST_SIZE
,
2995 .halg
.statesize
= sizeof(struct talitos_export_state
),
2997 .cra_name
= "hmac(sha256)",
2998 .cra_driver_name
= "hmac-sha256-talitos",
2999 .cra_blocksize
= SHA256_BLOCK_SIZE
,
3000 .cra_flags
= CRYPTO_ALG_ASYNC
|
3001 CRYPTO_ALG_ALLOCATES_MEMORY
,
3004 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
3005 DESC_HDR_SEL0_MDEUA
|
3006 DESC_HDR_MODE0_MDEU_SHA256
,
3008 { .type
= CRYPTO_ALG_TYPE_AHASH
,
3010 .halg
.digestsize
= SHA384_DIGEST_SIZE
,
3011 .halg
.statesize
= sizeof(struct talitos_export_state
),
3013 .cra_name
= "hmac(sha384)",
3014 .cra_driver_name
= "hmac-sha384-talitos",
3015 .cra_blocksize
= SHA384_BLOCK_SIZE
,
3016 .cra_flags
= CRYPTO_ALG_ASYNC
|
3017 CRYPTO_ALG_ALLOCATES_MEMORY
,
3020 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
3021 DESC_HDR_SEL0_MDEUB
|
3022 DESC_HDR_MODE0_MDEUB_SHA384
,
3024 { .type
= CRYPTO_ALG_TYPE_AHASH
,
3026 .halg
.digestsize
= SHA512_DIGEST_SIZE
,
3027 .halg
.statesize
= sizeof(struct talitos_export_state
),
3029 .cra_name
= "hmac(sha512)",
3030 .cra_driver_name
= "hmac-sha512-talitos",
3031 .cra_blocksize
= SHA512_BLOCK_SIZE
,
3032 .cra_flags
= CRYPTO_ALG_ASYNC
|
3033 CRYPTO_ALG_ALLOCATES_MEMORY
,
3036 .desc_hdr_template
= DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
3037 DESC_HDR_SEL0_MDEUB
|
3038 DESC_HDR_MODE0_MDEUB_SHA512
,
3042 struct talitos_crypto_alg
{
3043 struct list_head entry
;
3045 struct talitos_alg_template algt
;
3048 static int talitos_init_common(struct talitos_ctx
*ctx
,
3049 struct talitos_crypto_alg
*talitos_alg
)
3051 struct talitos_private
*priv
;
3053 /* update context with ptr to dev */
3054 ctx
->dev
= talitos_alg
->dev
;
3056 /* assign SEC channel to tfm in round-robin fashion */
3057 priv
= dev_get_drvdata(ctx
->dev
);
3058 ctx
->ch
= atomic_inc_return(&priv
->last_chan
) &
3059 (priv
->num_channels
- 1);
3061 /* copy descriptor header template value */
3062 ctx
->desc_hdr_template
= talitos_alg
->algt
.desc_hdr_template
;
3064 /* select done notification */
3065 ctx
->desc_hdr_template
|= DESC_HDR_DONE_NOTIFY
;
3070 static int talitos_cra_init_aead(struct crypto_aead
*tfm
)
3072 struct aead_alg
*alg
= crypto_aead_alg(tfm
);
3073 struct talitos_crypto_alg
*talitos_alg
;
3074 struct talitos_ctx
*ctx
= crypto_aead_ctx(tfm
);
3076 talitos_alg
= container_of(alg
, struct talitos_crypto_alg
,
3079 return talitos_init_common(ctx
, talitos_alg
);
3082 static int talitos_cra_init_skcipher(struct crypto_skcipher
*tfm
)
3084 struct skcipher_alg
*alg
= crypto_skcipher_alg(tfm
);
3085 struct talitos_crypto_alg
*talitos_alg
;
3086 struct talitos_ctx
*ctx
= crypto_skcipher_ctx(tfm
);
3088 talitos_alg
= container_of(alg
, struct talitos_crypto_alg
,
3091 return talitos_init_common(ctx
, talitos_alg
);
3094 static int talitos_cra_init_ahash(struct crypto_tfm
*tfm
)
3096 struct crypto_alg
*alg
= tfm
->__crt_alg
;
3097 struct talitos_crypto_alg
*talitos_alg
;
3098 struct talitos_ctx
*ctx
= crypto_tfm_ctx(tfm
);
3100 talitos_alg
= container_of(__crypto_ahash_alg(alg
),
3101 struct talitos_crypto_alg
,
3105 crypto_ahash_set_reqsize(__crypto_ahash_cast(tfm
),
3106 sizeof(struct talitos_ahash_req_ctx
));
3108 return talitos_init_common(ctx
, talitos_alg
);
3111 static void talitos_cra_exit(struct crypto_tfm
*tfm
)
3113 struct talitos_ctx
*ctx
= crypto_tfm_ctx(tfm
);
3114 struct device
*dev
= ctx
->dev
;
3117 dma_unmap_single(dev
, ctx
->dma_key
, ctx
->keylen
, DMA_TO_DEVICE
);
3121 * given the alg's descriptor header template, determine whether descriptor
3122 * type and primary/secondary execution units required match the hw
3123 * capabilities description provided in the device tree node.
3125 static int hw_supports(struct device
*dev
, __be32 desc_hdr_template
)
3127 struct talitos_private
*priv
= dev_get_drvdata(dev
);
3130 ret
= (1 << DESC_TYPE(desc_hdr_template
) & priv
->desc_types
) &&
3131 (1 << PRIMARY_EU(desc_hdr_template
) & priv
->exec_units
);
3133 if (SECONDARY_EU(desc_hdr_template
))
3134 ret
= ret
&& (1 << SECONDARY_EU(desc_hdr_template
)
3135 & priv
->exec_units
);
3140 static void talitos_remove(struct platform_device
*ofdev
)
3142 struct device
*dev
= &ofdev
->dev
;
3143 struct talitos_private
*priv
= dev_get_drvdata(dev
);
3144 struct talitos_crypto_alg
*t_alg
, *n
;
3147 list_for_each_entry_safe(t_alg
, n
, &priv
->alg_list
, entry
) {
3148 switch (t_alg
->algt
.type
) {
3149 case CRYPTO_ALG_TYPE_SKCIPHER
:
3150 crypto_unregister_skcipher(&t_alg
->algt
.alg
.skcipher
);
3152 case CRYPTO_ALG_TYPE_AEAD
:
3153 crypto_unregister_aead(&t_alg
->algt
.alg
.aead
);
3155 case CRYPTO_ALG_TYPE_AHASH
:
3156 crypto_unregister_ahash(&t_alg
->algt
.alg
.hash
);
3159 list_del(&t_alg
->entry
);
3162 if (hw_supports(dev
, DESC_HDR_SEL0_RNG
))
3163 talitos_unregister_rng(dev
);
3165 for (i
= 0; i
< 2; i
++)
3167 free_irq(priv
->irq
[i
], dev
);
3168 irq_dispose_mapping(priv
->irq
[i
]);
3171 tasklet_kill(&priv
->done_task
[0]);
3173 tasklet_kill(&priv
->done_task
[1]);
3176 static struct talitos_crypto_alg
*talitos_alg_alloc(struct device
*dev
,
3177 struct talitos_alg_template
3180 struct talitos_private
*priv
= dev_get_drvdata(dev
);
3181 struct talitos_crypto_alg
*t_alg
;
3182 struct crypto_alg
*alg
;
3184 t_alg
= devm_kzalloc(dev
, sizeof(struct talitos_crypto_alg
),
3187 return ERR_PTR(-ENOMEM
);
3189 t_alg
->algt
= *template;
3191 switch (t_alg
->algt
.type
) {
3192 case CRYPTO_ALG_TYPE_SKCIPHER
:
3193 alg
= &t_alg
->algt
.alg
.skcipher
.base
;
3194 alg
->cra_exit
= talitos_cra_exit
;
3195 t_alg
->algt
.alg
.skcipher
.init
= talitos_cra_init_skcipher
;
3196 t_alg
->algt
.alg
.skcipher
.setkey
=
3197 t_alg
->algt
.alg
.skcipher
.setkey
?: skcipher_setkey
;
3198 t_alg
->algt
.alg
.skcipher
.encrypt
= skcipher_encrypt
;
3199 t_alg
->algt
.alg
.skcipher
.decrypt
= skcipher_decrypt
;
3200 if (!strcmp(alg
->cra_name
, "ctr(aes)") && !has_ftr_sec1(priv
) &&
3201 DESC_TYPE(t_alg
->algt
.desc_hdr_template
) !=
3202 DESC_TYPE(DESC_HDR_TYPE_AESU_CTR_NONSNOOP
)) {
3203 devm_kfree(dev
, t_alg
);
3204 return ERR_PTR(-ENOTSUPP
);
3207 case CRYPTO_ALG_TYPE_AEAD
:
3208 alg
= &t_alg
->algt
.alg
.aead
.base
;
3209 alg
->cra_exit
= talitos_cra_exit
;
3210 t_alg
->algt
.alg
.aead
.init
= talitos_cra_init_aead
;
3211 t_alg
->algt
.alg
.aead
.setkey
= t_alg
->algt
.alg
.aead
.setkey
?:
3213 t_alg
->algt
.alg
.aead
.encrypt
= aead_encrypt
;
3214 t_alg
->algt
.alg
.aead
.decrypt
= aead_decrypt
;
3215 if (!(priv
->features
& TALITOS_FTR_SHA224_HWINIT
) &&
3216 !strncmp(alg
->cra_name
, "authenc(hmac(sha224)", 20)) {
3217 devm_kfree(dev
, t_alg
);
3218 return ERR_PTR(-ENOTSUPP
);
3221 case CRYPTO_ALG_TYPE_AHASH
:
3222 alg
= &t_alg
->algt
.alg
.hash
.halg
.base
;
3223 alg
->cra_init
= talitos_cra_init_ahash
;
3224 alg
->cra_exit
= talitos_cra_exit
;
3225 t_alg
->algt
.alg
.hash
.init
= ahash_init
;
3226 t_alg
->algt
.alg
.hash
.update
= ahash_update
;
3227 t_alg
->algt
.alg
.hash
.final
= ahash_final
;
3228 t_alg
->algt
.alg
.hash
.finup
= ahash_finup
;
3229 t_alg
->algt
.alg
.hash
.digest
= ahash_digest
;
3230 if (!strncmp(alg
->cra_name
, "hmac", 4))
3231 t_alg
->algt
.alg
.hash
.setkey
= ahash_setkey
;
3232 t_alg
->algt
.alg
.hash
.import
= ahash_import
;
3233 t_alg
->algt
.alg
.hash
.export
= ahash_export
;
3235 if (!(priv
->features
& TALITOS_FTR_HMAC_OK
) &&
3236 !strncmp(alg
->cra_name
, "hmac", 4)) {
3237 devm_kfree(dev
, t_alg
);
3238 return ERR_PTR(-ENOTSUPP
);
3240 if (!(priv
->features
& TALITOS_FTR_SHA224_HWINIT
) &&
3241 (!strcmp(alg
->cra_name
, "sha224") ||
3242 !strcmp(alg
->cra_name
, "hmac(sha224)"))) {
3243 t_alg
->algt
.alg
.hash
.init
= ahash_init_sha224_swinit
;
3244 t_alg
->algt
.alg
.hash
.digest
=
3245 ahash_digest_sha224_swinit
;
3246 t_alg
->algt
.desc_hdr_template
=
3247 DESC_HDR_TYPE_COMMON_NONSNOOP_NO_AFEU
|
3248 DESC_HDR_SEL0_MDEUA
|
3249 DESC_HDR_MODE0_MDEU_SHA256
;
3253 dev_err(dev
, "unknown algorithm type %d\n", t_alg
->algt
.type
);
3254 devm_kfree(dev
, t_alg
);
3255 return ERR_PTR(-EINVAL
);
3258 alg
->cra_module
= THIS_MODULE
;
3259 if (t_alg
->algt
.priority
)
3260 alg
->cra_priority
= t_alg
->algt
.priority
;
3262 alg
->cra_priority
= TALITOS_CRA_PRIORITY
;
3263 if (has_ftr_sec1(priv
) && t_alg
->algt
.type
!= CRYPTO_ALG_TYPE_AHASH
)
3264 alg
->cra_alignmask
= 3;
3266 alg
->cra_alignmask
= 0;
3267 alg
->cra_ctxsize
= sizeof(struct talitos_ctx
);
3268 alg
->cra_flags
|= CRYPTO_ALG_KERN_DRIVER_ONLY
;
3275 static int talitos_probe_irq(struct platform_device
*ofdev
)
3277 struct device
*dev
= &ofdev
->dev
;
3278 struct device_node
*np
= ofdev
->dev
.of_node
;
3279 struct talitos_private
*priv
= dev_get_drvdata(dev
);
3281 bool is_sec1
= has_ftr_sec1(priv
);
3283 priv
->irq
[0] = irq_of_parse_and_map(np
, 0);
3284 if (!priv
->irq
[0]) {
3285 dev_err(dev
, "failed to map irq\n");
3289 err
= request_irq(priv
->irq
[0], talitos1_interrupt_4ch
, 0,
3290 dev_driver_string(dev
), dev
);
3294 priv
->irq
[1] = irq_of_parse_and_map(np
, 1);
3296 /* get the primary irq line */
3297 if (!priv
->irq
[1]) {
3298 err
= request_irq(priv
->irq
[0], talitos2_interrupt_4ch
, 0,
3299 dev_driver_string(dev
), dev
);
3303 err
= request_irq(priv
->irq
[0], talitos2_interrupt_ch0_2
, 0,
3304 dev_driver_string(dev
), dev
);
3308 /* get the secondary irq line */
3309 err
= request_irq(priv
->irq
[1], talitos2_interrupt_ch1_3
, 0,
3310 dev_driver_string(dev
), dev
);
3312 dev_err(dev
, "failed to request secondary irq\n");
3313 irq_dispose_mapping(priv
->irq
[1]);
3321 dev_err(dev
, "failed to request primary irq\n");
3322 irq_dispose_mapping(priv
->irq
[0]);
3329 static int talitos_probe(struct platform_device
*ofdev
)
3331 struct device
*dev
= &ofdev
->dev
;
3332 struct device_node
*np
= ofdev
->dev
.of_node
;
3333 struct talitos_private
*priv
;
3336 struct resource
*res
;
3338 priv
= devm_kzalloc(dev
, sizeof(struct talitos_private
), GFP_KERNEL
);
3342 INIT_LIST_HEAD(&priv
->alg_list
);
3344 dev_set_drvdata(dev
, priv
);
3346 priv
->ofdev
= ofdev
;
3348 spin_lock_init(&priv
->reg_lock
);
3350 res
= platform_get_resource(ofdev
, IORESOURCE_MEM
, 0);
3353 priv
->reg
= devm_ioremap(dev
, res
->start
, resource_size(res
));
3355 dev_err(dev
, "failed to of_iomap\n");
3360 /* get SEC version capabilities from device tree */
3361 of_property_read_u32(np
, "fsl,num-channels", &priv
->num_channels
);
3362 of_property_read_u32(np
, "fsl,channel-fifo-len", &priv
->chfifo_len
);
3363 of_property_read_u32(np
, "fsl,exec-units-mask", &priv
->exec_units
);
3364 of_property_read_u32(np
, "fsl,descriptor-types-mask",
3367 if (!is_power_of_2(priv
->num_channels
) || !priv
->chfifo_len
||
3368 !priv
->exec_units
|| !priv
->desc_types
) {
3369 dev_err(dev
, "invalid property data in device tree node\n");
3374 if (of_device_is_compatible(np
, "fsl,sec3.0"))
3375 priv
->features
|= TALITOS_FTR_SRC_LINK_TBL_LEN_INCLUDES_EXTENT
;
3377 if (of_device_is_compatible(np
, "fsl,sec2.1"))
3378 priv
->features
|= TALITOS_FTR_HW_AUTH_CHECK
|
3379 TALITOS_FTR_SHA224_HWINIT
|
3380 TALITOS_FTR_HMAC_OK
;
3382 if (of_device_is_compatible(np
, "fsl,sec1.0"))
3383 priv
->features
|= TALITOS_FTR_SEC1
;
3385 if (of_device_is_compatible(np
, "fsl,sec1.2")) {
3386 priv
->reg_deu
= priv
->reg
+ TALITOS12_DEU
;
3387 priv
->reg_aesu
= priv
->reg
+ TALITOS12_AESU
;
3388 priv
->reg_mdeu
= priv
->reg
+ TALITOS12_MDEU
;
3389 stride
= TALITOS1_CH_STRIDE
;
3390 } else if (of_device_is_compatible(np
, "fsl,sec1.0")) {
3391 priv
->reg_deu
= priv
->reg
+ TALITOS10_DEU
;
3392 priv
->reg_aesu
= priv
->reg
+ TALITOS10_AESU
;
3393 priv
->reg_mdeu
= priv
->reg
+ TALITOS10_MDEU
;
3394 priv
->reg_afeu
= priv
->reg
+ TALITOS10_AFEU
;
3395 priv
->reg_rngu
= priv
->reg
+ TALITOS10_RNGU
;
3396 priv
->reg_pkeu
= priv
->reg
+ TALITOS10_PKEU
;
3397 stride
= TALITOS1_CH_STRIDE
;
3399 priv
->reg_deu
= priv
->reg
+ TALITOS2_DEU
;
3400 priv
->reg_aesu
= priv
->reg
+ TALITOS2_AESU
;
3401 priv
->reg_mdeu
= priv
->reg
+ TALITOS2_MDEU
;
3402 priv
->reg_afeu
= priv
->reg
+ TALITOS2_AFEU
;
3403 priv
->reg_rngu
= priv
->reg
+ TALITOS2_RNGU
;
3404 priv
->reg_pkeu
= priv
->reg
+ TALITOS2_PKEU
;
3405 priv
->reg_keu
= priv
->reg
+ TALITOS2_KEU
;
3406 priv
->reg_crcu
= priv
->reg
+ TALITOS2_CRCU
;
3407 stride
= TALITOS2_CH_STRIDE
;
3410 err
= talitos_probe_irq(ofdev
);
3414 if (has_ftr_sec1(priv
)) {
3415 if (priv
->num_channels
== 1)
3416 tasklet_init(&priv
->done_task
[0], talitos1_done_ch0
,
3417 (unsigned long)dev
);
3419 tasklet_init(&priv
->done_task
[0], talitos1_done_4ch
,
3420 (unsigned long)dev
);
3423 tasklet_init(&priv
->done_task
[0], talitos2_done_ch0_2
,
3424 (unsigned long)dev
);
3425 tasklet_init(&priv
->done_task
[1], talitos2_done_ch1_3
,
3426 (unsigned long)dev
);
3427 } else if (priv
->num_channels
== 1) {
3428 tasklet_init(&priv
->done_task
[0], talitos2_done_ch0
,
3429 (unsigned long)dev
);
3431 tasklet_init(&priv
->done_task
[0], talitos2_done_4ch
,
3432 (unsigned long)dev
);
3436 priv
->chan
= devm_kcalloc(dev
,
3438 sizeof(struct talitos_channel
),
3441 dev_err(dev
, "failed to allocate channel management space\n");
3446 priv
->fifo_len
= roundup_pow_of_two(priv
->chfifo_len
);
3448 for (i
= 0; i
< priv
->num_channels
; i
++) {
3449 priv
->chan
[i
].reg
= priv
->reg
+ stride
* (i
+ 1);
3450 if (!priv
->irq
[1] || !(i
& 1))
3451 priv
->chan
[i
].reg
+= TALITOS_CH_BASE_OFFSET
;
3453 spin_lock_init(&priv
->chan
[i
].head_lock
);
3454 spin_lock_init(&priv
->chan
[i
].tail_lock
);
3456 priv
->chan
[i
].fifo
= devm_kcalloc(dev
,
3458 sizeof(struct talitos_request
),
3460 if (!priv
->chan
[i
].fifo
) {
3461 dev_err(dev
, "failed to allocate request fifo %d\n", i
);
3466 atomic_set(&priv
->chan
[i
].submit_count
,
3467 -(priv
->chfifo_len
- 1));
3470 dma_set_mask(dev
, DMA_BIT_MASK(36));
3472 /* reset and initialize the h/w */
3473 err
= init_device(dev
);
3475 dev_err(dev
, "failed to initialize device\n");
3479 /* register the RNG, if available */
3480 if (hw_supports(dev
, DESC_HDR_SEL0_RNG
)) {
3481 err
= talitos_register_rng(dev
);
3483 dev_err(dev
, "failed to register hwrng: %d\n", err
);
3486 dev_info(dev
, "hwrng\n");
3489 /* register crypto algorithms the device supports */
3490 for (i
= 0; i
< ARRAY_SIZE(driver_algs
); i
++) {
3491 if (hw_supports(dev
, driver_algs
[i
].desc_hdr_template
)) {
3492 struct talitos_crypto_alg
*t_alg
;
3493 struct crypto_alg
*alg
= NULL
;
3495 t_alg
= talitos_alg_alloc(dev
, &driver_algs
[i
]);
3496 if (IS_ERR(t_alg
)) {
3497 err
= PTR_ERR(t_alg
);
3498 if (err
== -ENOTSUPP
)
3503 switch (t_alg
->algt
.type
) {
3504 case CRYPTO_ALG_TYPE_SKCIPHER
:
3505 err
= crypto_register_skcipher(
3506 &t_alg
->algt
.alg
.skcipher
);
3507 alg
= &t_alg
->algt
.alg
.skcipher
.base
;
3510 case CRYPTO_ALG_TYPE_AEAD
:
3511 err
= crypto_register_aead(
3512 &t_alg
->algt
.alg
.aead
);
3513 alg
= &t_alg
->algt
.alg
.aead
.base
;
3516 case CRYPTO_ALG_TYPE_AHASH
:
3517 err
= crypto_register_ahash(
3518 &t_alg
->algt
.alg
.hash
);
3519 alg
= &t_alg
->algt
.alg
.hash
.halg
.base
;
3523 dev_err(dev
, "%s alg registration failed\n",
3524 alg
->cra_driver_name
);
3525 devm_kfree(dev
, t_alg
);
3527 list_add_tail(&t_alg
->entry
, &priv
->alg_list
);
3530 if (!list_empty(&priv
->alg_list
))
3531 dev_info(dev
, "%s algorithms registered in /proc/crypto\n",
3532 (char *)of_get_property(np
, "compatible", NULL
));
3537 talitos_remove(ofdev
);
3542 static const struct of_device_id talitos_match
[] = {
3543 #ifdef CONFIG_CRYPTO_DEV_TALITOS1
3545 .compatible
= "fsl,sec1.0",
3548 #ifdef CONFIG_CRYPTO_DEV_TALITOS2
3550 .compatible
= "fsl,sec2.0",
3555 MODULE_DEVICE_TABLE(of
, talitos_match
);
3557 static struct platform_driver talitos_driver
= {
3560 .of_match_table
= talitos_match
,
3562 .probe
= talitos_probe
,
3563 .remove
= talitos_remove
,
3566 module_platform_driver(talitos_driver
);
3568 MODULE_LICENSE("GPL");
3569 MODULE_AUTHOR("Kim Phillips <kim.phillips@freescale.com>");
3570 MODULE_DESCRIPTION("Freescale integrated security engine (SEC) driver");