mirror of
https://github.com/openssl/openssl.git
synced 2025-01-18 13:44:20 +08:00
Check i2d_X509_NAME return in X509_NAME_hash_ex/old
Reviewed-by: Tom Cosgrove <tom.cosgrove@arm.com> Reviewed-by: Tomas Mraz <tomas@openssl.org> (Merged from https://github.com/openssl/openssl/pull/21697)
This commit is contained in:
parent
830b6a13f9
commit
945fde53a3
@ -292,12 +292,13 @@ unsigned long X509_NAME_hash_ex(const X509_NAME *x, OSSL_LIB_CTX *libctx,
|
|||||||
unsigned long ret = 0;
|
unsigned long ret = 0;
|
||||||
unsigned char md[SHA_DIGEST_LENGTH];
|
unsigned char md[SHA_DIGEST_LENGTH];
|
||||||
EVP_MD *sha1 = EVP_MD_fetch(libctx, "SHA1", propq);
|
EVP_MD *sha1 = EVP_MD_fetch(libctx, "SHA1", propq);
|
||||||
|
int i2d_ret;
|
||||||
|
|
||||||
/* Make sure X509_NAME structure contains valid cached encoding */
|
/* Make sure X509_NAME structure contains valid cached encoding */
|
||||||
i2d_X509_NAME(x, NULL);
|
i2d_ret = i2d_X509_NAME(x, NULL);
|
||||||
if (ok != NULL)
|
if (ok != NULL)
|
||||||
*ok = 0;
|
*ok = 0;
|
||||||
if (sha1 != NULL
|
if (i2d_ret >= 0 && sha1 != NULL
|
||||||
&& EVP_Digest(x->canon_enc, x->canon_enclen, md, NULL, sha1, NULL)) {
|
&& EVP_Digest(x->canon_enc, x->canon_enclen, md, NULL, sha1, NULL)) {
|
||||||
ret = (((unsigned long)md[0]) | ((unsigned long)md[1] << 8L) |
|
ret = (((unsigned long)md[0]) | ((unsigned long)md[1] << 8L) |
|
||||||
((unsigned long)md[2] << 16L) | ((unsigned long)md[3] << 24L)
|
((unsigned long)md[2] << 16L) | ((unsigned long)md[3] << 24L)
|
||||||
@ -325,7 +326,9 @@ unsigned long X509_NAME_hash_old(const X509_NAME *x)
|
|||||||
goto end;
|
goto end;
|
||||||
|
|
||||||
/* Make sure X509_NAME structure contains valid cached encoding */
|
/* Make sure X509_NAME structure contains valid cached encoding */
|
||||||
i2d_X509_NAME(x, NULL);
|
if (i2d_X509_NAME(x, NULL) < 0)
|
||||||
|
goto end;
|
||||||
|
|
||||||
if (EVP_DigestInit_ex(md_ctx, md5, NULL)
|
if (EVP_DigestInit_ex(md_ctx, md5, NULL)
|
||||||
&& EVP_DigestUpdate(md_ctx, x->bytes->data, x->bytes->length)
|
&& EVP_DigestUpdate(md_ctx, x->bytes->data, x->bytes->length)
|
||||||
&& EVP_DigestFinal_ex(md_ctx, md, NULL))
|
&& EVP_DigestFinal_ex(md_ctx, md, NULL))
|
||||||
|
Loading…
Reference in New Issue
Block a user