md5.h 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /* $OpenBSD: md5.h,v 1.17 2012/12/05 23:19:57 deraadt Exp $ */
  2. /*
  3. * This code implements the MD5 message-digest algorithm.
  4. * The algorithm is due to Ron Rivest. This code was
  5. * written by Colin Plumb in 1993, no copyright is claimed.
  6. * This code is in the public domain; do with it what you wish.
  7. *
  8. * Equivalent code is available from RSA Data Security, Inc.
  9. * This code has been tested against that, and is equivalent,
  10. * except that you don't need to include two pages of legalese
  11. * with every copy.
  12. */
  13. #ifndef _MD5_H_
  14. #define _MD5_H_
  15. #ifndef WITH_OPENSSL
  16. #define MD5_BLOCK_LENGTH 64
  17. #define MD5_DIGEST_LENGTH 16
  18. #define MD5_DIGEST_STRING_LENGTH (MD5_DIGEST_LENGTH * 2 + 1)
  19. typedef struct MD5Context {
  20. u_int32_t state[4]; /* state */
  21. u_int64_t count; /* number of bits, mod 2^64 */
  22. u_int8_t buffer[MD5_BLOCK_LENGTH]; /* input buffer */
  23. } MD5_CTX;
  24. void MD5Init(MD5_CTX *);
  25. void MD5Update(MD5_CTX *, const u_int8_t *, size_t)
  26. __attribute__((__bounded__(__string__,2,3)));
  27. void MD5Pad(MD5_CTX *);
  28. void MD5Final(u_int8_t [MD5_DIGEST_LENGTH], MD5_CTX *)
  29. __attribute__((__bounded__(__minbytes__,1,MD5_DIGEST_LENGTH)));
  30. void MD5Transform(u_int32_t [4], const u_int8_t [MD5_BLOCK_LENGTH])
  31. __attribute__((__bounded__(__minbytes__,1,4)))
  32. __attribute__((__bounded__(__minbytes__,2,MD5_BLOCK_LENGTH)));
  33. char *MD5End(MD5_CTX *, char *)
  34. __attribute__((__bounded__(__minbytes__,2,MD5_DIGEST_STRING_LENGTH)));
  35. char *MD5File(const char *, char *)
  36. __attribute__((__bounded__(__minbytes__,2,MD5_DIGEST_STRING_LENGTH)));
  37. char *MD5FileChunk(const char *, char *, off_t, off_t)
  38. __attribute__((__bounded__(__minbytes__,2,MD5_DIGEST_STRING_LENGTH)));
  39. char *MD5Data(const u_int8_t *, size_t, char *)
  40. __attribute__((__bounded__(__string__,1,2)))
  41. __attribute__((__bounded__(__minbytes__,3,MD5_DIGEST_STRING_LENGTH)));
  42. #endif /* !WITH_OPENSSL */
  43. #endif /* _MD5_H_ */