aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAndreas Schneider <asn@cryptomilk.org>2012-02-04 23:37:25 +0100
committerAndreas Schneider <asn@cryptomilk.org>2012-02-04 23:44:55 +0100
commit216cb8b1aa86d6fd5cf8db38938e70d5986403cd (patch)
tree96a4bb4b9fab1a34a719e42d3f5ea1c68a52461a /src
parentfb6855a8213fb8b0434fae3a08943d3bd4c827a9 (diff)
downloadlibssh-216cb8b1aa86d6fd5cf8db38938e70d5986403cd.tar.gz
libssh-216cb8b1aa86d6fd5cf8db38938e70d5986403cd.tar.xz
libssh-216cb8b1aa86d6fd5cf8db38938e70d5986403cd.zip
crypto: Add evp hashing function.
Diffstat (limited to 'src')
-rw-r--r--src/libcrypto.c28
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) {