2006-09-17 13:00:18 +00:00
|
|
|
/**********************************************************************
|
2006-09-21 13:04:43 +00:00
|
|
|
* gosthash.h *
|
2006-09-17 13:00:18 +00:00
|
|
|
* Copyright (c) 2005-2006 Cryptocom LTD *
|
|
|
|
* This file is distributed under the same license as OpenSSL *
|
|
|
|
* *
|
|
|
|
* Declaration of GOST R 34.11-94 hash functions *
|
|
|
|
* uses and gost89.h Doesn't need OpenSSL *
|
|
|
|
**********************************************************************/
|
|
|
|
#ifndef GOSTHASH_H
|
2015-01-22 03:40:55 +00:00
|
|
|
# define GOSTHASH_H
|
|
|
|
# include "gost89.h"
|
|
|
|
# include <stdlib.h>
|
2008-01-05 21:28:53 +00:00
|
|
|
|
2015-01-22 03:40:55 +00:00
|
|
|
# if (defined(_WIN32) || defined(_WIN64)) && !defined(__MINGW32__)
|
2008-01-05 21:28:53 +00:00
|
|
|
typedef __int64 ghosthash_len;
|
2015-01-22 03:40:55 +00:00
|
|
|
# elif defined(__arch64__)
|
2008-01-05 21:28:53 +00:00
|
|
|
typedef long ghosthash_len;
|
2015-01-22 03:40:55 +00:00
|
|
|
# else
|
2008-01-05 21:28:53 +00:00
|
|
|
typedef long long ghosthash_len;
|
2015-01-22 03:40:55 +00:00
|
|
|
# endif
|
2008-01-05 21:28:53 +00:00
|
|
|
|
2006-09-17 13:00:18 +00:00
|
|
|
typedef struct gost_hash_ctx {
|
2015-01-22 03:40:55 +00:00
|
|
|
ghosthash_len len;
|
|
|
|
gost_ctx *cipher_ctx;
|
|
|
|
int left;
|
|
|
|
byte H[32];
|
|
|
|
byte S[32];
|
|
|
|
byte remainder[32];
|
|
|
|
} gost_hash_ctx;
|
2006-09-17 13:00:18 +00:00
|
|
|
|
|
|
|
/* Initalizes gost hash ctx, including creation of gost cipher ctx */
|
|
|
|
|
2015-01-22 03:40:55 +00:00
|
|
|
int init_gost_hash_ctx(gost_hash_ctx * ctx,
|
|
|
|
const gost_subst_block * subst_block);
|
|
|
|
void done_gost_hash_ctx(gost_hash_ctx * ctx);
|
2006-09-17 13:00:18 +00:00
|
|
|
|
2015-01-22 03:40:55 +00:00
|
|
|
/*
|
|
|
|
* Cleans up all fields, except cipher ctx preparing ctx for computing of new
|
|
|
|
* hash value
|
|
|
|
*/
|
|
|
|
int start_hash(gost_hash_ctx * ctx);
|
2006-09-17 13:00:18 +00:00
|
|
|
|
|
|
|
/* Hashes block of data */
|
2015-01-22 03:40:55 +00:00
|
|
|
int hash_block(gost_hash_ctx * ctx, const byte * block, size_t length);
|
2006-09-17 13:00:18 +00:00
|
|
|
|
2015-01-22 03:40:55 +00:00
|
|
|
/*
|
|
|
|
* Finalizes computation of hash and fills buffer (which should be at least
|
|
|
|
* 32 bytes long) with value of computed hash.
|
|
|
|
*/
|
|
|
|
int finish_hash(gost_hash_ctx * ctx, byte * hashval);
|
2006-09-17 13:00:18 +00:00
|
|
|
|
2015-01-22 03:40:55 +00:00
|
|
|
#endif
|