crypto: drbg - always try to free Jitter RNG instance
The Jitter RNG is unconditionally allocated as a seed source follwoing the patch97f2650e50
. Thus, the instance must always be deallocated. Reported-by: syzbot+2e635807decef724a1fa@syzkaller.appspotmail.com Fixes:97f2650e50
("crypto: drbg - always seeded with SP800-90B ...") Signed-off-by: Stephan Mueller <smueller@chronox.de> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
This commit is contained in:
parent
1f5b07f5dd
commit
819966c06b
|
@ -1631,9 +1631,11 @@ static int drbg_uninstantiate(struct drbg_state *drbg)
|
||||||
if (drbg->random_ready.func) {
|
if (drbg->random_ready.func) {
|
||||||
del_random_ready_callback(&drbg->random_ready);
|
del_random_ready_callback(&drbg->random_ready);
|
||||||
cancel_work_sync(&drbg->seed_work);
|
cancel_work_sync(&drbg->seed_work);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!IS_ERR_OR_NULL(drbg->jent))
|
||||||
crypto_free_rng(drbg->jent);
|
crypto_free_rng(drbg->jent);
|
||||||
drbg->jent = NULL;
|
drbg->jent = NULL;
|
||||||
}
|
|
||||||
|
|
||||||
if (drbg->d_ops)
|
if (drbg->d_ops)
|
||||||
drbg->d_ops->crypto_fini(drbg);
|
drbg->d_ops->crypto_fini(drbg);
|
||||||
|
|
Loading…
Reference in New Issue
Block a user