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
...
...
...
...
...
#ifndef NX_CRYPTO_CCM_H
#define NX_CRYPTO_CCM_H
/* ... */
#ifdef __cplusplus
extern "C" {
#endif
#include "nx_crypto.h"
#define NX_CRYPTO_CCM_BLOCK_SIZE 16
typedef struct NX_CRYPTO_CCM_STRUCT
{
USHORT nx_crypto_ccm_icv_length;
UCHAR nx_crypto_ccm_reserved[2];
UCHAR nx_crypto_ccm_A[NX_CRYPTO_CCM_BLOCK_SIZE];
UCHAR nx_crypto_ccm_X[NX_CRYPTO_CCM_BLOCK_SIZE];
VOID *nx_crypto_ccm_additional_data;
UINT nx_crypto_ccm_additional_data_len;
...} NX_CRYPTO_CCM;
NX_CRYPTO_KEEP UINT _nx_crypto_ccm_encrypt_init(VOID *crypto_metadata, NX_CRYPTO_CCM *ccm_metadata,
UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT),
VOID *additional_data, UINT additional_len,
UINT length, UCHAR *iv, USHORT icv_len, USHORT block_size);
NX_CRYPTO_KEEP UINT _nx_crypto_ccm_encrypt_update(UINT op, VOID *crypto_metadata, NX_CRYPTO_CCM *ccm_metadata,
UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT),
UCHAR *input, UCHAR *output, UINT length, UINT block_size);
NX_CRYPTO_KEEP UINT _nx_crypto_ccm_encrypt_calculate(VOID *crypto_metadata, NX_CRYPTO_CCM *ccm_metadata,
UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT),
UCHAR *icv, UINT block_size);
NX_CRYPTO_KEEP UINT _nx_crypto_ccm_decrypt_calculate(VOID *crypto_metadata, NX_CRYPTO_CCM *ccm_metadata,
UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT),
UCHAR *icv, UINT block_size);
#define _nx_crypto_ccm_decrypt_init _nx_crypto_ccm_encrypt_init
#define _nx_crypto_ccm_decrypt_update _nx_crypto_ccm_encrypt_update
#ifdef __cplusplus
}extern "C" { ... }
#endif
/* ... */
#endif ...