mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-16 04:21:09 -04:00
crypto: nx - fix context leak in nx842_crypto_free_ctx
Since the scomp conversion, nx842_crypto_alloc_ctx() allocates the
context separately, but nx842_crypto_free_ctx() never releases it. Add
the missing kfree(ctx) to nx842_crypto_free_ctx(), and reuse
nx842_crypto_free_ctx() in the allocation error path.
Fixes: 980b5705f4 ("crypto: nx - Migrate to scomp API")
Cc: stable@vger.kernel.org
Signed-off-by: Thorsten Blum <thorsten.blum@linux.dev>
Reviewed-by: Ard Biesheuvel <ardb@kernel.org>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
This commit is contained in:
committed by
Herbert Xu
parent
adb3faf2db
commit
344e6a4f7f
@@ -115,10 +115,7 @@ void *nx842_crypto_alloc_ctx(struct nx842_driver *driver)
|
||||
ctx->sbounce = (u8 *)__get_free_pages(GFP_KERNEL, BOUNCE_BUFFER_ORDER);
|
||||
ctx->dbounce = (u8 *)__get_free_pages(GFP_KERNEL, BOUNCE_BUFFER_ORDER);
|
||||
if (!ctx->wmem || !ctx->sbounce || !ctx->dbounce) {
|
||||
kfree(ctx->wmem);
|
||||
free_pages((unsigned long)ctx->sbounce, BOUNCE_BUFFER_ORDER);
|
||||
free_pages((unsigned long)ctx->dbounce, BOUNCE_BUFFER_ORDER);
|
||||
kfree(ctx);
|
||||
nx842_crypto_free_ctx(ctx);
|
||||
return ERR_PTR(-ENOMEM);
|
||||
}
|
||||
|
||||
@@ -133,6 +130,7 @@ void nx842_crypto_free_ctx(void *p)
|
||||
kfree(ctx->wmem);
|
||||
free_pages((unsigned long)ctx->sbounce, BOUNCE_BUFFER_ORDER);
|
||||
free_pages((unsigned long)ctx->dbounce, BOUNCE_BUFFER_ORDER);
|
||||
kfree(ctx);
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(nx842_crypto_free_ctx);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user