1
10
13
14
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
61
62
63
64
65
66
67
68
69
70
71
72
75
76
77
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
...
...
...
...
#ifndef SRC_NX_CRYPTO_SHA5_H_
#define SRC_NX_CRYPTO_SHA5_H_
/* ... */
#ifdef __cplusplus
extern "C" {
#endif
#include "nx_crypto.h"
#ifndef ULONG64_DEFINED
#define ULONG64_DEFINED
#define ULONG64 unsigned long long
/* ... */#endif
#define NX_CRYPTO_SHA512_BLOCK_SIZE_IN_BYTES 128
#define NX_CRYPTO_SHA384_ICV_LEN_IN_BITS 384
#define NX_CRYPTO_SHA512_ICV_LEN_IN_BITS 512
#define NX_CRYPTO_SHA512_224_ICV_LEN_IN_BITS 224
#define NX_CRYPTO_SHA512_256_ICV_LEN_IN_BITS 256
#define NX_SHA512 NX_CRYPTO_SHA512
6 defines
typedef struct NX_CRYPTO_SHA512_STRUCT
{
ULONG64 nx_sha512_states[8];
ULONG64 nx_sha512_bit_count[2];
UCHAR nx_sha512_buffer[NX_CRYPTO_SHA512_BLOCK_SIZE_IN_BYTES];
ULONG64 nx_sha512_word_array[128];
...} NX_CRYPTO_SHA512;
UINT _nx_crypto_sha512_initialize(NX_CRYPTO_SHA512 *context, UINT algorithm);
UINT _nx_crypto_sha512_update(NX_CRYPTO_SHA512 *context, UCHAR *input_ptr, UINT input_length);
UINT _nx_crypto_sha512_digest_calculate(NX_CRYPTO_SHA512 *context, UCHAR *digest, UINT algorithm);
VOID _nx_crypto_sha512_process_buffer(NX_CRYPTO_SHA512 *context, UCHAR *buffer);
UINT _nx_crypto_method_sha512_init(struct NX_CRYPTO_METHOD_STRUCT *method,
UCHAR *key, NX_CRYPTO_KEY_SIZE key_size_in_bits,
VOID **handle,
VOID *crypto_metadata,
ULONG crypto_metadata_size);
UINT _nx_crypto_method_sha512_cleanup(VOID *crypto_metadata);
UINT _nx_crypto_method_sha512_operation(UINT op,
VOID *handle,
struct NX_CRYPTO_METHOD_STRUCT *method,
UCHAR *key, NX_CRYPTO_KEY_SIZE key_size_in_bits,
UCHAR *input, ULONG input_length_in_byte,
UCHAR *iv_ptr,
UCHAR *output, ULONG output_length_in_byte,
VOID *crypto_metadata, ULONG crypto_metadata_size,
VOID *packet_ptr,
VOID (*nx_crypto_hw_process_callback)(VOID *packet_ptr, UINT status));
#ifdef __cplusplus
}extern "C" { ... }
#endif
/* ... */
#endif ...