| 153 | | a = buf[0]; |
| 154 | | b = buf[1]; |
| 155 | | c = buf[2]; |
| 156 | | d = buf[3]; |
| 157 | | |
| 158 | | MD5STEP(F1, a, b, c, d, in[0] + 0xd76aa478, 7); |
| 159 | | MD5STEP(F1, d, a, b, c, in[1] + 0xe8c7b756, 12); |
| 160 | | MD5STEP(F1, c, d, a, b, in[2] + 0x242070db, 17); |
| 161 | | MD5STEP(F1, b, c, d, a, in[3] + 0xc1bdceee, 22); |
| 162 | | MD5STEP(F1, a, b, c, d, in[4] + 0xf57c0faf, 7); |
| 163 | | MD5STEP(F1, d, a, b, c, in[5] + 0x4787c62a, 12); |
| 164 | | MD5STEP(F1, c, d, a, b, in[6] + 0xa8304613, 17); |
| 165 | | MD5STEP(F1, b, c, d, a, in[7] + 0xfd469501, 22); |
| 166 | | MD5STEP(F1, a, b, c, d, in[8] + 0x698098d8, 7); |
| 167 | | MD5STEP(F1, d, a, b, c, in[9] + 0x8b44f7af, 12); |
| 168 | | MD5STEP(F1, c, d, a, b, in[10] + 0xffff5bb1, 17); |
| 169 | | MD5STEP(F1, b, c, d, a, in[11] + 0x895cd7be, 22); |
| 170 | | MD5STEP(F1, a, b, c, d, in[12] + 0x6b901122, 7); |
| 171 | | MD5STEP(F1, d, a, b, c, in[13] + 0xfd987193, 12); |
| 172 | | MD5STEP(F1, c, d, a, b, in[14] + 0xa679438e, 17); |
| 173 | | MD5STEP(F1, b, c, d, a, in[15] + 0x49b40821, 22); |
| 174 | | |
| 175 | | MD5STEP(F2, a, b, c, d, in[1] + 0xf61e2562, 5); |
| 176 | | MD5STEP(F2, d, a, b, c, in[6] + 0xc040b340, 9); |
| 177 | | MD5STEP(F2, c, d, a, b, in[11] + 0x265e5a51, 14); |
| 178 | | MD5STEP(F2, b, c, d, a, in[0] + 0xe9b6c7aa, 20); |
| 179 | | MD5STEP(F2, a, b, c, d, in[5] + 0xd62f105d, 5); |
| 180 | | MD5STEP(F2, d, a, b, c, in[10] + 0x02441453, 9); |
| 181 | | MD5STEP(F2, c, d, a, b, in[15] + 0xd8a1e681, 14); |
| 182 | | MD5STEP(F2, b, c, d, a, in[4] + 0xe7d3fbc8, 20); |
| 183 | | MD5STEP(F2, a, b, c, d, in[9] + 0x21e1cde6, 5); |
| 184 | | MD5STEP(F2, d, a, b, c, in[14] + 0xc33707d6, 9); |
| 185 | | MD5STEP(F2, c, d, a, b, in[3] + 0xf4d50d87, 14); |
| 186 | | MD5STEP(F2, b, c, d, a, in[8] + 0x455a14ed, 20); |
| 187 | | MD5STEP(F2, a, b, c, d, in[13] + 0xa9e3e905, 5); |
| 188 | | MD5STEP(F2, d, a, b, c, in[2] + 0xfcefa3f8, 9); |
| 189 | | MD5STEP(F2, c, d, a, b, in[7] + 0x676f02d9, 14); |
| 190 | | MD5STEP(F2, b, c, d, a, in[12] + 0x8d2a4c8a, 20); |
| 191 | | |
| 192 | | MD5STEP(F3, a, b, c, d, in[5] + 0xfffa3942, 4); |
| 193 | | MD5STEP(F3, d, a, b, c, in[8] + 0x8771f681, 11); |
| 194 | | MD5STEP(F3, c, d, a, b, in[11] + 0x6d9d6122, 16); |
| 195 | | MD5STEP(F3, b, c, d, a, in[14] + 0xfde5380c, 23); |
| 196 | | MD5STEP(F3, a, b, c, d, in[1] + 0xa4beea44, 4); |
| 197 | | MD5STEP(F3, d, a, b, c, in[4] + 0x4bdecfa9, 11); |
| 198 | | MD5STEP(F3, c, d, a, b, in[7] + 0xf6bb4b60, 16); |
| 199 | | MD5STEP(F3, b, c, d, a, in[10] + 0xbebfbc70, 23); |
| 200 | | MD5STEP(F3, a, b, c, d, in[13] + 0x289b7ec6, 4); |
| 201 | | MD5STEP(F3, d, a, b, c, in[0] + 0xeaa127fa, 11); |
| 202 | | MD5STEP(F3, c, d, a, b, in[3] + 0xd4ef3085, 16); |
| 203 | | MD5STEP(F3, b, c, d, a, in[6] + 0x04881d05, 23); |
| 204 | | MD5STEP(F3, a, b, c, d, in[9] + 0xd9d4d039, 4); |
| 205 | | MD5STEP(F3, d, a, b, c, in[12] + 0xe6db99e5, 11); |
| 206 | | MD5STEP(F3, c, d, a, b, in[15] + 0x1fa27cf8, 16); |
| 207 | | MD5STEP(F3, b, c, d, a, in[2] + 0xc4ac5665, 23); |
| 208 | | |
| 209 | | MD5STEP(F4, a, b, c, d, in[0] + 0xf4292244, 6); |
| 210 | | MD5STEP(F4, d, a, b, c, in[7] + 0x432aff97, 10); |
| 211 | | MD5STEP(F4, c, d, a, b, in[14] + 0xab9423a7, 15); |
| 212 | | MD5STEP(F4, b, c, d, a, in[5] + 0xfc93a039, 21); |
| 213 | | MD5STEP(F4, a, b, c, d, in[12] + 0x655b59c3, 6); |
| 214 | | MD5STEP(F4, d, a, b, c, in[3] + 0x8f0ccc92, 10); |
| 215 | | MD5STEP(F4, c, d, a, b, in[10] + 0xffeff47d, 15); |
| 216 | | MD5STEP(F4, b, c, d, a, in[1] + 0x85845dd1, 21); |
| 217 | | MD5STEP(F4, a, b, c, d, in[8] + 0x6fa87e4f, 6); |
| 218 | | MD5STEP(F4, d, a, b, c, in[15] + 0xfe2ce6e0, 10); |
| 219 | | MD5STEP(F4, c, d, a, b, in[6] + 0xa3014314, 15); |
| 220 | | MD5STEP(F4, b, c, d, a, in[13] + 0x4e0811a1, 21); |
| 221 | | MD5STEP(F4, a, b, c, d, in[4] + 0xf7537e82, 6); |
| 222 | | MD5STEP(F4, d, a, b, c, in[11] + 0xbd3af235, 10); |
| 223 | | MD5STEP(F4, c, d, a, b, in[2] + 0x2ad7d2bb, 15); |
| 224 | | MD5STEP(F4, b, c, d, a, in[9] + 0xeb86d391, 21); |
| 225 | | |
| 226 | | buf[0] += a; |
| 227 | | buf[1] += b; |
| 228 | | buf[2] += c; |
| 229 | | buf[3] += d; |
| 230 | | } |
| 231 | | |
| 232 | | #endif |
| | 156 | a = buf[0]; |
| | 157 | b = buf[1]; |
| | 158 | c = buf[2]; |
| | 159 | d = buf[3]; |
| | 160 | |
| | 161 | MD5STEP(F1, a, b, c, d, in[0] + 0xd76aa478, 7); |
| | 162 | MD5STEP(F1, d, a, b, c, in[1] + 0xe8c7b756, 12); |
| | 163 | MD5STEP(F1, c, d, a, b, in[2] + 0x242070db, 17); |
| | 164 | MD5STEP(F1, b, c, d, a, in[3] + 0xc1bdceee, 22); |
| | 165 | MD5STEP(F1, a, b, c, d, in[4] + 0xf57c0faf, 7); |
| | 166 | MD5STEP(F1, d, a, b, c, in[5] + 0x4787c62a, 12); |
| | 167 | MD5STEP(F1, c, d, a, b, in[6] + 0xa8304613, 17); |
| | 168 | MD5STEP(F1, b, c, d, a, in[7] + 0xfd469501, 22); |
| | 169 | MD5STEP(F1, a, b, c, d, in[8] + 0x698098d8, 7); |
| | 170 | MD5STEP(F1, d, a, b, c, in[9] + 0x8b44f7af, 12); |
| | 171 | MD5STEP(F1, c, d, a, b, in[10] + 0xffff5bb1, 17); |
| | 172 | MD5STEP(F1, b, c, d, a, in[11] + 0x895cd7be, 22); |
| | 173 | MD5STEP(F1, a, b, c, d, in[12] + 0x6b901122, 7); |
| | 174 | MD5STEP(F1, d, a, b, c, in[13] + 0xfd987193, 12); |
| | 175 | MD5STEP(F1, c, d, a, b, in[14] + 0xa679438e, 17); |
| | 176 | MD5STEP(F1, b, c, d, a, in[15] + 0x49b40821, 22); |
| | 177 | |
| | 178 | MD5STEP(F2, a, b, c, d, in[1] + 0xf61e2562, 5); |
| | 179 | MD5STEP(F2, d, a, b, c, in[6] + 0xc040b340, 9); |
| | 180 | MD5STEP(F2, c, d, a, b, in[11] + 0x265e5a51, 14); |
| | 181 | MD5STEP(F2, b, c, d, a, in[0] + 0xe9b6c7aa, 20); |
| | 182 | MD5STEP(F2, a, b, c, d, in[5] + 0xd62f105d, 5); |
| | 183 | MD5STEP(F2, d, a, b, c, in[10] + 0x02441453, 9); |
| | 184 | MD5STEP(F2, c, d, a, b, in[15] + 0xd8a1e681, 14); |
| | 185 | MD5STEP(F2, b, c, d, a, in[4] + 0xe7d3fbc8, 20); |
| | 186 | MD5STEP(F2, a, b, c, d, in[9] + 0x21e1cde6, 5); |
| | 187 | MD5STEP(F2, d, a, b, c, in[14] + 0xc33707d6, 9); |
| | 188 | MD5STEP(F2, c, d, a, b, in[3] + 0xf4d50d87, 14); |
| | 189 | MD5STEP(F2, b, c, d, a, in[8] + 0x455a14ed, 20); |
| | 190 | MD5STEP(F2, a, b, c, d, in[13] + 0xa9e3e905, 5); |
| | 191 | MD5STEP(F2, d, a, b, c, in[2] + 0xfcefa3f8, 9); |
| | 192 | MD5STEP(F2, c, d, a, b, in[7] + 0x676f02d9, 14); |
| | 193 | MD5STEP(F2, b, c, d, a, in[12] + 0x8d2a4c8a, 20); |
| | 194 | |
| | 195 | MD5STEP(F3, a, b, c, d, in[5] + 0xfffa3942, 4); |
| | 196 | MD5STEP(F3, d, a, b, c, in[8] + 0x8771f681, 11); |
| | 197 | MD5STEP(F3, c, d, a, b, in[11] + 0x6d9d6122, 16); |
| | 198 | MD5STEP(F3, b, c, d, a, in[14] + 0xfde5380c, 23); |
| | 199 | MD5STEP(F3, a, b, c, d, in[1] + 0xa4beea44, 4); |
| | 200 | MD5STEP(F3, d, a, b, c, in[4] + 0x4bdecfa9, 11); |
| | 201 | MD5STEP(F3, c, d, a, b, in[7] + 0xf6bb4b60, 16); |
| | 202 | MD5STEP(F3, b, c, d, a, in[10] + 0xbebfbc70, 23); |
| | 203 | MD5STEP(F3, a, b, c, d, in[13] + 0x289b7ec6, 4); |
| | 204 | MD5STEP(F3, d, a, b, c, in[0] + 0xeaa127fa, 11); |
| | 205 | MD5STEP(F3, c, d, a, b, in[3] + 0xd4ef3085, 16); |
| | 206 | MD5STEP(F3, b, c, d, a, in[6] + 0x04881d05, 23); |
| | 207 | MD5STEP(F3, a, b, c, d, in[9] + 0xd9d4d039, 4); |
| | 208 | MD5STEP(F3, d, a, b, c, in[12] + 0xe6db99e5, 11); |
| | 209 | MD5STEP(F3, c, d, a, b, in[15] + 0x1fa27cf8, 16); |
| | 210 | MD5STEP(F3, b, c, d, a, in[2] + 0xc4ac5665, 23); |
| | 211 | |
| | 212 | MD5STEP(F4, a, b, c, d, in[0] + 0xf4292244, 6); |
| | 213 | MD5STEP(F4, d, a, b, c, in[7] + 0x432aff97, 10); |
| | 214 | MD5STEP(F4, c, d, a, b, in[14] + 0xab9423a7, 15); |
| | 215 | MD5STEP(F4, b, c, d, a, in[5] + 0xfc93a039, 21); |
| | 216 | MD5STEP(F4, a, b, c, d, in[12] + 0x655b59c3, 6); |
| | 217 | MD5STEP(F4, d, a, b, c, in[3] + 0x8f0ccc92, 10); |
| | 218 | MD5STEP(F4, c, d, a, b, in[10] + 0xffeff47d, 15); |
| | 219 | MD5STEP(F4, b, c, d, a, in[1] + 0x85845dd1, 21); |
| | 220 | MD5STEP(F4, a, b, c, d, in[8] + 0x6fa87e4f, 6); |
| | 221 | MD5STEP(F4, d, a, b, c, in[15] + 0xfe2ce6e0, 10); |
| | 222 | MD5STEP(F4, c, d, a, b, in[6] + 0xa3014314, 15); |
| | 223 | MD5STEP(F4, b, c, d, a, in[13] + 0x4e0811a1, 21); |
| | 224 | MD5STEP(F4, a, b, c, d, in[4] + 0xf7537e82, 6); |
| | 225 | MD5STEP(F4, d, a, b, c, in[11] + 0xbd3af235, 10); |
| | 226 | MD5STEP(F4, c, d, a, b, in[2] + 0x2ad7d2bb, 15); |
| | 227 | MD5STEP(F4, b, c, d, a, in[9] + 0xeb86d391, 21); |
| | 228 | |
| | 229 | buf[0] += a; |
| | 230 | buf[1] += b; |
| | 231 | buf[2] += c; |
| | 232 | buf[3] += d; |
| | 233 | } |