-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathsha1.h
More file actions
78 lines (67 loc) · 1.5 KB
/
sha1.h
File metadata and controls
78 lines (67 loc) · 1.5 KB
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#ifndef _SHA1_H
#define _SHA1_H
/** @file
*
* SHA-1 algorithm
*
*/
#include <stdint.h>
/** An SHA-1 digest */
struct sha1_digest
{
/** Hash output */
uint32_t h[5];
};
/** An SHA-1 data block */
union sha1_block
{
/** Raw bytes */
uint8_t byte[64];
/** Raw dwords */
uint32_t dword[16];
/** Final block structure */
struct
{
/** Padding */
uint8_t pad[56];
/** Length in bits */
uint64_t len;
} final;
};
/** SHA-1 digest and data block
*
* The order of fields within this structure is designed to minimise
* code size.
*/
struct sha1_digest_data
{
/** Digest of data already processed */
struct sha1_digest digest;
/** Accumulated data */
union sha1_block data;
} __attribute__ ((packed));
/** SHA-1 digest and data block */
union sha1_digest_data_dwords
{
/** Digest and data block */
struct sha1_digest_data dd;
/** Raw dwords */
uint32_t dword[ sizeof (struct sha1_digest_data) /
sizeof (uint32_t) ];
};
/** An SHA-1 context */
struct sha1_context
{
/** Amount of accumulated data */
size_t len;
/** Digest and accumulated data */
union sha1_digest_data_dwords ddd;
} __attribute__ ((packed));
/** SHA-1 context size */
#define SHA1_CTX_SIZE sizeof ( struct sha1_context )
/** SHA-1 digest size */
#define SHA1_DIGEST_SIZE sizeof ( struct sha1_digest )
extern void sha1_init (void *ctx);
extern void sha1_update (void *ctx, const void *data, size_t len);
extern void sha1_final (void *ctx, void *out);
#endif /* _SHA1_H */