|  | #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); |