mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-22 08:44:23 +07:00
crypto: omap-sham - huge buffer access fixes
The ctx internal buffer can only hold buflen amount of data, don't try to copy over more than that. Also, initialize the context sg pointer if we only have data in the context internal buffer, this can happen when closing a hash with certain data amounts. Signed-off-by: Tero Kristo <t-kristo@ti.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
This commit is contained in:
parent
7e34e0bbc6
commit
6395166d7a
@ -750,8 +750,15 @@ static int omap_sham_align_sgs(struct scatterlist *sg,
|
||||
int offset = rctx->offset;
|
||||
int bufcnt = rctx->bufcnt;
|
||||
|
||||
if (!sg || !sg->length || !nbytes)
|
||||
if (!sg || !sg->length || !nbytes) {
|
||||
if (bufcnt) {
|
||||
sg_init_table(rctx->sgl, 1);
|
||||
sg_set_buf(rctx->sgl, rctx->dd->xmit_buf, bufcnt);
|
||||
rctx->sg = rctx->sgl;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
new_len = nbytes;
|
||||
|
||||
@ -895,7 +902,7 @@ static int omap_sham_prepare_request(struct ahash_request *req, bool update)
|
||||
if (hash_later < 0)
|
||||
hash_later = 0;
|
||||
|
||||
if (hash_later) {
|
||||
if (hash_later && hash_later <= rctx->buflen) {
|
||||
scatterwalk_map_and_copy(rctx->buffer,
|
||||
req->src,
|
||||
req->nbytes - hash_later,
|
||||
|
Loading…
Reference in New Issue
Block a user