crypto: sun8i-ss - handle zero sized sg
[ Upstream commit c149e4763d28bb4c0e5daae8a59f2c74e889f407 ]
sun8i-ss does not handle well the possible zero sized sg.
Fixes: d9b45418a9
("crypto: sun8i-ss - support hash algorithms")
Signed-off-by: Corentin Labbe <clabbe@baylibre.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
5bea8f700a
commit
40c41a7bfd
@@ -379,13 +379,21 @@ int sun8i_ss_hash_run(struct crypto_engine *engine, void *breq)
|
|||||||
}
|
}
|
||||||
|
|
||||||
len = areq->nbytes;
|
len = areq->nbytes;
|
||||||
for_each_sg(areq->src, sg, nr_sgs, i) {
|
sg = areq->src;
|
||||||
|
i = 0;
|
||||||
|
while (len > 0 && sg) {
|
||||||
|
if (sg_dma_len(sg) == 0) {
|
||||||
|
sg = sg_next(sg);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
rctx->t_src[i].addr = sg_dma_address(sg);
|
rctx->t_src[i].addr = sg_dma_address(sg);
|
||||||
todo = min(len, sg_dma_len(sg));
|
todo = min(len, sg_dma_len(sg));
|
||||||
rctx->t_src[i].len = todo / 4;
|
rctx->t_src[i].len = todo / 4;
|
||||||
len -= todo;
|
len -= todo;
|
||||||
rctx->t_dst[i].addr = addr_res;
|
rctx->t_dst[i].addr = addr_res;
|
||||||
rctx->t_dst[i].len = digestsize / 4;
|
rctx->t_dst[i].len = digestsize / 4;
|
||||||
|
sg = sg_next(sg);
|
||||||
|
i++;
|
||||||
}
|
}
|
||||||
if (len > 0) {
|
if (len > 0) {
|
||||||
dev_err(ss->dev, "remaining len %d\n", len);
|
dev_err(ss->dev, "remaining len %d\n", len);
|
||||||
|
Reference in New Issue
Block a user