1 /* MD4.H - header file for MD4C.C
5 /* Copyright (C) 1991-2, RSA Data Security, Inc. Created 1991. All
8 License to copy and use this software is granted provided that it
9 is identified as the "RSA Data Security, Inc. MD4 Message-Digest
10 Algorithm" in all material mentioning or referencing this software
12 License is also granted to make and use derivative works provided
13 that such works are identified as "derived from the RSA Data
14 Security, Inc. MD4 Message-Digest Algorithm" in all material
15 mentioning or referencing the derived work.
17 RSA Data Security, Inc. makes no representations concerning either
18 the merchantability of this software or the suitability of this
19 software for any particular purpose. It is provided "as is"
20 without express or implied warranty of any kind.
22 These notices must be retained in any copies of any part of this
23 documentation and/or software.
29 typedef struct MD4Context {
30 u_int32_t state[4]; /* state (ABCD) */
31 u_int32_t count[2]; /* number of bits, modulo 2^64 (lsb first) */
32 unsigned char buffer[64]; /* input buffer */
35 #include <sys/cdefs.h>
39 /* Ensure libmd symbols do not clash with libcrypto */
42 #define MD4Init _libmd_MD4Init
45 #define MD4Update _libmd_MD4Update
48 #define MD4Pad _libmd_MD4Pad
51 #define MD4Final _libmd_MD4Final
54 #define MD4End _libmd_MD4End
57 #define MD4Fd _libmd_MD4Fd
60 #define MD4FdChunk _libmd_MD4FdChunk
63 #define MD4File _libmd_MD4File
66 #define MD4FileChunk _libmd_MD4FileChunk
69 #define MD4Data _libmd_MD4Data
72 void MD4Init(MD4_CTX *);
73 void MD4Update(MD4_CTX *, const void *, unsigned int);
74 void MD4Pad(MD4_CTX *);
75 void MD4Final(unsigned char [16], MD4_CTX *);
76 char * MD4End(MD4_CTX *, char *);
77 char * MD4Fd(int, char *);
78 char * MD4FdChunk(int, char *, off_t, off_t);
79 char * MD4File(const char *, char *);
80 char * MD4FileChunk(const char *, char *, off_t, off_t);
81 char * MD4Data(const void *, unsigned int, char *);