00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034 #include <string.h>
00035 #include "md5.h"
00036
00037
00038
00039 #define S11 7
00040 #define S12 12
00041 #define S13 17
00042 #define S14 22
00043 #define S21 5
00044 #define S22 9
00045 #define S23 14
00046 #define S24 20
00047 #define S31 4
00048 #define S32 11
00049 #define S33 16
00050 #define S34 23
00051 #define S41 6
00052 #define S42 10
00053 #define S43 15
00054 #define S44 21
00055
00056
00057 static void MD5Transform (unsigned int [4], unsigned char [64]);
00058 static void Encode (unsigned char *, unsigned int *, unsigned int);
00059 static void Decode (unsigned int *, unsigned char *, unsigned int);
00060
00061
00062 static unsigned char PADDING[64] = {
00063 0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
00064 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
00065 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
00066 };
00067
00068
00069
00070 #define F(x, y, z) (((x) & (y)) | ((~x) & (z)))
00071 #define G(x, y, z) (((x) & (z)) | ((y) & (~z)))
00072 #define H(x, y, z) ((x) ^ (y) ^ (z))
00073 #define I(x, y, z) ((y) ^ ((x) | (~z)))
00074
00075
00076
00077 #define ROTATE_LEFT(x, n) (((x) << (n)) | ((x) >> (32-(n))))
00078
00079
00080
00081
00082
00083
00084 #define FF(a, b, c, d, x, s, ac) { \
00085 (a) += F ((b), (c), (d)) + (x) + (unsigned int)(ac); \
00086 (a) = ROTATE_LEFT ((a), (s)); \
00087 (a) += (b); \
00088 }
00089 #define GG(a, b, c, d, x, s, ac) { \
00090 (a) += G ((b), (c), (d)) + (x) + (unsigned int)(ac); \
00091 (a) = ROTATE_LEFT ((a), (s)); \
00092 (a) += (b); \
00093 }
00094 #define HH(a, b, c, d, x, s, ac) { \
00095 (a) += H ((b), (c), (d)) + (x) + (unsigned int)(ac); \
00096 (a) = ROTATE_LEFT ((a), (s)); \
00097 (a) += (b); \
00098 }
00099 #define II(a, b, c, d, x, s, ac) { \
00100 (a) += I ((b), (c), (d)) + (x) + (unsigned int)(ac); \
00101 (a) = ROTATE_LEFT ((a), (s)); \
00102 (a) += (b); \
00103 }
00104
00105
00106
00107
00108
00109
00110 void MD5Init (MD5_CTX *context)
00111 {
00112 context->count[0] = context->count[1] = 0;
00113
00114 context->state[0] = 0x67452301;
00115 context->state[1] = 0xefcdab89;
00116 context->state[2] = 0x98badcfe;
00117 context->state[3] = 0x10325476;
00118 }
00119
00120
00121
00122
00123
00124
00125
00126
00127
00128
00129
00130
00131 void U_MD5Update (MD5_CTX *context, unsigned char *input, unsigned int inputLen)
00132 {
00133 unsigned int i, index, partLen;
00134
00135
00136 index = (unsigned int)((context->count[0] >> 3) & 0x3F);
00137
00138
00139 if ((context->count[0] += ((unsigned int)inputLen << 3)) < ((unsigned int)inputLen << 3))
00140 context->count[1]++;
00141
00142 context->count[1] += ((unsigned int)inputLen >> 29);
00143 partLen = 64 - index;
00144
00145
00146 if (inputLen >= partLen) {
00147 memcpy((unsigned char *)&context->buffer[index], (unsigned char *)input, partLen);
00148 MD5Transform (context->state, context->buffer);
00149
00150 for (i = partLen; i + 63 < inputLen; i += 64)
00151 MD5Transform (context->state, &input[i]);
00152
00153 index = 0;
00154 }
00155 else
00156 i = 0;
00157
00158
00159 memcpy((unsigned char *)&context->buffer[index], (unsigned char *)&input[i], inputLen-i);
00160 }
00161
00162
00163
00164
00165
00166
00167
00168
00169
00170
00171 void U_MD5Final (unsigned char digest[16], MD5_CTX *context)
00172 {
00173 unsigned char bits[8];
00174 unsigned int index, padLen;
00175
00176
00177 Encode (bits, context->count, 8);
00178
00179
00180 index = (unsigned int)((context->count[0] >> 3) & 0x3f);
00181 padLen = (index < 56) ? (56 - index) : (120 - index);
00182 U_MD5Update (context, PADDING, padLen);
00183
00184
00185 U_MD5Update (context, bits, 8);
00186
00187
00188 Encode (digest, context->state, 16);
00189
00190
00191 memset ((unsigned char *)context, 0, sizeof (*context));
00192 }
00193
00194
00195
00196
00197
00198
00199
00200 static void MD5Transform (unsigned int state[4], unsigned char block[64])
00201 {
00202 unsigned int a = state[0], b = state[1], c = state[2], d = state[3], x[16];
00203
00204 Decode (x, block, 64);
00205
00206
00207 FF (a, b, c, d, x[ 0], S11, 0xd76aa478);
00208 FF (d, a, b, c, x[ 1], S12, 0xe8c7b756);
00209 FF (c, d, a, b, x[ 2], S13, 0x242070db);
00210 FF (b, c, d, a, x[ 3], S14, 0xc1bdceee);
00211 FF (a, b, c, d, x[ 4], S11, 0xf57c0faf);
00212 FF (d, a, b, c, x[ 5], S12, 0x4787c62a);
00213 FF (c, d, a, b, x[ 6], S13, 0xa8304613);
00214 FF (b, c, d, a, x[ 7], S14, 0xfd469501);
00215 FF (a, b, c, d, x[ 8], S11, 0x698098d8);
00216 FF (d, a, b, c, x[ 9], S12, 0x8b44f7af);
00217 FF (c, d, a, b, x[10], S13, 0xffff5bb1);
00218 FF (b, c, d, a, x[11], S14, 0x895cd7be);
00219 FF (a, b, c, d, x[12], S11, 0x6b901122);
00220 FF (d, a, b, c, x[13], S12, 0xfd987193);
00221 FF (c, d, a, b, x[14], S13, 0xa679438e);
00222 FF (b, c, d, a, x[15], S14, 0x49b40821);
00223
00224
00225 GG (a, b, c, d, x[ 1], S21, 0xf61e2562);
00226 GG (d, a, b, c, x[ 6], S22, 0xc040b340);
00227 GG (c, d, a, b, x[11], S23, 0x265e5a51);
00228 GG (b, c, d, a, x[ 0], S24, 0xe9b6c7aa);
00229 GG (a, b, c, d, x[ 5], S21, 0xd62f105d);
00230 GG (d, a, b, c, x[10], S22, 0x2441453);
00231 GG (c, d, a, b, x[15], S23, 0xd8a1e681);
00232 GG (b, c, d, a, x[ 4], S24, 0xe7d3fbc8);
00233 GG (a, b, c, d, x[ 9], S21, 0x21e1cde6);
00234 GG (d, a, b, c, x[14], S22, 0xc33707d6);
00235 GG (c, d, a, b, x[ 3], S23, 0xf4d50d87);
00236 GG (b, c, d, a, x[ 8], S24, 0x455a14ed);
00237 GG (a, b, c, d, x[13], S21, 0xa9e3e905);
00238 GG (d, a, b, c, x[ 2], S22, 0xfcefa3f8);
00239 GG (c, d, a, b, x[ 7], S23, 0x676f02d9);
00240 GG (b, c, d, a, x[12], S24, 0x8d2a4c8a);
00241
00242
00243 HH (a, b, c, d, x[ 5], S31, 0xfffa3942);
00244 HH (d, a, b, c, x[ 8], S32, 0x8771f681);
00245 HH (c, d, a, b, x[11], S33, 0x6d9d6122);
00246 HH (b, c, d, a, x[14], S34, 0xfde5380c);
00247 HH (a, b, c, d, x[ 1], S31, 0xa4beea44);
00248 HH (d, a, b, c, x[ 4], S32, 0x4bdecfa9);
00249 HH (c, d, a, b, x[ 7], S33, 0xf6bb4b60);
00250 HH (b, c, d, a, x[10], S34, 0xbebfbc70);
00251 HH (a, b, c, d, x[13], S31, 0x289b7ec6);
00252 HH (d, a, b, c, x[ 0], S32, 0xeaa127fa);
00253 HH (c, d, a, b, x[ 3], S33, 0xd4ef3085);
00254 HH (b, c, d, a, x[ 6], S34, 0x4881d05);
00255 HH (a, b, c, d, x[ 9], S31, 0xd9d4d039);
00256 HH (d, a, b, c, x[12], S32, 0xe6db99e5);
00257 HH (c, d, a, b, x[15], S33, 0x1fa27cf8);
00258 HH (b, c, d, a, x[ 2], S34, 0xc4ac5665);
00259
00260
00261 II (a, b, c, d, x[ 0], S41, 0xf4292244);
00262 II (d, a, b, c, x[ 7], S42, 0x432aff97);
00263 II (c, d, a, b, x[14], S43, 0xab9423a7);
00264 II (b, c, d, a, x[ 5], S44, 0xfc93a039);
00265 II (a, b, c, d, x[12], S41, 0x655b59c3);
00266 II (d, a, b, c, x[ 3], S42, 0x8f0ccc92);
00267 II (c, d, a, b, x[10], S43, 0xffeff47d);
00268 II (b, c, d, a, x[ 1], S44, 0x85845dd1);
00269 II (a, b, c, d, x[ 8], S41, 0x6fa87e4f);
00270 II (d, a, b, c, x[15], S42, 0xfe2ce6e0);
00271 II (c, d, a, b, x[ 6], S43, 0xa3014314);
00272 II (b, c, d, a, x[13], S44, 0x4e0811a1);
00273 II (a, b, c, d, x[ 4], S41, 0xf7537e82);
00274 II (d, a, b, c, x[11], S42, 0xbd3af235);
00275 II (c, d, a, b, x[ 2], S43, 0x2ad7d2bb);
00276 II (b, c, d, a, x[ 9], S44, 0xeb86d391);
00277
00278 state[0] += a;
00279 state[1] += b;
00280 state[2] += c;
00281 state[3] += d;
00282
00283
00284 memset ((unsigned char *)x, 0, sizeof (x));
00285 }
00286
00287
00288
00289
00290
00291
00292
00293
00294
00295 static void Encode (unsigned char *output, unsigned int *input, unsigned int len)
00296 {
00297 unsigned int i, j;
00298
00299 for (i = 0, j = 0; j < len; i++, j += 4) {
00300 output[j] = (unsigned char)(input[i] & 0xff);
00301 output[j+1] = (unsigned char)((input[i] >> 8) & 0xff);
00302 output[j+2] = (unsigned char)((input[i] >> 16) & 0xff);
00303 output[j+3] = (unsigned char)((input[i] >> 24) & 0xff);
00304 }
00305 }
00306
00307
00308
00309
00310
00311
00312
00313
00314
00315 static void Decode (unsigned int *output, unsigned char *input, unsigned int len)
00316 {
00317 unsigned int i, j;
00318
00319 for (i = 0, j = 0; j < len; i++, j += 4)
00320 output[i] = ((unsigned int)input[j]) | (((unsigned int)input[j+1]) << 8) |
00321 (((unsigned int)input[j+2]) << 16) | (((unsigned int)input[j+3]) << 24);
00322 }