blob: b0eff29db78c0f79cd82e9a243e3f4b3e13a26c2 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
/* See LICENSE file for copyright and license details. */
#include "common.h"
/**
* Absorb more of the message
*
* @param state The hashing state
* @param message The message, in bits, must be equivalent to 0 modulus 8
* @param msglen The length of the message
*/
void
libsha2_update(struct libsha2_state *restrict state, const char *restrict message, size_t msglen) /* TODO avoid coping */
{
size_t n, off, mlen;
msglen /= 8;
mlen = state->message_size / 8;
while (msglen) {
off = mlen % state->chunk_size;
n = state->chunk_size - off;
n = n < msglen ? n : msglen;
memcpy(state->chunk + off, message, n);
if (off + n == state->chunk_size)
libsha2_process(state, state->chunk);
message += n, mlen += n, msglen -= n;
}
state->message_size = mlen * 8;
}
|