crypto: tcrypt - Fix potential leak in test_aead_speed() if crypto_alloc_aead() fails
Fix a potential memory leak in the error handling of test_aead_speed(). In case crypto_alloc_aead() fails, the function returns without going through the centralized cleanup path. Reported by Coverity - CID 1163870. Signed-off-by: Christian Engelmayer <cengelma@gmx.at> Reviewed-by: Marek Vasut <marex@denx.de> Acked-by: Tim Chen <tim.c.chen@linux.intel.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
This commit is contained in:
parent
ac5f863f8c
commit
a2ea6ed6a6
1 changed files with 2 additions and 1 deletions
|
@ -313,7 +313,7 @@ static void test_aead_speed(const char *algo, int enc, unsigned int sec,
|
||||||
if (IS_ERR(tfm)) {
|
if (IS_ERR(tfm)) {
|
||||||
pr_err("alg: aead: Failed to load transform for %s: %ld\n", algo,
|
pr_err("alg: aead: Failed to load transform for %s: %ld\n", algo,
|
||||||
PTR_ERR(tfm));
|
PTR_ERR(tfm));
|
||||||
return;
|
goto out_notfm;
|
||||||
}
|
}
|
||||||
|
|
||||||
req = aead_request_alloc(tfm, GFP_KERNEL);
|
req = aead_request_alloc(tfm, GFP_KERNEL);
|
||||||
|
@ -391,6 +391,7 @@ static void test_aead_speed(const char *algo, int enc, unsigned int sec,
|
||||||
|
|
||||||
out:
|
out:
|
||||||
crypto_free_aead(tfm);
|
crypto_free_aead(tfm);
|
||||||
|
out_notfm:
|
||||||
kfree(sg);
|
kfree(sg);
|
||||||
out_nosg:
|
out_nosg:
|
||||||
testmgr_free_buf(xoutbuf);
|
testmgr_free_buf(xoutbuf);
|
||||||
|
|
Loading…
Add table
Reference in a new issue