sha1.h 707 Bytes
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14
/*
 * 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.
 */

typedef struct {
	unsigned long long size;
	unsigned int H[5];
	unsigned int W[16];
} blk_SHA_CTX;

15 16 17
void git__blk_SHA1_Init(blk_SHA_CTX *ctx);
void git__blk_SHA1_Update(blk_SHA_CTX *ctx, const void *dataIn, unsigned long len);
void git__blk_SHA1_Final(unsigned char hashout[20], blk_SHA_CTX *ctx);
18

19
#define SHA_CTX		blk_SHA_CTX
20 21 22
#define SHA1_Init	git__blk_SHA1_Init
#define SHA1_Update	git__blk_SHA1_Update
#define SHA1_Final	git__blk_SHA1_Final