diff options
Diffstat (limited to 'drivers/crypto/caam/sg_link_tbl.h')
-rw-r--r-- | drivers/crypto/caam/sg_link_tbl.h | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/drivers/crypto/caam/sg_link_tbl.h b/drivers/crypto/caam/sg_link_tbl.h new file mode 100644 index 000000000000..6df434922460 --- /dev/null +++ b/drivers/crypto/caam/sg_link_tbl.h | |||
@@ -0,0 +1,84 @@ | |||
1 | /* | ||
2 | * CAAM/SEC 4.x functions for using scatterlists in caam driver | ||
3 | * | ||
4 | * Copyright 2008-2011 Freescale Semiconductor, Inc. | ||
5 | * | ||
6 | */ | ||
7 | |||
8 | struct link_tbl_entry; | ||
9 | |||
10 | /* | ||
11 | * convert single dma address to h/w link table format | ||
12 | */ | ||
13 | static inline void sg_to_link_tbl_one(struct link_tbl_entry *link_tbl_ptr, | ||
14 | dma_addr_t dma, u32 len, u32 offset) | ||
15 | { | ||
16 | link_tbl_ptr->ptr = dma; | ||
17 | link_tbl_ptr->len = len; | ||
18 | link_tbl_ptr->reserved = 0; | ||
19 | link_tbl_ptr->buf_pool_id = 0; | ||
20 | link_tbl_ptr->offset = offset; | ||
21 | #ifdef DEBUG | ||
22 | print_hex_dump(KERN_ERR, "link_tbl_ptr@: ", | ||
23 | DUMP_PREFIX_ADDRESS, 16, 4, link_tbl_ptr, | ||
24 | sizeof(struct link_tbl_entry), 1); | ||
25 | #endif | ||
26 | } | ||
27 | |||
28 | /* | ||
29 | * convert scatterlist to h/w link table format | ||
30 | * but does not have final bit; instead, returns last entry | ||
31 | */ | ||
32 | static inline struct link_tbl_entry * | ||
33 | sg_to_link_tbl(struct scatterlist *sg, int sg_count, | ||
34 | struct link_tbl_entry *link_tbl_ptr, u32 offset) | ||
35 | { | ||
36 | while (sg_count) { | ||
37 | sg_to_link_tbl_one(link_tbl_ptr, sg_dma_address(sg), | ||
38 | sg_dma_len(sg), offset); | ||
39 | link_tbl_ptr++; | ||
40 | sg = sg_next(sg); | ||
41 | sg_count--; | ||
42 | } | ||
43 | return link_tbl_ptr - 1; | ||
44 | } | ||
45 | |||
46 | /* | ||
47 | * convert scatterlist to h/w link table format | ||
48 | * scatterlist must have been previously dma mapped | ||
49 | */ | ||
50 | static inline void sg_to_link_tbl_last(struct scatterlist *sg, int sg_count, | ||
51 | struct link_tbl_entry *link_tbl_ptr, | ||
52 | u32 offset) | ||
53 | { | ||
54 | link_tbl_ptr = sg_to_link_tbl(sg, sg_count, link_tbl_ptr, offset); | ||
55 | link_tbl_ptr->len |= LINK_TBL_LEN_FIN; | ||
56 | } | ||
57 | |||
58 | /* count number of elements in scatterlist */ | ||
59 | static inline int __sg_count(struct scatterlist *sg_list, int nbytes) | ||
60 | { | ||
61 | struct scatterlist *sg = sg_list; | ||
62 | int sg_nents = 0; | ||
63 | |||
64 | while (nbytes > 0) { | ||
65 | sg_nents++; | ||
66 | nbytes -= sg->length; | ||
67 | if (!sg_is_last(sg) && (sg + 1)->length == 0) | ||
68 | BUG(); /* Not support chaining */ | ||
69 | sg = scatterwalk_sg_next(sg); | ||
70 | } | ||
71 | |||
72 | return sg_nents; | ||
73 | } | ||
74 | |||
75 | /* derive number of elements in scatterlist, but return 0 for 1 */ | ||
76 | static inline int sg_count(struct scatterlist *sg_list, int nbytes) | ||
77 | { | ||
78 | int sg_nents = __sg_count(sg_list, nbytes); | ||
79 | |||
80 | if (likely(sg_nents == 1)) | ||
81 | return 0; | ||
82 | |||
83 | return sg_nents; | ||
84 | } | ||