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
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
122
123
124
125
126
127
128
129
130
131
132
...
...
...
...
...
#ifndef NX_CRYPTO_RSA_H
#define NX_CRYPTO_RSA_H
/* ... */
#ifdef __cplusplus
extern "C" {
#endif
#include "nx_crypto.h"
#ifndef NX_CRYPTO_MAX_RSA_MODULUS_SIZE
#define NX_CRYPTO_MAX_RSA_MODULUS_SIZE (4096)
#endif
/* ... */
#define NX_CRYPTO_RSA_SCRATCH_BUFFER_SIZE (((10 * (NX_CRYPTO_MAX_RSA_MODULUS_SIZE / 8)) + 24) / sizeof(USHORT))
typedef struct NX_CRYPTO_RSA_STRUCT
{
UCHAR *nx_crypto_rsa_modulus;
UINT nx_crypto_rsa_modulus_length;
UCHAR *nx_crypto_rsa_prime_p;
UINT nx_crypto_rsa_prime_p_length;
UCHAR *nx_crypto_rsa_prime_q;
UINT nx_crypto_rsa_prime_q_length;
USHORT nx_crypto_rsa_scratch_buffer[NX_CRYPTO_RSA_SCRATCH_BUFFER_SIZE];
...} NX_CRYPTO_RSA;
UINT _nx_crypto_rsa_operation(const UCHAR *exponent, UINT exponent_length, const UCHAR *modulus, UINT modulus_length,
const UCHAR *p, UINT p_length, UCHAR *q, UINT q_length,
const UCHAR *input, UINT input_length, UCHAR *output,
USHORT *scratch_buf_ptr, UINT scratch_buf_length);
UINT _nx_crypto_method_rsa_cleanup(VOID *crypto_metadata);
UINT _nx_crypto_method_rsa_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));
UINT _nx_crypto_method_rsa_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);
#ifdef __cplusplus
}extern "C" { ... }
#endif
/* ... */
#endif ...