1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- #include <stdio.h>
- #include "internal/cryptlib.h"
- #include <openssl/md2.h>
- unsigned char *MD2(const unsigned char *d, size_t n, unsigned char *md)
- {
- MD2_CTX c;
- static unsigned char m[MD2_DIGEST_LENGTH];
- if (md == NULL)
- md = m;
- if (!MD2_Init(&c))
- return NULL;
- #ifndef CHARSET_EBCDIC
- MD2_Update(&c, d, n);
- #else
- {
- char temp[1024];
- unsigned long chunk;
- while (n > 0) {
- chunk = (n > sizeof(temp)) ? sizeof(temp) : n;
- ebcdic2ascii(temp, d, chunk);
- MD2_Update(&c, temp, chunk);
- n -= chunk;
- d += chunk;
- }
- }
- #endif
- MD2_Final(md, &c);
- OPENSSL_cleanse(&c, sizeof(c));
- return md;
- }
|