From: Dr. Stephen Henson Date: Thu, 11 Mar 2010 13:27:05 +0000 (+0000) Subject: New function X509_ALGOR_set_md() to set X509_ALGOR (DigestAlgorithmIdentifier) X-Git-Tag: OpenSSL-fips-2_0-rc1~1202 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=ce25c7207b8bb817de9b8db4c516ef93e010156f;p=openssl New function X509_ALGOR_set_md() to set X509_ALGOR (DigestAlgorithmIdentifier) from a digest algorithm. --- diff --git a/crypto/asn1/x_algor.c b/crypto/asn1/x_algor.c index 99e53429b7..274e456c73 100644 --- a/crypto/asn1/x_algor.c +++ b/crypto/asn1/x_algor.c @@ -128,3 +128,17 @@ void X509_ALGOR_get0(ASN1_OBJECT **paobj, int *pptype, void **ppval, } } +/* Set up an X509_ALGOR DigestAlgorithmIdentifier from an EVP_MD */ + +void X509_ALGOR_set_md(X509_ALGOR *alg, const EVP_MD *md) + { + int param_type; + + if (md->flags & EVP_MD_FLAG_DIGALGID_ABSENT) + param_type = V_ASN1_UNDEF; + else + param_type = V_ASN1_NULL; + + X509_ALGOR_set0(alg, OBJ_nid2obj(EVP_MD_type(md)), param_type, NULL); + + } diff --git a/crypto/x509/x509.h b/crypto/x509/x509.h index 9fbb0c809d..9090f2ee4b 100644 --- a/crypto/x509/x509.h +++ b/crypto/x509/x509.h @@ -763,6 +763,7 @@ X509_ALGOR *X509_ALGOR_dup(X509_ALGOR *xn); int X509_ALGOR_set0(X509_ALGOR *alg, ASN1_OBJECT *aobj, int ptype, void *pval); void X509_ALGOR_get0(ASN1_OBJECT **paobj, int *pptype, void **ppval, X509_ALGOR *algor); +void X509_ALGOR_set_md(X509_ALGOR *alg, const EVP_MD *md); X509_NAME *X509_NAME_dup(X509_NAME *xn); X509_NAME_ENTRY *X509_NAME_ENTRY_dup(X509_NAME_ENTRY *ne);