1
10
13
14
20
21
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
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
79
80
81
82
83
84
85
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
...
...
...
...
...
#ifndef NX_CRYPTO_GCM_H
#define NX_CRYPTO_GCM_H
/* ... */
#ifdef __cplusplus
extern "C" {
#endif
#include "nx_crypto.h"
#define NX_CRYPTO_GCM_BLOCK_SIZE 16
#define NX_CRYPTO_GCM_BLOCK_SIZE_BITS 128
#define NX_CRYPTO_GCM_BLOCK_SIZE_INT 4
#define NX_CRYPTO_GCM_BLOCK_SIZE_SHIFT 4
typedef struct NX_CRYPTO_GCM_STRUCT
{
ULONG nx_crypto_gcm_input_total_length;
UCHAR nx_crypto_gcm_hkey[NX_CRYPTO_GCM_BLOCK_SIZE];
UCHAR nx_crypto_gcm_j0[NX_CRYPTO_GCM_BLOCK_SIZE];
UCHAR nx_crypto_gcm_s[NX_CRYPTO_GCM_BLOCK_SIZE];
UCHAR nx_crypto_gcm_counter[NX_CRYPTO_GCM_BLOCK_SIZE];
VOID *nx_crypto_gcm_additional_data;
UINT nx_crypto_gcm_additional_data_len;
...} NX_CRYPTO_GCM;
NX_CRYPTO_KEEP UINT _nx_crypto_gcm_encrypt_init(VOID *crypto_metadata, NX_CRYPTO_GCM *gcm_metadata,
UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT),
VOID *additional_data, UINT additional_len,
UCHAR *iv, UINT block_size);
NX_CRYPTO_KEEP UINT _nx_crypto_gcm_encrypt_update(VOID *crypto_metadata, NX_CRYPTO_GCM *gcm_metadata,
UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT),
UCHAR *input, UCHAR *output, UINT length,
UINT block_size);
NX_CRYPTO_KEEP UINT _nx_crypto_gcm_encrypt_calculate(VOID *crypto_metadata, NX_CRYPTO_GCM *gcm_metadata,
UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT),
UCHAR *output, UINT icv_len, UINT block_size);
NX_CRYPTO_KEEP UINT _nx_crypto_gcm_decrypt_update(VOID *crypto_metadata, NX_CRYPTO_GCM *gcm_metadata,
UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT),
UCHAR *input, UCHAR *output, UINT length,
UINT block_size);
NX_CRYPTO_KEEP UINT _nx_crypto_gcm_decrypt_calculate(VOID *crypto_metadata, NX_CRYPTO_GCM *gcm_metadata,
UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT),
UCHAR *input, UINT icv_len, UINT block_size);
#define _nx_crypto_gcm_decrypt_init _nx_crypto_gcm_encrypt_init
#ifdef __cplusplus
}extern "C" { ... }
#endif
/* ... */
#endif ...