public inbox for linux-crypto@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] Fix NULL pointer deref. on no default_rng
@ 2017-11-12 14:24 Pierre Ducroquet
  2017-11-12 14:46 ` PrasannaKumar Muralidharan
  2017-11-29  6:34 ` Herbert Xu
  0 siblings, 2 replies; 6+ messages in thread
From: Pierre Ducroquet @ 2017-11-12 14:24 UTC (permalink / raw)
  To: linux-crypto; +Cc: davem, herbert, Pierre Ducroquet

If crypto_get_default_rng returns an error, the
function ecc_gen_privkey should return an error.
Instead, it currently tries to use the default_rng
nevertheless, thus creating a kernel panic with a
NULL pointer dereference.
Returning the error directly, as was supposedly
intended when looking at the code, fixes this.

Signed-off-by: Pierre Ducroquet <pinaraf@pinaraf.info>
---
 crypto/ecc.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/crypto/ecc.c b/crypto/ecc.c
index 633a9bcdc574..18f32f2a5e1c 100644
--- a/crypto/ecc.c
+++ b/crypto/ecc.c
@@ -964,7 +964,7 @@ int ecc_gen_privkey(unsigned int curve_id, unsigned int ndigits, u64 *privkey)
 	 * DRBG with a security strength of 256.
 	 */
 	if (crypto_get_default_rng())
-		err = -EFAULT;
+		return -EFAULT;
 
 	err = crypto_rng_get_bytes(crypto_default_rng, (u8 *)priv, nbytes);
 	crypto_put_default_rng();
-- 
2.15.0

^ permalink raw reply related	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2017-12-20 19:50 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-11-12 14:24 [PATCH] Fix NULL pointer deref. on no default_rng Pierre Ducroquet
2017-11-12 14:46 ` PrasannaKumar Muralidharan
2017-11-18 17:18   ` Pierre
2017-11-29  6:34 ` Herbert Xu
2017-12-07 10:32   ` Pierre
2017-12-20 19:49   ` Pierre

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox