sha1.c 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336
  1. /*
  2. * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
  3. * All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. * 1. Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright
  11. * notice, this list of conditions and the following disclaimer in the
  12. * documentation and/or other materials provided with the distribution.
  13. * 3. Neither the name of the project nor the names of its contributors
  14. * may be used to endorse or promote products derived from this software
  15. * without specific prior written permission.
  16. *
  17. * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
  18. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  19. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  20. * ARE DISCLAIMED. IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
  21. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  22. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  23. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  24. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  25. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  26. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  27. * SUCH DAMAGE.
  28. */
  29. /*
  30. * FIPS pub 180-1: Secure Hash Algorithm (SHA-1)
  31. * based on: http://www.itl.nist.gov/fipspubs/fip180-1.htm
  32. * implemented by Jun-ichiro itojun Itoh <itojun@itojun.org>
  33. */
  34. #include "sha1.h"
  35. #include <string.h>
  36. /* constant table */
  37. static uint32_t _K[] = {0x5a827999, 0x6ed9eba1, 0x8f1bbcdc, 0xca62c1d6};
  38. #define K(t) _K[(t) / 20]
  39. #define F0(b, c, d) (((b) & (c)) | ((~(b)) & (d)))
  40. #define F1(b, c, d) (((b) ^ (c)) ^ (d))
  41. #define F2(b, c, d) (((b) & (c)) | ((b) & (d)) | ((c) & (d)))
  42. #define F3(b, c, d) (((b) ^ (c)) ^ (d))
  43. #define S(n, x) (((x) << (n)) | ((x) >> (32 - (n))))
  44. #define H(n) (ctxt->h.b32[(n)])
  45. #define COUNT (ctxt->count)
  46. #define BCOUNT (ctxt->c.b64[0] / 8)
  47. #define W(n) (ctxt->m.b32[(n)])
  48. #define PUTBYTE(x) \
  49. do { \
  50. ctxt->m.b8[(COUNT % 64)] = (x); \
  51. COUNT++; \
  52. COUNT %= 64; \
  53. ctxt->c.b64[0] += 8; \
  54. if (COUNT % 64 == 0) \
  55. sha1_step(ctxt); \
  56. } while (0)
  57. #define PUTPAD(x) \
  58. do { \
  59. ctxt->m.b8[(COUNT % 64)] = (x); \
  60. COUNT++; \
  61. COUNT %= 64; \
  62. if (COUNT % 64 == 0) \
  63. sha1_step(ctxt); \
  64. } while (0)
  65. static void sha1_step(struct sha1_ctxt *);
  66. static void
  67. sha1_step(struct sha1_ctxt * ctxt)
  68. {
  69. uint32_t a,
  70. b,
  71. c,
  72. d,
  73. e;
  74. size_t t,
  75. s;
  76. uint32_t tmp;
  77. #ifndef WORDS_BIGENDIAN
  78. struct sha1_ctxt tctxt;
  79. memmove(&tctxt.m.b8[0], &ctxt->m.b8[0], 64);
  80. ctxt->m.b8[0] = tctxt.m.b8[3];
  81. ctxt->m.b8[1] = tctxt.m.b8[2];
  82. ctxt->m.b8[2] = tctxt.m.b8[1];
  83. ctxt->m.b8[3] = tctxt.m.b8[0];
  84. ctxt->m.b8[4] = tctxt.m.b8[7];
  85. ctxt->m.b8[5] = tctxt.m.b8[6];
  86. ctxt->m.b8[6] = tctxt.m.b8[5];
  87. ctxt->m.b8[7] = tctxt.m.b8[4];
  88. ctxt->m.b8[8] = tctxt.m.b8[11];
  89. ctxt->m.b8[9] = tctxt.m.b8[10];
  90. ctxt->m.b8[10] = tctxt.m.b8[9];
  91. ctxt->m.b8[11] = tctxt.m.b8[8];
  92. ctxt->m.b8[12] = tctxt.m.b8[15];
  93. ctxt->m.b8[13] = tctxt.m.b8[14];
  94. ctxt->m.b8[14] = tctxt.m.b8[13];
  95. ctxt->m.b8[15] = tctxt.m.b8[12];
  96. ctxt->m.b8[16] = tctxt.m.b8[19];
  97. ctxt->m.b8[17] = tctxt.m.b8[18];
  98. ctxt->m.b8[18] = tctxt.m.b8[17];
  99. ctxt->m.b8[19] = tctxt.m.b8[16];
  100. ctxt->m.b8[20] = tctxt.m.b8[23];
  101. ctxt->m.b8[21] = tctxt.m.b8[22];
  102. ctxt->m.b8[22] = tctxt.m.b8[21];
  103. ctxt->m.b8[23] = tctxt.m.b8[20];
  104. ctxt->m.b8[24] = tctxt.m.b8[27];
  105. ctxt->m.b8[25] = tctxt.m.b8[26];
  106. ctxt->m.b8[26] = tctxt.m.b8[25];
  107. ctxt->m.b8[27] = tctxt.m.b8[24];
  108. ctxt->m.b8[28] = tctxt.m.b8[31];
  109. ctxt->m.b8[29] = tctxt.m.b8[30];
  110. ctxt->m.b8[30] = tctxt.m.b8[29];
  111. ctxt->m.b8[31] = tctxt.m.b8[28];
  112. ctxt->m.b8[32] = tctxt.m.b8[35];
  113. ctxt->m.b8[33] = tctxt.m.b8[34];
  114. ctxt->m.b8[34] = tctxt.m.b8[33];
  115. ctxt->m.b8[35] = tctxt.m.b8[32];
  116. ctxt->m.b8[36] = tctxt.m.b8[39];
  117. ctxt->m.b8[37] = tctxt.m.b8[38];
  118. ctxt->m.b8[38] = tctxt.m.b8[37];
  119. ctxt->m.b8[39] = tctxt.m.b8[36];
  120. ctxt->m.b8[40] = tctxt.m.b8[43];
  121. ctxt->m.b8[41] = tctxt.m.b8[42];
  122. ctxt->m.b8[42] = tctxt.m.b8[41];
  123. ctxt->m.b8[43] = tctxt.m.b8[40];
  124. ctxt->m.b8[44] = tctxt.m.b8[47];
  125. ctxt->m.b8[45] = tctxt.m.b8[46];
  126. ctxt->m.b8[46] = tctxt.m.b8[45];
  127. ctxt->m.b8[47] = tctxt.m.b8[44];
  128. ctxt->m.b8[48] = tctxt.m.b8[51];
  129. ctxt->m.b8[49] = tctxt.m.b8[50];
  130. ctxt->m.b8[50] = tctxt.m.b8[49];
  131. ctxt->m.b8[51] = tctxt.m.b8[48];
  132. ctxt->m.b8[52] = tctxt.m.b8[55];
  133. ctxt->m.b8[53] = tctxt.m.b8[54];
  134. ctxt->m.b8[54] = tctxt.m.b8[53];
  135. ctxt->m.b8[55] = tctxt.m.b8[52];
  136. ctxt->m.b8[56] = tctxt.m.b8[59];
  137. ctxt->m.b8[57] = tctxt.m.b8[58];
  138. ctxt->m.b8[58] = tctxt.m.b8[57];
  139. ctxt->m.b8[59] = tctxt.m.b8[56];
  140. ctxt->m.b8[60] = tctxt.m.b8[63];
  141. ctxt->m.b8[61] = tctxt.m.b8[62];
  142. ctxt->m.b8[62] = tctxt.m.b8[61];
  143. ctxt->m.b8[63] = tctxt.m.b8[60];
  144. #endif
  145. a = H(0);
  146. b = H(1);
  147. c = H(2);
  148. d = H(3);
  149. e = H(4);
  150. for (t = 0; t < 20; t++)
  151. {
  152. s = t & 0x0f;
  153. if (t >= 16)
  154. W(s) = S(1, W((s + 13) & 0x0f) ^ W((s + 8) & 0x0f) ^ W((s + 2) & 0x0f) ^ W(s));
  155. tmp = S(5, a) + F0(b, c, d) + e + W(s) + K(t);
  156. e = d;
  157. d = c;
  158. c = S(30, b);
  159. b = a;
  160. a = tmp;
  161. }
  162. for (t = 20; t < 40; t++)
  163. {
  164. s = t & 0x0f;
  165. W(s) = S(1, W((s + 13) & 0x0f) ^ W((s + 8) & 0x0f) ^ W((s + 2) & 0x0f) ^ W(s));
  166. tmp = S(5, a) + F1(b, c, d) + e + W(s) + K(t);
  167. e = d;
  168. d = c;
  169. c = S(30, b);
  170. b = a;
  171. a = tmp;
  172. }
  173. for (t = 40; t < 60; t++)
  174. {
  175. s = t & 0x0f;
  176. W(s) = S(1, W((s + 13) & 0x0f) ^ W((s + 8) & 0x0f) ^ W((s + 2) & 0x0f) ^ W(s));
  177. tmp = S(5, a) + F2(b, c, d) + e + W(s) + K(t);
  178. e = d;
  179. d = c;
  180. c = S(30, b);
  181. b = a;
  182. a = tmp;
  183. }
  184. for (t = 60; t < 80; t++)
  185. {
  186. s = t & 0x0f;
  187. W(s) = S(1, W((s + 13) & 0x0f) ^ W((s + 8) & 0x0f) ^ W((s + 2) & 0x0f) ^ W(s));
  188. tmp = S(5, a) + F3(b, c, d) + e + W(s) + K(t);
  189. e = d;
  190. d = c;
  191. c = S(30, b);
  192. b = a;
  193. a = tmp;
  194. }
  195. H(0) = H(0) + a;
  196. H(1) = H(1) + b;
  197. H(2) = H(2) + c;
  198. H(3) = H(3) + d;
  199. H(4) = H(4) + e;
  200. memset(&ctxt->m.b8[0], 0, 64);
  201. }
  202. /*------------------------------------------------------------*/
  203. void
  204. sha1_init(struct sha1_ctxt * ctxt)
  205. {
  206. memset(ctxt, 0, sizeof(struct sha1_ctxt));
  207. H(0) = 0x67452301;
  208. H(1) = 0xefcdab89;
  209. H(2) = 0x98badcfe;
  210. H(3) = 0x10325476;
  211. H(4) = 0xc3d2e1f0;
  212. }
  213. void
  214. sha1_pad(struct sha1_ctxt * ctxt)
  215. {
  216. size_t padlen; /* pad length in bytes */
  217. size_t padstart;
  218. PUTPAD(0x80);
  219. padstart = COUNT % 64;
  220. padlen = 64 - padstart;
  221. if (padlen < 8)
  222. {
  223. memset(&ctxt->m.b8[padstart], 0, padlen);
  224. COUNT += (uint8_t) padlen;
  225. COUNT %= 64;
  226. sha1_step(ctxt);
  227. padstart = COUNT % 64; /* should be 0 */
  228. padlen = 64 - padstart; /* should be 64 */
  229. }
  230. memset(&ctxt->m.b8[padstart], 0, padlen - 8);
  231. COUNT += ((uint8_t) padlen - 8);
  232. COUNT %= 64;
  233. #ifdef WORDS_BIGENDIAN
  234. PUTPAD(ctxt->c.b8[0]);
  235. PUTPAD(ctxt->c.b8[1]);
  236. PUTPAD(ctxt->c.b8[2]);
  237. PUTPAD(ctxt->c.b8[3]);
  238. PUTPAD(ctxt->c.b8[4]);
  239. PUTPAD(ctxt->c.b8[5]);
  240. PUTPAD(ctxt->c.b8[6]);
  241. PUTPAD(ctxt->c.b8[7]);
  242. #else
  243. PUTPAD(ctxt->c.b8[7]);
  244. PUTPAD(ctxt->c.b8[6]);
  245. PUTPAD(ctxt->c.b8[5]);
  246. PUTPAD(ctxt->c.b8[4]);
  247. PUTPAD(ctxt->c.b8[3]);
  248. PUTPAD(ctxt->c.b8[2]);
  249. PUTPAD(ctxt->c.b8[1]);
  250. PUTPAD(ctxt->c.b8[0]);
  251. #endif
  252. }
  253. void
  254. sha1_loop(struct sha1_ctxt * ctxt, const uint8_t *input0, size_t len)
  255. {
  256. const uint8_t *input;
  257. size_t gaplen;
  258. size_t gapstart;
  259. size_t off;
  260. size_t copysiz;
  261. input = (const uint8_t *) input0;
  262. off = 0;
  263. while (off < len)
  264. {
  265. gapstart = COUNT % 64;
  266. gaplen = 64 - gapstart;
  267. copysiz = (gaplen < len - off) ? gaplen : len - off;
  268. memmove(&ctxt->m.b8[gapstart], &input[off], copysiz);
  269. COUNT += (uint8_t) copysiz;
  270. COUNT %= 64;
  271. ctxt->c.b64[0] += copysiz * 8;
  272. if (COUNT % 64 == 0)
  273. sha1_step(ctxt);
  274. off += copysiz;
  275. }
  276. }
  277. void
  278. sha1_result(struct sha1_ctxt * ctxt, uint8_t *digest0)
  279. {
  280. uint8_t *digest;
  281. digest = (uint8_t *) digest0;
  282. sha1_pad(ctxt);
  283. #ifdef WORDS_BIGENDIAN
  284. memmove(digest, &ctxt->h.b8[0], 20);
  285. #else
  286. digest[0] = ctxt->h.b8[3];
  287. digest[1] = ctxt->h.b8[2];
  288. digest[2] = ctxt->h.b8[1];
  289. digest[3] = ctxt->h.b8[0];
  290. digest[4] = ctxt->h.b8[7];
  291. digest[5] = ctxt->h.b8[6];
  292. digest[6] = ctxt->h.b8[5];
  293. digest[7] = ctxt->h.b8[4];
  294. digest[8] = ctxt->h.b8[11];
  295. digest[9] = ctxt->h.b8[10];
  296. digest[10] = ctxt->h.b8[9];
  297. digest[11] = ctxt->h.b8[8];
  298. digest[12] = ctxt->h.b8[15];
  299. digest[13] = ctxt->h.b8[14];
  300. digest[14] = ctxt->h.b8[13];
  301. digest[15] = ctxt->h.b8[12];
  302. digest[16] = ctxt->h.b8[19];
  303. digest[17] = ctxt->h.b8[18];
  304. digest[18] = ctxt->h.b8[17];
  305. digest[19] = ctxt->h.b8[16];
  306. #endif
  307. }