Source code of Windows XP (NT5)
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
#ifndef __MD4_H__
#define __MD4_H__
#ifndef RSA32API
#define RSA32API __stdcall
#endif
/*
** ******************************************************************** ** md4.h -- Header file for implementation of ** ** MD4 Message Digest Algorithm ** ** Updated: 2/13/90 by Ronald L. Rivest ** ** (C) 1990 RSA Data Security, Inc. ** ** ******************************************************************** */
#ifdef __cplusplus
extern "C" { #endif
// MD4Update Errors
#define MD4_SUCCESS 0
#define MD4_TOO_BIG 1
#define MD4_ALREADY_DONE 2
// MD4 Digest length -- 4 word result == 16 bytes
#define MD4DIGESTLEN 16
// Block size of MD4 -- Assumes 8 bits per byte
#define MD4BLOCKSIZE 64
#define MD4BYTESTOBITS(bytes) ((bytes)*8) // MDupdate wants bits
/* MDstruct is the data structure for a message digest computation.
*/ typedef struct { unsigned long buffer[4]; /* Holds 4-word result of MD computation */ unsigned char count[8]; /* Number of bits processed so far */ unsigned int done; /* Nonzero means MD computation finished */ } MDstruct, *MDptr;
/* MDbegin(MD)
** Input: MD -- an MDptr ** Initialize the MDstruct prepatory to doing a message digest ** computation. ** ** MTS: Assumes MDPtr is locked against simultaneous use. */ extern void MDbegin(MDptr);
/* MDupdate(MD,X,count)
** Input: MD -- an MDptr ** X -- a pointer to an array of unsigned characters. ** count -- the number of bits of X to use (an unsigned int). ** Updates MD using the first "count" bits of X. ** The array pointed to by X is not modified. ** If count is not a multiple of 8, MDupdate uses high bits of ** last byte. ** This is the basic input routine for a user. ** The routine terminates the MD computation when count < MD4BLOCKSIZE, so ** every MD computation should end with one call to MDupdate with a ** count less than MD4BLOCKSIZE. Zero is OK for a count. ** ** Return values: ** MD4_SUCCESS: success ** MD4_TOO_LONG: Hash is already terminated ** MD4_ALREADY_DONE: Length is invalid (too big) ** ** MTS: Assumes MDPtr is locked against simultaneous use. ** ** ** NOTE: MDupdate wants the length in BITS */ extern int MDupdate(MDptr, const unsigned char *pbData, int wLen);
/*
This second implementation of MD4 entry points is the newer style, optimized implementation, compatible with newer code expecting these entry point names.
Scott Field (sfield) 21-Oct-97
*/
#ifndef UINT4
#define UINT4 unsigned long
#endif
/* Data structure for MD4 (Message Digest) computation */ typedef struct { UINT4 state[4]; /* state (ABCD) */ UINT4 count[2]; /* number of bits, modulo 2^64 (lsb first) */ unsigned char buffer[64]; /* input buffer */ unsigned char digest[16]; /* actual digest after MD4Final call */ } MD4_CTX;
#define MD4_LEN 16
void RSA32API MD4Init (MD4_CTX *); void RSA32API MD4Update (MD4_CTX *, unsigned char *, unsigned int); void RSA32API MD4Final (MD4_CTX * );
#ifdef __cplusplus
} #endif
#endif __MD4_H__
|