-
Notifications
You must be signed in to change notification settings - Fork 1
/
aes_hash.h
48 lines (41 loc) · 1.04 KB
/
aes_hash.h
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#ifdef __cplusplus
extern "C" {
#endif
#include <x86intrin.h>
struct aes_hash_state {
union {
__m128i ints[8];
uint8_t chars[128];
} buf;
uint32_t count;
uint32_t block_size;
uint64_t total_len;
__m128i x1;
__m128i x2;
__m128i x3;
__m128i x4;
__m128i x5;
__m128i x6;
__m128i x7;
__m128i x8;
};
struct aes_hash {
uint64_t h[2];
};
typedef struct aes_hash_state aes_hash_state_t;
typedef struct aes_hash aes_hash_t;
/* Streaming interfaces */
void aes_hash_start(aes_hash_state_t * const state);
void aes_hash_start_seed(aes_hash_state_t * const state,
const void * const seed);
void aes_hash_update(aes_hash_state_t * const state, const void * const data,
const size_t len);
void aes_hash_end(aes_hash_state_t * const state, aes_hash_t * const hash);
/* Convenience routines for single shot hashing */
void aes_hash_seed(const void * const data, const size_t len,
const void * const seed, aes_hash_t * const hash);
void aes_hash(const void * const data, const size_t len,
aes_hash_t * const hash);
#ifdef __cplusplus
}
#endif