2013-02-16 01:03:42 +00:00
|
|
|
/*
|
|
|
|
* SHA1 routine optimized to do word accesses rather than byte accesses,
|
|
|
|
* and to avoid unnecessary copies into the context array.
|
|
|
|
*
|
|
|
|
* This was initially based on the Mozilla SHA1 implementation, although
|
|
|
|
* none of the original Mozilla code remains.
|
|
|
|
*/
|
2014-02-11 18:14:46 +00:00
|
|
|
#ifndef SHA1_H
|
|
|
|
#define SHA1_H
|
2013-02-16 01:03:42 +00:00
|
|
|
|
2024-02-27 22:22:49 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-02-28 04:09:57 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
2013-02-16 01:03:42 +00:00
|
|
|
unsigned long long size;
|
|
|
|
unsigned int H[5];
|
|
|
|
unsigned int W[16];
|
|
|
|
} blk_SHA_CTX;
|
|
|
|
|
|
|
|
void blk_SHA1_Init(blk_SHA_CTX *ctx);
|
|
|
|
void blk_SHA1_Update(blk_SHA_CTX *ctx, const void *dataIn, unsigned long len);
|
|
|
|
void blk_SHA1_Final(unsigned char hashout[20], blk_SHA_CTX *ctx);
|
|
|
|
|
|
|
|
/* Make us use the standard names */
|
2014-02-28 04:09:57 +00:00
|
|
|
#define SHA_CTX blk_SHA_CTX
|
|
|
|
#define SHA1_Init blk_SHA1_Init
|
|
|
|
#define SHA1_Update blk_SHA1_Update
|
|
|
|
#define SHA1_Final blk_SHA1_Final
|
2013-02-16 01:03:42 +00:00
|
|
|
|
2024-04-23 07:28:11 +00:00
|
|
|
/* Helper function that calculates an SHA1 has and returns the first 4 bytes as uint32_t */
|
|
|
|
uint32_t SHA1_uint32(const void *dataIn, unsigned long len);
|
2014-02-11 18:14:46 +00:00
|
|
|
|
2024-02-27 22:22:49 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2014-02-11 18:14:46 +00:00
|
|
|
#endif // SHA1_H
|