提交 538caf83 编写于 作者: L LEROY Christophe 提交者: Herbert Xu

crypto: talitos - helper function for ptr len

This patch adds a helper function for reads and writes of the len
param of the talitos descriptor. This will help implement
SEC1 later.
Signed-off-by: NChristophe Leroy <christophe.leroy@c-s.fr>
Signed-off-by: NHerbert Xu <herbert@gondor.apana.org.au>
上级 a2b35aa8
...@@ -61,6 +61,16 @@ static void to_talitos_ptr(struct talitos_ptr *ptr, dma_addr_t dma_addr) ...@@ -61,6 +61,16 @@ static void to_talitos_ptr(struct talitos_ptr *ptr, dma_addr_t dma_addr)
ptr->eptr = upper_32_bits(dma_addr); ptr->eptr = upper_32_bits(dma_addr);
} }
static void to_talitos_ptr_len(struct talitos_ptr *ptr, unsigned short len)
{
ptr->len = cpu_to_be16(len);
}
static unsigned short from_talitos_ptr_len(struct talitos_ptr *ptr)
{
return be16_to_cpu(ptr->len);
}
static void to_talitos_ptr_extent_clear(struct talitos_ptr *ptr) static void to_talitos_ptr_extent_clear(struct talitos_ptr *ptr)
{ {
ptr->j_extent = 0; ptr->j_extent = 0;
...@@ -76,7 +86,7 @@ static void map_single_talitos_ptr(struct device *dev, ...@@ -76,7 +86,7 @@ static void map_single_talitos_ptr(struct device *dev,
{ {
dma_addr_t dma_addr = dma_map_single(dev, data, len, dir); dma_addr_t dma_addr = dma_map_single(dev, data, len, dir);
ptr->len = cpu_to_be16(len); to_talitos_ptr_len(ptr, len);
to_talitos_ptr(ptr, dma_addr); to_talitos_ptr(ptr, dma_addr);
to_talitos_ptr_extent_clear(ptr); to_talitos_ptr_extent_clear(ptr);
} }
...@@ -89,7 +99,7 @@ static void unmap_single_talitos_ptr(struct device *dev, ...@@ -89,7 +99,7 @@ static void unmap_single_talitos_ptr(struct device *dev,
enum dma_data_direction dir) enum dma_data_direction dir)
{ {
dma_unmap_single(dev, be32_to_cpu(ptr->ptr), dma_unmap_single(dev, be32_to_cpu(ptr->ptr),
be16_to_cpu(ptr->len), dir); from_talitos_ptr_len(ptr), dir);
} }
static int reset_channel(struct device *dev, int ch) static int reset_channel(struct device *dev, int ch)
...@@ -1375,7 +1385,7 @@ int map_sg_in_talitos_ptr(struct device *dev, struct scatterlist *src, ...@@ -1375,7 +1385,7 @@ int map_sg_in_talitos_ptr(struct device *dev, struct scatterlist *src,
{ {
int sg_count; int sg_count;
ptr->len = cpu_to_be16(len); to_talitos_ptr_len(ptr, len);
to_talitos_ptr_extent_clear(ptr); to_talitos_ptr_extent_clear(ptr);
sg_count = talitos_map_sg(dev, src, edesc->src_nents ? : 1, dir, sg_count = talitos_map_sg(dev, src, edesc->src_nents ? : 1, dir,
...@@ -1405,7 +1415,7 @@ void map_sg_out_talitos_ptr(struct device *dev, struct scatterlist *dst, ...@@ -1405,7 +1415,7 @@ void map_sg_out_talitos_ptr(struct device *dev, struct scatterlist *dst,
enum dma_data_direction dir, enum dma_data_direction dir,
struct talitos_ptr *ptr, int sg_count) struct talitos_ptr *ptr, int sg_count)
{ {
ptr->len = cpu_to_be16(len); to_talitos_ptr_len(ptr, len);
to_talitos_ptr_extent_clear(ptr); to_talitos_ptr_extent_clear(ptr);
if (dir != DMA_NONE) if (dir != DMA_NONE)
...@@ -1447,7 +1457,7 @@ static int common_nonsnoop(struct talitos_edesc *edesc, ...@@ -1447,7 +1457,7 @@ static int common_nonsnoop(struct talitos_edesc *edesc,
/* cipher iv */ /* cipher iv */
to_talitos_ptr(&desc->ptr[1], edesc->iv_dma); to_talitos_ptr(&desc->ptr[1], edesc->iv_dma);
desc->ptr[1].len = cpu_to_be16(ivsize); to_talitos_ptr_len(&desc->ptr[1], ivsize);
to_talitos_ptr_extent_clear(&desc->ptr[1]); to_talitos_ptr_extent_clear(&desc->ptr[1]);
/* cipher key */ /* cipher key */
...@@ -1539,11 +1549,11 @@ static void common_nonsnoop_hash_unmap(struct device *dev, ...@@ -1539,11 +1549,11 @@ static void common_nonsnoop_hash_unmap(struct device *dev,
unmap_sg_talitos_ptr(dev, req_ctx->psrc, NULL, 0, edesc); unmap_sg_talitos_ptr(dev, req_ctx->psrc, NULL, 0, edesc);
/* When using hashctx-in, must unmap it. */ /* When using hashctx-in, must unmap it. */
if (edesc->desc.ptr[1].len) if (from_talitos_ptr_len(&edesc->desc.ptr[1]))
unmap_single_talitos_ptr(dev, &edesc->desc.ptr[1], unmap_single_talitos_ptr(dev, &edesc->desc.ptr[1],
DMA_TO_DEVICE); DMA_TO_DEVICE);
if (edesc->desc.ptr[2].len) if (from_talitos_ptr_len(&edesc->desc.ptr[2]))
unmap_single_talitos_ptr(dev, &edesc->desc.ptr[2], unmap_single_talitos_ptr(dev, &edesc->desc.ptr[2],
DMA_TO_DEVICE); DMA_TO_DEVICE);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册