14static const uint32_t
K[64] = {
15 0x428a2f98u, 0x71374491u, 0xb5c0fbcfu, 0xe9b5dba5u, 0x3956c25bu, 0x59f111f1u,
16 0x923f82a4u, 0xab1c5ed5u, 0xd807aa98u, 0x12835b01u, 0x243185beu, 0x550c7dc3u,
17 0x72be5d74u, 0x80deb1feu, 0x9bdc06a7u, 0xc19bf174u, 0xe49b69c1u, 0xefbe4786u,
18 0x0fc19dc6u, 0x240ca1ccu, 0x2de92c6fu, 0x4a7484aau, 0x5cb0a9dcu, 0x76f988dau,
19 0x983e5152u, 0xa831c66du, 0xb00327c8u, 0xbf597fc7u, 0xc6e00bf3u, 0xd5a79147u,
20 0x06ca6351u, 0x14292967u, 0x27b70a85u, 0x2e1b2138u, 0x4d2c6dfcu, 0x53380d13u,
21 0x650a7354u, 0x766a0abbu, 0x81c2c92eu, 0x92722c85u, 0xa2bfe8a1u, 0xa81a664bu,
22 0xc24b8b70u, 0xc76c51a3u, 0xd192e819u, 0xd6990624u, 0xf40e3585u, 0x106aa070u,
23 0x19a4c116u, 0x1e376c08u, 0x2748774cu, 0x34b0bcb5u, 0x391c0cb3u, 0x4ed8aa4au,
24 0x5b9cca4fu, 0x682e6ff3u, 0x748f82eeu, 0x78a5636fu, 0x84c87814u, 0x8cc70208u,
25 0x90befffau, 0xa4506cebu, 0xbef9a3f7u, 0xc67178f2u
34 for (
int i = 0; i < 16; i++) {
35 W[i] = ((uint32_t)block[i * 4 + 0] << 24)
36 | ((uint32_t)block[i * 4 + 1] << 16)
37 | ((uint32_t)block[i * 4 + 2] << 8)
38 | (uint32_t)block[i * 4 + 3];
40 for (
int i = 16; i < 64; i++) {
41 uint32_t s0 =
rotr(W[i - 15], 7) ^
rotr(W[i - 15], 18) ^ (W[i - 15] >> 3);
42 uint32_t s1 =
rotr(W[i - 2], 17) ^
rotr(W[i - 2], 19) ^ (W[i - 2] >> 10);
43 W[i] = W[i - 16] + s0 + W[i - 7] + s1;
46 uint32_t a = H[0], b = H[1], c = H[2], d = H[3];
47 uint32_t e = H[4], f = H[5], g = H[6], h = H[7];
49 for (
int i = 0; i < 64; i++) {
51 uint32_t ch = (e & f) ^ ((~e) & g);
52 uint32_t t1 = h + S1 + ch +
K[i] + W[i];
54 uint32_t mj = (a & b) ^ (a & c) ^ (b & c);
55 uint32_t t2 = S0 + mj;
62 H[0] += a; H[1] += b; H[2] += c; H[3] += d;
63 H[4] += e; H[5] += f; H[6] += g; H[7] += h;
68 0x6a09e667u, 0xbb67ae85u, 0x3c6ef372u, 0xa54ff53au,
69 0x510e527fu, 0x9b05688cu, 0x1f83d9abu, 0x5be0cd19u
72 uint64_t bit_len = (uint64_t)len * 8;
76 while (len - off >= 64) {
83 uint8_t pad[128] = {0};
84 size_t rem = len - off;
85 memcpy(pad, data + off, rem);
96 for (
int i = 0; i < 8; i++) {
97 pad[pad_len - 1 - i] = (uint8_t)(bit_len >> (i * 8));
104 for (
int i = 0; i < 8; i++) {
105 digest[i * 4 + 0] = (uint8_t)(H[i] >> 24);
106 digest[i * 4 + 1] = (uint8_t)(H[i] >> 16);
107 digest[i * 4 + 2] = (uint8_t)(H[i] >> 8);
108 digest[i * 4 + 3] = (uint8_t)(H[i] );