diff options
author | Dr. Stephen Henson <steve@openssl.org> | 2012-01-04 23:03:40 +0000 |
---|---|---|
committer | Dr. Stephen Henson <steve@openssl.org> | 2012-01-04 23:03:40 +0000 |
commit | 6bf896d9b1693916d9e8d303f9e3cc04959632b2 (patch) | |
tree | 1691ae92ad84b14781a06654e206e11099bd6238 /engines/ccgost/gost2001_keyx.c | |
parent | be71c37296b3ba43c944eaa220ac62413782bad3 (diff) | |
download | openssl-6bf896d9b1693916d9e8d303f9e3cc04959632b2.tar.gz |
Check GOST parameters are not NULL (CVE-2012-0027)
Diffstat (limited to 'engines/ccgost/gost2001_keyx.c')
-rw-r--r-- | engines/ccgost/gost2001_keyx.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/engines/ccgost/gost2001_keyx.c b/engines/ccgost/gost2001_keyx.c index 00759bcab0..c748102857 100644 --- a/engines/ccgost/gost2001_keyx.c +++ b/engines/ccgost/gost2001_keyx.c @@ -280,6 +280,10 @@ int pkey_GOST01cp_decrypt(EVP_PKEY_CTX *pctx, unsigned char *key, size_t * key_l } param = get_encryption_params(gkt->key_agreement_info->cipher); + if(!param){ + goto err; + } + gost_init(&ctx,param->sblock); OPENSSL_assert(gkt->key_agreement_info->eph_iv->length==8); memcpy(wrappedKey,gkt->key_agreement_info->eph_iv->data,8); |