| #ifndef MD5_H |
| #define MD5_H |
| #ifndef HEADER_MD5_H |
| /* Try to avoid clashes with OpenSSL */ |
| #define HEADER_MD5_H |
| #endif |
| |
| struct MD5Context { |
| __u32 buf[4]; |
| __u32 bits[2]; |
| unsigned char in[64]; |
| }; |
| #endif /* !MD5_H */ |
| |
| #ifndef _HMAC_MD5_H |
| struct HMACMD5Context { |
| struct MD5Context ctx; |
| unsigned char k_ipad[65]; |
| unsigned char k_opad[65]; |
| }; |
| #endif /* _HMAC_MD5_H */ |
| |
| void MD5Init(struct MD5Context *context); |
| void MD5Update(struct MD5Context *context, unsigned char const *buf, |
| unsigned len); |
| void MD5Final(unsigned char digest[16], struct MD5Context *context); |
| |
| /* The following definitions come from lib/hmacmd5.c */ |
| |
| void hmac_md5_init_rfc2104(unsigned char *key, int key_len, |
| struct HMACMD5Context *ctx); |
| void hmac_md5_init_limK_to_64(const unsigned char *key, int key_len, |
| struct HMACMD5Context *ctx); |
| void hmac_md5_update(const unsigned char *text, int text_len, |
| struct HMACMD5Context *ctx); |
| void hmac_md5_final(unsigned char *digest, struct HMACMD5Context *ctx); |
| void hmac_md5(unsigned char key[16], unsigned char *data, int data_len, |
| unsigned char *digest); |