X-Git-Url: http://wagner.pp.ru/gitweb/?a=blobdiff_plain;f=gosthash2012.c;h=201fe317ec23fb954e023c6b7a9fc48b5b0993eb;hb=11777554bd63b16bb13aa3b7358d8e7809f17523;hp=ee534c2f9f838f2ef52797c23e88e63f98b9b5ef;hpb=835e0d788bfec1f51545b038cef135b02456b27b;p=openssl-gost%2Fengine.git diff --git a/gosthash2012.c b/gosthash2012.c index ee534c2..201fe31 100644 --- a/gosthash2012.c +++ b/gosthash2012.c @@ -35,24 +35,22 @@ void init_gost2012_hash_ctx(gost2012_hash_ctx * CTX, memset(CTX, 0, sizeof(gost2012_hash_ctx)); CTX->digest_size = digest_size; + /* + * IV for 512-bit hash should be 0^512 + * IV for 256-bit hash should be (00000001)^64 + * + * It's already zeroed when CTX is cleared above, so we only + * need to set it to 0x01-s for 256-bit hash. + */ if (digest_size == 256) memset(&CTX->h, 0x01, sizeof(uint512_u)); - else - memset(&CTX->h, 0x00, sizeof(uint512_u)); } static INLINE void pad(gost2012_hash_ctx * CTX) { - unsigned char buf[64]; - - if (CTX->bufsize > 63) - return; + memset(&(CTX->buffer[CTX->bufsize]), 0, sizeof(CTX->buffer) - CTX->bufsize); + CTX->buffer[CTX->bufsize] = 1; - memset(&buf, 0x00, sizeof buf); - memcpy(&buf, CTX->buffer, CTX->bufsize); - - buf[CTX->bufsize] = 0x01; - memcpy(CTX->buffer, &buf, sizeof buf); } static INLINE void add512(const union uint512_u *x, @@ -157,10 +155,13 @@ static void g(union uint512_u *h, const union uint512_u *N, static INLINE void stage2(gost2012_hash_ctx * CTX, const unsigned char *data) { - g(&(CTX->h), &(CTX->N), data); + union uint512_u m; + + memcpy(&m, data, sizeof(m)); + g(&(CTX->h), &(CTX->N), (const unsigned char *)&m); add512(&(CTX->N), &buffer512, &(CTX->N)); - add512(&(CTX->Sigma), (const union uint512_u *)data, &(CTX->Sigma)); + add512(&(CTX->Sigma), &m, &(CTX->Sigma)); } static INLINE void stage3(gost2012_hash_ctx * CTX) @@ -189,7 +190,6 @@ static INLINE void stage3(gost2012_hash_ctx * CTX) g(&(CTX->h), &buffer0, (const unsigned char *)&(CTX->N)); g(&(CTX->h), &buffer0, (const unsigned char *)&(CTX->Sigma)); - memcpy(&(CTX->hash), &(CTX->h), sizeof(uint512_u)); } /* @@ -239,7 +239,7 @@ void gost2012_finish_hash(gost2012_hash_ctx * CTX, unsigned char *digest) CTX->bufsize = 0; if (CTX->digest_size == 256) - memcpy(digest, &(CTX->hash.QWORD[4]), 32); + memcpy(digest, &(CTX->h.QWORD[4]), 32); else - memcpy(digest, &(CTX->hash.QWORD[0]), 64); + memcpy(digest, &(CTX->h.QWORD[0]), 64); }