19fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/*
29fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamCopyright (C) 1996-1997 Id Software, Inc.
39fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
49fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamThis program is free software; you can redistribute it and/or
59fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreammodify it under the terms of the GNU General Public License
69fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamas published by the Free Software Foundation; either version 2
79fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamof the License, or (at your option) any later version.
89fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
99fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamThis program is distributed in the hope that it will be useful,
109fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreambut WITHOUT ANY WARRANTY; without even the implied warranty of
119fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
129fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
139fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamSee the GNU General Public License for more details.
149fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
159fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamYou should have received a copy of the GNU General Public License
169fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamalong with this program; if not, write to the Free Software
179fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFoundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
189fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
199fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream*/
209fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* GLOBAL.H - RSAREF types and constants */
219fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
229fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#include <string.h>
239fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
249fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* POINTER defines a generic pointer type */
259fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamtypedef unsigned char *POINTER;
269fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
279fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* UINT2 defines a two byte word */
289fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamtypedef unsigned short int UINT2;
299fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
309fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* UINT4 defines a four byte word */
319fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#ifdef __alpha__
329fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamtypedef unsigned int UINT4;
339fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#else
349fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamtypedef unsigned long int UINT4;
359fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#endif
369fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
379fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
389fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* MD4.H - header file for MD4C.C */
399fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
409fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* Copyright (C) 1991-2, RSA Data Security, Inc. Created 1991.
419fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
429fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamAll rights reserved.
439fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
449fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamLicense to copy and use this software is granted provided that it is identified as the �RSA Data Security, Inc. MD4 Message-Digest Algorithm� in all material mentioning or referencing this software or this function.
459fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamLicense is also granted to make and use derivative works provided that such works are identified as �derived from the RSA Data Security, Inc. MD4 Message-Digest Algorithm� in all material mentioning or referencing the derived work.
469fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamRSA Data Security, Inc. makes no representations concerning either the merchantability of this software or the suitability of this software for any particular purpose. It is provided �as is� without express or implied warranty of any kind.
479fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
489fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamThese notices must be retained in any copies of any part of this documentation and/or software. */
499fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
509fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* MD4 context. */
519fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamtypedef struct {
529fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	UINT4 state[4];				/* state (ABCD) */
539fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	UINT4 count[2];				/* number of bits, modulo 2^64 (lsb first) */
549fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	unsigned char buffer[64]; 			/* input buffer */
559fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream} MD4_CTX;
569fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
579fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamvoid MD4Init (MD4_CTX *);
589fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamvoid MD4Update (MD4_CTX *, unsigned char *, unsigned int);
599fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamvoid MD4Final (unsigned char [16], MD4_CTX *);
609fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
619fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
629fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
639fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* MD4C.C - RSA Data Security, Inc., MD4 message-digest algorithm */
649fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* Copyright (C) 1990-2, RSA Data Security, Inc. All rights reserved.
659fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
669fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamLicense to copy and use this software is granted provided that it is identified as the
679fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamRSA Data Security, Inc. MD4 Message-Digest Algorithm
689fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream in all material mentioning or referencing this software or this function.
699fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamLicense is also granted to make and use derivative works provided that such works are identified as
709fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamderived from the RSA Data Security, Inc. MD4 Message-Digest Algorithm
719fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamin all material mentioning or referencing the derived work.
729fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamRSA Data Security, Inc. makes no representations concerning either the merchantability of this software or the suitability of this software for any particular purpose. It is provided
739fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamas is without express or implied warranty of any kind.
749fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
759fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamThese notices must be retained in any copies of any part of this documentation and/or software. */
769fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
779fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* Constants for MD4Transform routine.  */
789fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define S11 3
799fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define S12 7
809fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define S13 11
819fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define S14 19
829fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define S21 3
839fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define S22 5
849fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define S23 9
859fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define S24 13
869fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define S31 3
879fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define S32 9
889fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define S33 11
899fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define S34 15
909fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
919fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamstatic void MD4Transform (UINT4 [4], unsigned char [64]);
929fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamstatic void Encode (unsigned char *, UINT4 *, unsigned int);
939fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamstatic void Decode (UINT4 *, unsigned char *, unsigned int);
949fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
959fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamstatic unsigned char PADDING[64] = {
969fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
979fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream};
989fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
999fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* F, G and H are basic MD4 functions. */
1009fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define F(x, y, z) (((x) & (y)) | ((~x) & (z)))
1019fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define G(x, y, z) (((x) & (y)) | ((x) & (z)) | ((y) & (z)))
1029fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define H(x, y, z) ((x) ^ (y) ^ (z))
1039fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1049fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* ROTATE_LEFT rotates x left n bits. */
1059fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define ROTATE_LEFT(x, n) (((x) << (n)) | ((x) >> (32-(n))))
1069fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1079fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* FF, GG and HH are transformations for rounds 1, 2 and 3 */
1089fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* Rotation is separate from addition to prevent recomputation */
1099fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define FF(a, b, c, d, x, s) {(a) += F ((b), (c), (d)) + (x); (a) = ROTATE_LEFT ((a), (s));}
1109fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1119fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define GG(a, b, c, d, x, s) {(a) += G ((b), (c), (d)) + (x) + (UINT4)0x5a827999; (a) = ROTATE_LEFT ((a), (s));}
1129fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1139fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream#define HH(a, b, c, d, x, s) {(a) += H ((b), (c), (d)) + (x) + (UINT4)0x6ed9eba1; (a) = ROTATE_LEFT ((a), (s));}
1149fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1159fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1169fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* MD4 initialization. Begins an MD4 operation, writing a new context. */
1179fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamvoid MD4Init (MD4_CTX *context)
1189fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream{
1199fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	context->count[0] = context->count[1] = 0;
1209fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1219fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* Load magic initialization constants.*/
1229fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamcontext->state[0] = 0x67452301;
1239fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamcontext->state[1] = 0xefcdab89;
1249fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamcontext->state[2] = 0x98badcfe;
1259fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamcontext->state[3] = 0x10325476;
1269fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream}
1279fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1289fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* MD4 block update operation. Continues an MD4 message-digest operation, processing another message block, and updating the context. */
1299fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamvoid MD4Update (MD4_CTX *context, unsigned char *input, unsigned int inputLen)
1309fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream{
1319fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	unsigned int i, index, partLen;
1329fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1339fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	/* Compute number of bytes mod 64 */
1349fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	index = (unsigned int)((context->count[0] >> 3) & 0x3F);
1359fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1369fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	/* Update number of bits */
1379fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	if ((context->count[0] += ((UINT4)inputLen << 3))< ((UINT4)inputLen << 3))
1389fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream		context->count[1]++;
1399fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1409fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	context->count[1] += ((UINT4)inputLen >> 29);
1419fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1429fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	partLen = 64 - index;
1439fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1449fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	/* Transform as many times as possible.*/
1459fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	if (inputLen >= partLen)
1469fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	{
1479fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream 		memcpy((POINTER)&context->buffer[index], (POINTER)input, partLen);
1489fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream 		MD4Transform (context->state, context->buffer);
1499fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1509fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream 		for (i = partLen; i + 63 < inputLen; i += 64)
1519fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream 			MD4Transform (context->state, &input[i]);
1529fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1539fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream 		index = 0;
1549fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	}
1559fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	else
1569fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream 		i = 0;
1579fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1589fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	/* Buffer remaining input */
1599fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	memcpy ((POINTER)&context->buffer[index], (POINTER)&input[i], inputLen-i);
1609fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream}
1619fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1629fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1639fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* MD4 finalization. Ends an MD4 message-digest operation, writing the the message digest and zeroizing the context. */
1649fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamvoid MD4Final (unsigned char digest[16], MD4_CTX *context)
1659fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream{
1669fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	unsigned char bits[8];
1679fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	unsigned int index, padLen;
1689fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1699fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	/* Save number of bits */
1709fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	Encode (bits, context->count, 8);
1719fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1729fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	/* Pad out to 56 mod 64.*/
1739fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	index = (unsigned int)((context->count[0] >> 3) & 0x3f);
1749fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	padLen = (index < 56) ? (56 - index) : (120 - index);
1759fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	MD4Update (context, PADDING, padLen);
1769fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1779fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	/* Append length (before padding) */
1789fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	MD4Update (context, bits, 8);
1799fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1809fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	/* Store state in digest */
1819fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	Encode (digest, context->state, 16);
1829fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1839fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	/* Zeroize sensitive information.*/
1849fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	memset ((POINTER)context, 0, sizeof (*context));
1859fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream}
1869fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1879fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1889fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* MD4 basic transformation. Transforms state based on block. */
1899fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamstatic void MD4Transform (UINT4 state[4], unsigned char block[64])
1909fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream{
1919fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	UINT4 a = state[0], b = state[1], c = state[2], d = state[3], x[16];
1929fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1939fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	Decode (x, block, 64);
1949fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
1959fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* Round 1 */
1969fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (a, b, c, d, x[ 0], S11); 				/* 1 */
1979fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (d, a, b, c, x[ 1], S12); 				/* 2 */
1989fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (c, d, a, b, x[ 2], S13); 				/* 3 */
1999fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (b, c, d, a, x[ 3], S14); 				/* 4 */
2009fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (a, b, c, d, x[ 4], S11); 				/* 5 */
2019fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (d, a, b, c, x[ 5], S12); 				/* 6 */
2029fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (c, d, a, b, x[ 6], S13); 				/* 7 */
2039fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (b, c, d, a, x[ 7], S14); 				/* 8 */
2049fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (a, b, c, d, x[ 8], S11); 				/* 9 */
2059fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (d, a, b, c, x[ 9], S12); 				/* 10 */
2069fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (c, d, a, b, x[10], S13); 			/* 11 */
2079fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (b, c, d, a, x[11], S14); 			/* 12 */
2089fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (a, b, c, d, x[12], S11); 			/* 13 */
2099fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (d, a, b, c, x[13], S12); 			/* 14 */
2109fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (c, d, a, b, x[14], S13); 			/* 15 */
2119fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamFF (b, c, d, a, x[15], S14); 			/* 16 */
2129fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2139fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* Round 2 */
2149fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (a, b, c, d, x[ 0], S21); 			/* 17 */
2159fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (d, a, b, c, x[ 4], S22); 			/* 18 */
2169fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (c, d, a, b, x[ 8], S23); 			/* 19 */
2179fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (b, c, d, a, x[12], S24); 			/* 20 */
2189fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (a, b, c, d, x[ 1], S21); 			/* 21 */
2199fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (d, a, b, c, x[ 5], S22); 			/* 22 */
2209fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (c, d, a, b, x[ 9], S23); 			/* 23 */
2219fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (b, c, d, a, x[13], S24); 			/* 24 */
2229fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (a, b, c, d, x[ 2], S21); 			/* 25 */
2239fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (d, a, b, c, x[ 6], S22); 			/* 26 */
2249fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (c, d, a, b, x[10], S23); 			/* 27 */
2259fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (b, c, d, a, x[14], S24); 			/* 28 */
2269fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (a, b, c, d, x[ 3], S21); 			/* 29 */
2279fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (d, a, b, c, x[ 7], S22); 			/* 30 */
2289fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (c, d, a, b, x[11], S23); 			/* 31 */
2299fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamGG (b, c, d, a, x[15], S24); 			/* 32 */
2309fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2319fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* Round 3 */
2329fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (a, b, c, d, x[ 0], S31);				/* 33 */
2339fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (d, a, b, c, x[ 8], S32); 			/* 34 */
2349fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (c, d, a, b, x[ 4], S33); 			/* 35 */
2359fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (b, c, d, a, x[12], S34); 			/* 36 */
2369fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (a, b, c, d, x[ 2], S31); 			/* 37 */
2379fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (d, a, b, c, x[10], S32); 			/* 38 */
2389fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (c, d, a, b, x[ 6], S33); 			/* 39 */
2399fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (b, c, d, a, x[14], S34); 			/* 40 */
2409fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (a, b, c, d, x[ 1], S31); 			/* 41 */
2419fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (d, a, b, c, x[ 9], S32); 			/* 42 */
2429fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (c, d, a, b, x[ 5], S33); 			/* 43 */
2439fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (b, c, d, a, x[13], S34); 			/* 44 */
2449fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (a, b, c, d, x[ 3], S31); 			/* 45 */
2459fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (d, a, b, c, x[11], S32); 			/* 46 */
2469fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (c, d, a, b, x[ 7], S33); 			/* 47 */
2479fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamHH (b, c, d, a, x[15], S34);			/* 48 */
2489fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2499fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamstate[0] += a;
2509fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamstate[1] += b;
2519fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamstate[2] += c;
2529fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamstate[3] += d;
2539fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2549fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	/* Zeroize sensitive information.*/
2559fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	memset ((POINTER)x, 0, sizeof (x));
2569fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream}
2579fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2589fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2599fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* Encodes input (UINT4) into output (unsigned char). Assumes len is a multiple of 4. */
2609fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamstatic void Encode (unsigned char *output, UINT4 *input, unsigned int len)
2619fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream{
2629fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	unsigned int i, j;
2639fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2649fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	for (i = 0, j = 0; j < len; i++, j += 4) {
2659fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream 		output[j] = (unsigned char)(input[i] & 0xff);
2669fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream 		output[j+1] = (unsigned char)((input[i] >> 8) & 0xff);
2679fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream 		output[j+2] = (unsigned char)((input[i] >> 16) & 0xff);
2689fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream 		output[j+3] = (unsigned char)((input[i] >> 24) & 0xff);
2699fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	}
2709fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream}
2719fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2729fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2739fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream/* Decodes input (unsigned char) into output (UINT4). Assumes len is a multiple of 4. */
2749fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamstatic void Decode (UINT4 *output, unsigned char *input, unsigned int len)
2759fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream{
2769fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamunsigned int i, j;
2779fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2789fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamfor (i = 0, j = 0; j < len; i++, j += 4)
2799fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream 	output[i] = ((UINT4)input[j]) | (((UINT4)input[j+1]) << 8) | (((UINT4)input[j+2]) << 16) | (((UINT4)input[j+3]) << 24);
2809fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream}
2819fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2829fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream//===================================================================
2839fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2849fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamunsigned Com_BlockChecksum (void *buffer, int length)
2859fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream{
2869fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	int			digest[4];
2879fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	unsigned	val;
2889fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	MD4_CTX		ctx;
2899fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2909fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	MD4Init (&ctx);
2919fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	MD4Update (&ctx, (unsigned char *)buffer, length);
2929fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	MD4Final ( (unsigned char *)digest, &ctx);
2939fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2949fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	val = digest[0] ^ digest[1] ^ digest[2] ^ digest[3];
2959fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2969fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	return val;
2979fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream}
2989fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
2999fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstreamvoid Com_BlockFullChecksum (void *buffer, int len, unsigned char *outbuf)
3009fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream{
3019fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	MD4_CTX		ctx;
3029fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream
3039fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	MD4Init (&ctx);
3049fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	MD4Update (&ctx, (unsigned char *)buffer, len);
3059fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream	MD4Final ( outbuf, &ctx);
3069fd67c44777b350dc56f3e70c88963b0d966ffc7quake upstream}
307