2005-04-23 00:08:43 -06:00
|
|
|
/*
|
|
|
|
* SHA-1 implementation.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2005 Paul Mackerras <paulus@samba.org>
|
|
|
|
*
|
|
|
|
* This version assumes we are running on a big-endian machine.
|
|
|
|
* It calls an external sha1_core() to process blocks of 64 bytes.
|
|
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include "sha1.h"
|
|
|
|
|
|
|
|
extern void sha1_core(uint32_t *hash, const unsigned char *p,
|
|
|
|
unsigned int nblocks);
|
|
|
|
|
|
|
|
int SHA1_Init(SHA_CTX *c)
|
|
|
|
{
|
|
|
|
c->hash[0] = 0x67452301;
|
|
|
|
c->hash[1] = 0xEFCDAB89;
|
|
|
|
c->hash[2] = 0x98BADCFE;
|
|
|
|
c->hash[3] = 0x10325476;
|
|
|
|
c->hash[4] = 0xC3D2E1F0;
|
|
|
|
c->len = 0;
|
|
|
|
c->cnt = 0;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int SHA1_Update(SHA_CTX *c, const void *ptr, unsigned long n)
|
|
|
|
{
|
|
|
|
unsigned long nb;
|
|
|
|
const unsigned char *p = ptr;
|
|
|
|
|
2006-06-18 17:25:16 -06:00
|
|
|
c->len += (uint64_t) n << 3;
|
2005-04-23 00:08:43 -06:00
|
|
|
while (n != 0) {
|
|
|
|
if (c->cnt || n < 64) {
|
|
|
|
nb = 64 - c->cnt;
|
|
|
|
if (nb > n)
|
|
|
|
nb = n;
|
|
|
|
memcpy(&c->buf.b[c->cnt], p, nb);
|
|
|
|
if ((c->cnt += nb) == 64) {
|
|
|
|
sha1_core(c->hash, c->buf.b, 1);
|
|
|
|
c->cnt = 0;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
nb = n >> 6;
|
|
|
|
sha1_core(c->hash, p, nb);
|
|
|
|
nb <<= 6;
|
|
|
|
}
|
|
|
|
n -= nb;
|
|
|
|
p += nb;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int SHA1_Final(unsigned char *hash, SHA_CTX *c)
|
|
|
|
{
|
|
|
|
unsigned int cnt = c->cnt;
|
|
|
|
|
|
|
|
c->buf.b[cnt++] = 0x80;
|
|
|
|
if (cnt > 56) {
|
|
|
|
if (cnt < 64)
|
|
|
|
memset(&c->buf.b[cnt], 0, 64 - cnt);
|
|
|
|
sha1_core(c->hash, c->buf.b, 1);
|
|
|
|
cnt = 0;
|
|
|
|
}
|
|
|
|
if (cnt < 56)
|
|
|
|
memset(&c->buf.b[cnt], 0, 56 - cnt);
|
|
|
|
c->buf.l[7] = c->len;
|
|
|
|
sha1_core(c->hash, c->buf.b, 1);
|
|
|
|
memcpy(hash, c->hash, 20);
|
|
|
|
return 0;
|
|
|
|
}
|