Check for 0 modulus in BN_MONT_CTX_set

The function BN_MONT_CTX_set was assuming that the modulus was non-zero
and therefore that |mod->top| > 0. In an error situation that may not be
the case and could cause a seg fault.

This is a follow on from CVE-2015-1794.

Reviewed-by: Richard Levitte <levitte@openssl.org>
This commit is contained in:
Matt Caswell 2015-08-10 12:00:29 +01:00
parent f15c99f4d4
commit b11980d79a

View File

@ -373,6 +373,9 @@ int BN_MONT_CTX_set(BN_MONT_CTX *mont, const BIGNUM *mod, BN_CTX *ctx)
int ret = 0; int ret = 0;
BIGNUM *Ri, *R; BIGNUM *Ri, *R;
if (BN_is_zero(mod))
return 0;
BN_CTX_start(ctx); BN_CTX_start(ctx);
if ((Ri = BN_CTX_get(ctx)) == NULL) if ((Ri = BN_CTX_get(ctx)) == NULL)
goto err; goto err;