gtkradiant/libs/md4lib.h

54 lines
1.4 KiB
C
Raw Normal View History

/*
* This is an OpenSSL-compatible implementation of the RSA Data Security,
* Inc. MD4 Message-Digest Algorithm.
*
* Written by Solar Designer <solar@openwall.com> in 2001, and placed in
* the public domain. See md4.c for more information.
*/
#ifndef MD4_H
#define MD4_H
#ifdef _WIN32
#include "stdint.msvc.h"
#else
#include <stdint.h>
#endif
struct hash_method {
const char *name;
/* Number of bytes that must be allocated for context */
unsigned int context_size;
/* Number of bytes that must be allocated for result()'s digest */
unsigned int digest_size;
void ( *init )( void *context );
void ( *loop )( void *context, const void *data, size_t size );
void ( *result )( void *context, unsigned char *digest_r );
};
const struct hash_method *hash_method_lookup( const char *name );
/* NULL-terminated list of all hash methods */
extern const struct hash_method *hash_methods[];
#define MD4_RESULTLEN ( 128 / 8 )
struct md4_context {
uint_fast32_t lo, hi;
uint_fast32_t a, b, c, d;
unsigned char buffer[64];
uint_fast32_t block[MD4_RESULTLEN];
};
void md4_init( struct md4_context *ctx );
void md4_update( struct md4_context *ctx, const void *data, size_t size );
void md4_final( struct md4_context *ctx, unsigned char result[MD4_RESULTLEN] );
void md4_get_digest( const void *data, size_t size,
unsigned char result[MD4_RESULTLEN] );
extern const struct hash_method hash_method_md4;
#endif