diff options
author | Andreas Schneider <asn@cryptomilk.org> | 2012-02-04 23:37:25 +0100 |
---|---|---|
committer | Andreas Schneider <asn@cryptomilk.org> | 2012-02-04 23:44:55 +0100 |
commit | 216cb8b1aa86d6fd5cf8db38938e70d5986403cd (patch) | |
tree | 96a4bb4b9fab1a34a719e42d3f5ea1c68a52461a /src | |
parent | fb6855a8213fb8b0434fae3a08943d3bd4c827a9 (diff) | |
download | libssh-216cb8b1aa86d6fd5cf8db38938e70d5986403cd.tar.gz libssh-216cb8b1aa86d6fd5cf8db38938e70d5986403cd.tar.xz libssh-216cb8b1aa86d6fd5cf8db38938e70d5986403cd.zip |
crypto: Add evp hashing function.
Diffstat (limited to 'src')
-rw-r--r-- | src/libcrypto.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/src/libcrypto.c b/src/libcrypto.c index 747994e..7977541 100644 --- a/src/libcrypto.c +++ b/src/libcrypto.c @@ -97,6 +97,34 @@ void sha1(unsigned char *digest, int len, unsigned char *hash) { SHA1(digest, len, hash); } +#ifdef HAVE_OPENSSL_ECC +static const EVP_MD *nid_to_evpmd(int nid) +{ + switch (nid) { + case NID_X9_62_prime256v1: + return EVP_sha256(); + case NID_secp384r1: + return EVP_sha384(); + case NID_secp521r1: + return EVP_sha512(); + default: + return NULL; + } + + return NULL; +} + +void evp(int nid, unsigned char *digest, int len, unsigned char *hash, unsigned int *hlen) +{ + const EVP_MD *evp_md = nid_to_evpmd(nid); + EVP_MD_CTX md; + + EVP_DigestInit(&md, evp_md); + EVP_DigestUpdate(&md, digest, len); + EVP_DigestFinal(&md, hash, hlen); +} +#endif + SHA256CTX sha256_init(void){ SHA256CTX c = malloc(sizeof(*c)); if (c == NULL) { |