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