Commit 16695408 authored by Herbert Xu's avatar Herbert Xu Committed by Sasha Levin

crypto: hash - Fix page length clamping in hash walk

[ Upstream commit 13f4bb78 ]

The crypto hash walk code is broken when supplied with an offset
greater than or equal to PAGE_SIZE.  This patch fixes it by adjusting
walk->pg and walk->offset when this happens.

Cc: <stable@vger.kernel.org>
Reported-by: default avatarSteffen Klassert <steffen.klassert@secunet.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: default avatarSasha Levin <sasha.levin@oracle.com>
parent a10c059a
...@@ -69,8 +69,9 @@ static int hash_walk_new_entry(struct crypto_hash_walk *walk) ...@@ -69,8 +69,9 @@ static int hash_walk_new_entry(struct crypto_hash_walk *walk)
struct scatterlist *sg; struct scatterlist *sg;
sg = walk->sg; sg = walk->sg;
walk->pg = sg_page(sg);
walk->offset = sg->offset; walk->offset = sg->offset;
walk->pg = sg_page(walk->sg) + (walk->offset >> PAGE_SHIFT);
walk->offset = offset_in_page(walk->offset);
walk->entrylen = sg->length; walk->entrylen = sg->length;
if (walk->entrylen > walk->total) if (walk->entrylen > walk->total)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment