typedef struct sha1_ctx_t {
uint32_t hash[8]; /* 5, +3 elements for sha256 */
- uint64_t total64;
+ uint64_t total64; /* must be directly after hash[] */
uint8_t wbuffer[64]; /* NB: always correctly aligned for uint64_t */
void (*process_block)(struct sha1_ctx_t*) FAST_FUNC;
} sha1_ctx_t;
#define sha256_end sha1_end
typedef struct sha512_ctx_t {
uint64_t hash[8];
- uint64_t total64[2];
+ uint64_t total64[2]; /* must be directly after hash[] */
uint8_t wbuffer[128]; /* NB: always correctly aligned for uint64_t */
} sha512_ctx_t;
void sha512_begin(sha512_ctx_t *ctx) FAST_FUNC;
0x510e527f,
0x9b05688c,
0x1f83d9ab,
- 0x5be0cd19
+ 0x5be0cd19,
+ 0,
+ 0,
};
static const uint32_t init512_lo[] = {
0xf3bcc908,
0xade682d1,
0x2b3e6c1f,
0xfb41bd6b,
- 0x137e2179
+ 0x137e2179,
+ 0,
+ 0,
};
/* Initialize structure containing state of computation.
void FAST_FUNC sha256_begin(sha256_ctx_t *ctx)
{
memcpy(ctx->hash, init256, sizeof(init256));
- ctx->total64 = 0;
+ /*ctx->total64 = 0; - done by extending init256 with two 32-bit zeros */
ctx->process_block = sha256_process_block64;
}
void FAST_FUNC sha512_begin(sha512_ctx_t *ctx)
{
int i;
- for (i = 0; i < 8; i++)
+ /* Two extra iterations zero out ctx->total64[] */
+ for (i = 0; i < 8+2; i++)
ctx->hash[i] = ((uint64_t)(init256[i]) << 32) + init512_lo[i];
- ctx->total64[0] = ctx->total64[1] = 0;
+ /*ctx->total64[0] = ctx->total64[1] = 0; - already done */
}