mirror of
https://github.com/torvalds/linux.git
synced 2026-06-06 05:27:07 +02:00
crypto: sun8i-ss - handle zero sized sg
[ Upstream commitc149e4763d] 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:
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);
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user