-
Notifications
You must be signed in to change notification settings - Fork 129
/
Copy pathqat_hw_kpt.h
163 lines (149 loc) · 5.56 KB
/
qat_hw_kpt.h
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
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
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
#ifndef __QAT_HW_KPT_H__
# define __QAT_HW_KPT_H__
/* Openssl */
# include <openssl/bio.h>
# include <openssl/pem.h>
# include <openssl/rsa.h>
# include <openssl/ec.h>
# include <openssl/x509.h>
# include <openssl/x509v3.h>
# include <openssl/asn1t.h>
/* QAT includes */
# include "cpa.h"
# include "cpa_cy_im.h"
# include "cpa_cy_kpt.h"
# include "qae_mem.h"
# include "qae_mem_utils.h"
# include "icp_sal_versions.h"
# include "icp_sal_poll.h"
/* Local Includes */
# include "qat_utils.h"
/* KPT2 Library Includes */
# include "kpt.h"
/******************************************************************************
* function:
* EVP_PKEY *qat_hw_kpt_load_privkey(ENGINE *e, const char *wpk)
*
* @param e [IN] - OpenSSL engine pointer
* @param wpk [IN] - Path of WPK file
*
* @return - Openssl EVP_PKEY key struct
*
* description:
* WPK file loading and parsing function. It will retrieve key information from
* ASN1 encoded stream and save the data into EVP_PKEY->ex_data for later usage.
*
******************************************************************************/
EVP_PKEY *qat_hw_kpt_load_privkey(ENGINE *e, const char *wpk);
/******************************************************************************
* function:
* qat_hw_kpt_init()
*
* @return - 1 represent successful, 0 represent failed
*
* description:
* KPT init functions. Provision the ESWK to QAT HW devices.
*
******************************************************************************/
int qat_hw_kpt_init();
/******************************************************************************
* function:
* void qat_hw_kpt_finish();
*
* description:
* KPT finish functions. Delete the provisioned SWK.
*
******************************************************************************/
void qat_hw_kpt_finish();
/******************************************************************************
* function:
* int is_kpt_mode(void);
*
* @return - 1 represent KPT mode, 0 represent Non-KPT mode.
*
* description:
* KPT mode availability check.
*
******************************************************************************/
int is_kpt_mode(void);
/******************************************************************************
* function:
* qat_check_rsa_wpk(RSA *rsa);
*
* @return - 1 represent the RSA WPK is used, 0 represent the opposition.
*
* description:
* Check whether the RSA Wrapped Private Key is used.
*
******************************************************************************/
int qat_check_rsa_wpk(RSA *rsa);
/******************************************************************************
* function:
* qat_hw_kpt_rsa_priv_enc (int flen,
* const unsigned char *from,
* unsigned char *to,
* RSA *rsa,
* int padding)
*
* @param flen [IN] - length in bytes of input file
* @param from [IN] - pointer to the input file
* @param to [OUT] - pointer to output signature
* @param rsa [IN] - pointer to private key structure
* @param padding [IN] - Padding scheme
*
* description: Perform a KPT RSA private encrypt (RSA Sign)
* We use the decrypt implementation to achieve this.
******************************************************************************/
int qat_hw_kpt_rsa_priv_enc(int flen, const unsigned char *from,
unsigned char *to, RSA *rsa, int padding);
/******************************************************************************
* function:
* qat_hw_kpt_rsa_priv_dec(int flen,
* const unsigned char *from,
* unsigned char *to,
* RSA * rsa,
* int padding)
*
* @param flen [IN] - length in bytes of input
* @param from [IN] - pointer to the input
* @param to [OUT] - pointer to output
* @param rsa [IN] - pointer to the private key structure
* @param padding [IN] - Padding scheme
*
* description:
* description: Perform a KPT RSA private decrypt. (RSA Decrypt)
******************************************************************************/
int qat_hw_kpt_rsa_priv_dec(int flen, const unsigned char *from,
unsigned char *to, RSA *rsa, int padding);
/******************************************************************************
* function:
* qat_check_ec_wpk(EC_KEY *eckey);
*
* @return - 1 represent the EC WPK is used, 0 represent the opposition.
*
* description:
* Check whether the EC Wrapped Private Key is used.
*
******************************************************************************/
int qat_check_ec_wpk(EC_KEY *eckey);
/******************************************************************************
* function:
* qat_hw_kpt_ecdsa_do_sign (const unsigned char *dgst,
* int dgst_len,
* const BIGNUM *in_kinv,
* const BIGNUM *in_r,
* EC_KEY *eckey)
*
* @param dgst [IN] - digest to be signed
* @param dgst_len [IN] - length in bytes of digest
* @param in_kinv [IN] - pointer to k_inv
* @param in_r [IN] - pointer to r
* @param eckey [IN] - pointer to the private key structure
* @return
*
* description: Perform a KPT ECDSA operation.
******************************************************************************/
ECDSA_SIG *qat_hw_kpt_ecdsa_do_sign(const unsigned char *dgst, int dgst_len,
const BIGNUM *in_kinv, const BIGNUM *in_r,
EC_KEY *eckey);
#endif