md5.cc 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412
  1. /* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
  2. *
  3. * HashKit library
  4. *
  5. * Copyright (C) 2011-2012 Data Differential, http://datadifferential.com/
  6. * Copyright (C) 2006-2009 Brian Aker All rights reserved.
  7. *
  8. * Redistribution and use in source and binary forms, with or without
  9. * modification, are permitted provided that the following conditions are
  10. * met:
  11. *
  12. * * Redistributions of source code must retain the above copyright
  13. * notice, this list of conditions and the following disclaimer.
  14. *
  15. * * Redistributions in binary form must reproduce the above
  16. * copyright notice, this list of conditions and the following disclaimer
  17. * in the documentation and/or other materials provided with the
  18. * distribution.
  19. *
  20. * * The names of its contributors may not be used to endorse or
  21. * promote products derived from this software without specific prior
  22. * written permission.
  23. *
  24. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  25. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  26. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  27. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  28. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  29. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  30. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  31. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  32. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  33. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  34. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  35. *
  36. */
  37. /*
  38. This Library has been modified from its original form by
  39. Brian Aker (brian@tangent.org)
  40. See below for original Copyright.
  41. */
  42. /* MD5C.C - RSA Data Security, Inc., MD5 message-digest algorithm
  43. */
  44. /* Copyright (C) 1991-2, RSA Data Security, Inc. Created 1991. All
  45. rights reserved.
  46. License to copy and use this software is granted provided that it
  47. is identified as the "RSA Data Security, Inc. MD5 Message-Digest
  48. Algorithm" in all material mentioning or referencing this software
  49. or this function.
  50. License is also granted to make and use derivative works provided
  51. that such works are identified as "derived from the RSA Data
  52. Security, Inc. MD5 Message-Digest Algorithm" in all material
  53. mentioning or referencing the derived work.
  54. RSA Data Security, Inc. makes no representations concerning either
  55. the merchantability of this software or the suitability of this
  56. software for any particular purpose. It is provided "as is"
  57. without express or implied warranty of any kind.
  58. These notices must be retained in any copies of any part of this
  59. documentation and/or software.
  60. */
  61. #include <libhashkit/common.h>
  62. #include <string.h>
  63. #include <sys/types.h>
  64. #define GCC_VERSION (__GNUC__ * 10000 \
  65. + __GNUC_MINOR__ * 100 \
  66. + __GNUC_PATCHLEVEL__)
  67. #if GCC_VERSION > 40600
  68. # pragma GCC diagnostic ignored "-Wunsafe-loop-optimizations"
  69. #endif
  70. /* POINTER defines a generic pointer type */
  71. typedef unsigned char *POINTER;
  72. typedef const unsigned char *CONST_POINTER;
  73. /* UINT4 defines a four byte word */
  74. typedef unsigned int UINT4;
  75. /* MD5 context. */
  76. typedef struct {
  77. UINT4 state[4]; /* state (ABCD) */
  78. UINT4 count[2]; /* number of bits, modulo 2^64 (lsb first) */
  79. unsigned char buffer[64]; /* input buffer */
  80. } MD5_CTX;
  81. static void MD5Init (MD5_CTX *context); /* context */
  82. static void MD5Update ( MD5_CTX *context, /* context */
  83. const unsigned char *input, /* input block */
  84. unsigned int inputLen); /* length of input block */
  85. static void MD5Final ( unsigned char digest[16], /* message digest */
  86. MD5_CTX *context); /* context */
  87. /* Constants for MD5Transform routine. */
  88. #define S11 7
  89. #define S12 12
  90. #define S13 17
  91. #define S14 22
  92. #define S21 5
  93. #define S22 9
  94. #define S23 14
  95. #define S24 20
  96. #define S31 4
  97. #define S32 11
  98. #define S33 16
  99. #define S34 23
  100. #define S41 6
  101. #define S42 10
  102. #define S43 15
  103. #define S44 21
  104. static void MD5Transform (UINT4 state[4],
  105. const unsigned char block[64]);
  106. static void Encode (unsigned char *output,
  107. UINT4 *input,
  108. unsigned int len);
  109. static void Decode(UINT4 *output, const unsigned char *input, unsigned int len);
  110. static unsigned char PADDING[64] = {
  111. 0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  112. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  113. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
  114. };
  115. /* F, G, H and I are basic MD5 functions.
  116. */
  117. #define F(x, y, z) (((x) & (y)) | ((~x) & (z)))
  118. #define G(x, y, z) (((x) & (z)) | ((y) & (~z)))
  119. #define H(x, y, z) ((x) ^ (y) ^ (z))
  120. #define I(x, y, z) ((y) ^ ((x) | (~z)))
  121. /* ROTATE_LEFT rotates x left n bits.
  122. */
  123. #define ROTATE_LEFT(x, n) (((x) << (n)) | ((x) >> (32-(n))))
  124. /* FF, GG, HH, and II transformations for rounds 1, 2, 3, and 4.
  125. Rotation is separate from addition to prevent recomputation.
  126. */
  127. #define FF(a, b, c, d, x, s, ac) { \
  128. (a) += F ((b), (c), (d)) + (x) + (UINT4)(ac); \
  129. (a) = ROTATE_LEFT ((a), (s)); \
  130. (a) += (b); \
  131. }
  132. #define GG(a, b, c, d, x, s, ac) { \
  133. (a) += G ((b), (c), (d)) + (x) + (UINT4)(ac); \
  134. (a) = ROTATE_LEFT ((a), (s)); \
  135. (a) += (b); \
  136. }
  137. #define HH(a, b, c, d, x, s, ac) { \
  138. (a) += H ((b), (c), (d)) + (x) + (UINT4)(ac); \
  139. (a) = ROTATE_LEFT ((a), (s)); \
  140. (a) += (b); \
  141. }
  142. #define II(a, b, c, d, x, s, ac) { \
  143. (a) += I ((b), (c), (d)) + (x) + (UINT4)(ac); \
  144. (a) = ROTATE_LEFT ((a), (s)); \
  145. (a) += (b); \
  146. }
  147. /*
  148. Just a simple method for getting the signature
  149. result must be == 16
  150. */
  151. void md5_signature(const unsigned char *key, unsigned int length, unsigned char *result)
  152. {
  153. MD5_CTX my_md5;
  154. MD5Init(&my_md5);
  155. (void)MD5Update(&my_md5, key, length);
  156. MD5Final(result, &my_md5);
  157. }
  158. /* MD5 initialization. Begins an MD5 operation, writing a new context.
  159. */
  160. static void MD5Init (MD5_CTX *context) /* context */
  161. {
  162. context->count[0] = context->count[1] = 0;
  163. /* Load magic initialization constants.
  164. */
  165. context->state[0] = 0x67452301;
  166. context->state[1] = 0xefcdab89;
  167. context->state[2] = 0x98badcfe;
  168. context->state[3] = 0x10325476;
  169. }
  170. /* MD5 block update operation. Continues an MD5 message-digest
  171. operation, processing another message block, and updating the
  172. context.
  173. */
  174. static void MD5Update (
  175. MD5_CTX *context, /* context */
  176. const unsigned char *input, /* input block */
  177. unsigned int inputLen) /* length of input block */
  178. {
  179. unsigned int i, idx, partLen;
  180. /* Compute number of bytes mod 64 */
  181. idx = (unsigned int)((context->count[0] >> 3) & 0x3F);
  182. /* Update number of bits */
  183. if ((context->count[0] += ((UINT4)inputLen << 3))
  184. < ((UINT4)inputLen << 3))
  185. context->count[1]++;
  186. context->count[1] += ((UINT4)inputLen >> 29);
  187. partLen = 64 - idx;
  188. /* Transform as many times as possible.
  189. */
  190. if (inputLen >= partLen) {
  191. memcpy((POINTER)&context->buffer[idx], (CONST_POINTER)input, partLen);
  192. MD5Transform(context->state, context->buffer);
  193. for (i = partLen; i + 63 < inputLen; i += 64)
  194. MD5Transform (context->state, (CONST_POINTER)&input[i]);
  195. idx = 0;
  196. }
  197. else
  198. i = 0;
  199. /* Buffer remaining input */
  200. memcpy((POINTER)&context->buffer[idx], (CONST_POINTER)&input[i],
  201. inputLen-i);
  202. }
  203. /* MD5 finalization. Ends an MD5 message-digest operation, writing the
  204. the message digest and zeroizing the context.
  205. */
  206. static void MD5Final (
  207. unsigned char digest[16], /* message digest */
  208. MD5_CTX *context) /* context */
  209. {
  210. unsigned char bits[8];
  211. unsigned int idx, padLen;
  212. /* Save number of bits */
  213. Encode (bits, context->count, 8);
  214. /* Pad out to 56 mod 64.
  215. */
  216. idx = (unsigned int)((context->count[0] >> 3) & 0x3f);
  217. padLen = (idx < 56) ? (56 - idx) : (120 - idx);
  218. MD5Update (context, PADDING, padLen);
  219. /* Append length (before padding) */
  220. MD5Update (context, bits, 8);
  221. /* Store state in digest */
  222. Encode (digest, context->state, 16);
  223. /* Zeroize sensitive information.
  224. */
  225. memset((POINTER)context, 0, sizeof (*context));
  226. }
  227. /* MD5 basic transformation. Transforms state based on block.
  228. */
  229. static void MD5Transform (
  230. UINT4 state[4],
  231. const unsigned char block[64])
  232. {
  233. UINT4 a = state[0], b = state[1], c = state[2], d = state[3], x[16];
  234. Decode (x, block, 64);
  235. /* Round 1 */
  236. FF (a, b, c, d, x[ 0], S11, 0xd76aa478); /* 1 */
  237. FF (d, a, b, c, x[ 1], S12, 0xe8c7b756); /* 2 */
  238. FF (c, d, a, b, x[ 2], S13, 0x242070db); /* 3 */
  239. FF (b, c, d, a, x[ 3], S14, 0xc1bdceee); /* 4 */
  240. FF (a, b, c, d, x[ 4], S11, 0xf57c0faf); /* 5 */
  241. FF (d, a, b, c, x[ 5], S12, 0x4787c62a); /* 6 */
  242. FF (c, d, a, b, x[ 6], S13, 0xa8304613); /* 7 */
  243. FF (b, c, d, a, x[ 7], S14, 0xfd469501); /* 8 */
  244. FF (a, b, c, d, x[ 8], S11, 0x698098d8); /* 9 */
  245. FF (d, a, b, c, x[ 9], S12, 0x8b44f7af); /* 10 */
  246. FF (c, d, a, b, x[10], S13, 0xffff5bb1); /* 11 */
  247. FF (b, c, d, a, x[11], S14, 0x895cd7be); /* 12 */
  248. FF (a, b, c, d, x[12], S11, 0x6b901122); /* 13 */
  249. FF (d, a, b, c, x[13], S12, 0xfd987193); /* 14 */
  250. FF (c, d, a, b, x[14], S13, 0xa679438e); /* 15 */
  251. FF (b, c, d, a, x[15], S14, 0x49b40821); /* 16 */
  252. /* Round 2 */
  253. GG (a, b, c, d, x[ 1], S21, 0xf61e2562); /* 17 */
  254. GG (d, a, b, c, x[ 6], S22, 0xc040b340); /* 18 */
  255. GG (c, d, a, b, x[11], S23, 0x265e5a51); /* 19 */
  256. GG (b, c, d, a, x[ 0], S24, 0xe9b6c7aa); /* 20 */
  257. GG (a, b, c, d, x[ 5], S21, 0xd62f105d); /* 21 */
  258. GG (d, a, b, c, x[10], S22, 0x2441453); /* 22 */
  259. GG (c, d, a, b, x[15], S23, 0xd8a1e681); /* 23 */
  260. GG (b, c, d, a, x[ 4], S24, 0xe7d3fbc8); /* 24 */
  261. GG (a, b, c, d, x[ 9], S21, 0x21e1cde6); /* 25 */
  262. GG (d, a, b, c, x[14], S22, 0xc33707d6); /* 26 */
  263. GG (c, d, a, b, x[ 3], S23, 0xf4d50d87); /* 27 */
  264. GG (b, c, d, a, x[ 8], S24, 0x455a14ed); /* 28 */
  265. GG (a, b, c, d, x[13], S21, 0xa9e3e905); /* 29 */
  266. GG (d, a, b, c, x[ 2], S22, 0xfcefa3f8); /* 30 */
  267. GG (c, d, a, b, x[ 7], S23, 0x676f02d9); /* 31 */
  268. GG (b, c, d, a, x[12], S24, 0x8d2a4c8a); /* 32 */
  269. /* Round 3 */
  270. HH (a, b, c, d, x[ 5], S31, 0xfffa3942); /* 33 */
  271. HH (d, a, b, c, x[ 8], S32, 0x8771f681); /* 34 */
  272. HH (c, d, a, b, x[11], S33, 0x6d9d6122); /* 35 */
  273. HH (b, c, d, a, x[14], S34, 0xfde5380c); /* 36 */
  274. HH (a, b, c, d, x[ 1], S31, 0xa4beea44); /* 37 */
  275. HH (d, a, b, c, x[ 4], S32, 0x4bdecfa9); /* 38 */
  276. HH (c, d, a, b, x[ 7], S33, 0xf6bb4b60); /* 39 */
  277. HH (b, c, d, a, x[10], S34, 0xbebfbc70); /* 40 */
  278. HH (a, b, c, d, x[13], S31, 0x289b7ec6); /* 41 */
  279. HH (d, a, b, c, x[ 0], S32, 0xeaa127fa); /* 42 */
  280. HH (c, d, a, b, x[ 3], S33, 0xd4ef3085); /* 43 */
  281. HH (b, c, d, a, x[ 6], S34, 0x4881d05); /* 44 */
  282. HH (a, b, c, d, x[ 9], S31, 0xd9d4d039); /* 45 */
  283. HH (d, a, b, c, x[12], S32, 0xe6db99e5); /* 46 */
  284. HH (c, d, a, b, x[15], S33, 0x1fa27cf8); /* 47 */
  285. HH (b, c, d, a, x[ 2], S34, 0xc4ac5665); /* 48 */
  286. /* Round 4 */
  287. II (a, b, c, d, x[ 0], S41, 0xf4292244); /* 49 */
  288. II (d, a, b, c, x[ 7], S42, 0x432aff97); /* 50 */
  289. II (c, d, a, b, x[14], S43, 0xab9423a7); /* 51 */
  290. II (b, c, d, a, x[ 5], S44, 0xfc93a039); /* 52 */
  291. II (a, b, c, d, x[12], S41, 0x655b59c3); /* 53 */
  292. II (d, a, b, c, x[ 3], S42, 0x8f0ccc92); /* 54 */
  293. II (c, d, a, b, x[10], S43, 0xffeff47d); /* 55 */
  294. II (b, c, d, a, x[ 1], S44, 0x85845dd1); /* 56 */
  295. II (a, b, c, d, x[ 8], S41, 0x6fa87e4f); /* 57 */
  296. II (d, a, b, c, x[15], S42, 0xfe2ce6e0); /* 58 */
  297. II (c, d, a, b, x[ 6], S43, 0xa3014314); /* 59 */
  298. II (b, c, d, a, x[13], S44, 0x4e0811a1); /* 60 */
  299. II (a, b, c, d, x[ 4], S41, 0xf7537e82); /* 61 */
  300. II (d, a, b, c, x[11], S42, 0xbd3af235); /* 62 */
  301. II (c, d, a, b, x[ 2], S43, 0x2ad7d2bb); /* 63 */
  302. II (b, c, d, a, x[ 9], S44, 0xeb86d391); /* 64 */
  303. state[0] += a;
  304. state[1] += b;
  305. state[2] += c;
  306. state[3] += d;
  307. /* Zeroize sensitive information.
  308. */
  309. memset((POINTER)x, 0, sizeof (x));
  310. }
  311. /* Encodes input (UINT4) into output (unsigned char). Assumes len is
  312. a multiple of 4.
  313. */
  314. static void Encode (
  315. unsigned char *output,
  316. UINT4 *input,
  317. unsigned int len)
  318. {
  319. unsigned int i, j;
  320. for (i = 0, j = 0; j < len; i++, j += 4) {
  321. output[j] = (unsigned char)(input[i] & 0xff);
  322. output[j+1] = (unsigned char)((input[i] >> 8) & 0xff);
  323. output[j+2] = (unsigned char)((input[i] >> 16) & 0xff);
  324. output[j+3] = (unsigned char)((input[i] >> 24) & 0xff);
  325. }
  326. }
  327. /* Decodes input (unsigned char) into output (UINT4). Assumes len is
  328. a multiple of 4.
  329. */
  330. static void Decode (
  331. UINT4 *output,
  332. const unsigned char *input,
  333. unsigned int len)
  334. {
  335. unsigned int i, j;
  336. for (i = 0, j = 0; j < len; i++, j += 4)
  337. output[i] = ((UINT4)input[j]) | (((UINT4)input[j+1]) << 8) |
  338. (((UINT4)input[j+2]) << 16) | (((UINT4)input[j+3]) << 24);
  339. }
  340. uint32_t hashkit_md5(const char *key, size_t key_length, void *context)
  341. {
  342. unsigned char results[16];
  343. (void)context;
  344. md5_signature((unsigned char*)key, (unsigned int)key_length, results);
  345. return ((uint32_t) (results[3] & 0xFF) << 24)
  346. | ((uint32_t) (results[2] & 0xFF) << 16)
  347. | ((uint32_t) (results[1] & 0xFF) << 8)
  348. | (results[0] & 0xFF);
  349. }