1 /*
2 * This file is part of the openHiTLS project.
3 *
4 * openHiTLS is licensed under the Mulan PSL v2.
5 * You can use this software according to the terms and conditions of the Mulan PSL v2.
6 * You may obtain a copy of Mulan PSL v2 at:
7 *
8 * http://license.coscl.org.cn/MulanPSL2
9 *
10 * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
11 * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
12 * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
13 * See the Mulan PSL v2 for more details.
14 */
15
16 #include "hitls_build.h"
17 #ifdef HITLS_CRYPTO_PROVIDER
18
19 #include "crypt_eal_implprovider.h"
20 #include "crypt_pbkdf2.h"
21 #include "crypt_kdf_tls12.h"
22 #include "crypt_hkdf.h"
23 #include "crypt_scrypt.h"
24 #include "bsl_sal.h"
25 #include "crypt_errno.h"
26 #include "bsl_log_internal.h"
27 #include "bsl_err_internal.h"
28
29
CRYPT_EAL_DefKdfNewCtx(void * provCtx,int32_t algId)30 void *CRYPT_EAL_DefKdfNewCtx(void *provCtx, int32_t algId)
31 {
32 (void) provCtx;
33
34 switch (algId) {
35 #ifdef HITLS_CRYPTO_SCRYPT
36 case CRYPT_KDF_SCRYPT:
37 return CRYPT_SCRYPT_NewCtx();
38 #endif
39 #ifdef HITLS_CRYPTO_PBKDF2
40 case CRYPT_KDF_PBKDF2:
41 return CRYPT_PBKDF2_NewCtx();
42 #endif
43 #ifdef HITLS_CRYPTO_KDFTLS12
44 case CRYPT_KDF_KDFTLS12:
45 return CRYPT_KDFTLS12_NewCtx();
46 #endif
47 #ifdef HITLS_CRYPTO_HKDF
48 case CRYPT_KDF_HKDF:
49 return CRYPT_HKDF_NewCtx();
50 #endif
51 default:
52 BSL_ERR_PUSH_ERROR(CRYPT_PROVIDER_NOT_SUPPORT);
53 return NULL;
54 }
55 }
56
CRYPT_EAL_DefKdfCtrl(void * ctx,int32_t cmd,void * val,uint32_t valLen)57 int32_t CRYPT_EAL_DefKdfCtrl(void *ctx, int32_t cmd, void *val, uint32_t valLen)
58 {
59 (void) ctx;
60 (void) cmd;
61 (void) val;
62 (void) valLen;
63 BSL_ERR_PUSH_ERROR(CRYPT_NOT_SUPPORT);
64 return CRYPT_NOT_SUPPORT;
65 }
66
67 const CRYPT_EAL_Func g_defEalKdfScrypt[] = {
68 #ifdef HITLS_CRYPTO_SCRYPT
69 {CRYPT_EAL_IMPLKDF_NEWCTX, (CRYPT_EAL_ImplKdfNewCtx)CRYPT_EAL_DefKdfNewCtx},
70 {CRYPT_EAL_IMPLKDF_SETPARAM, (CRYPT_EAL_ImplKdfSetParam)CRYPT_SCRYPT_SetParam},
71 {CRYPT_EAL_IMPLKDF_DERIVE, (CRYPT_EAL_ImplKdfDerive)CRYPT_SCRYPT_Derive},
72 {CRYPT_EAL_IMPLKDF_DEINITCTX, (CRYPT_EAL_ImplKdfDeInitCtx)CRYPT_SCRYPT_Deinit},
73 {CRYPT_EAL_IMPLKDF_CTRL, (CRYPT_EAL_ImplKdfCtrl)CRYPT_EAL_DefKdfCtrl},
74 {CRYPT_EAL_IMPLKDF_FREECTX, (CRYPT_EAL_ImplKdfFreeCtx)CRYPT_SCRYPT_FreeCtx},
75 #endif
76 CRYPT_EAL_FUNC_END,
77 };
78
79 const CRYPT_EAL_Func g_defEalKdfPBKdf2[] = {
80 #ifdef HITLS_CRYPTO_PBKDF2
81 {CRYPT_EAL_IMPLKDF_NEWCTX, (CRYPT_EAL_ImplKdfNewCtx)CRYPT_EAL_DefKdfNewCtx},
82 {CRYPT_EAL_IMPLKDF_SETPARAM, (CRYPT_EAL_ImplKdfSetParam)CRYPT_PBKDF2_SetParam},
83 {CRYPT_EAL_IMPLKDF_DERIVE, (CRYPT_EAL_ImplKdfDerive)CRYPT_PBKDF2_Derive},
84 {CRYPT_EAL_IMPLKDF_DEINITCTX, (CRYPT_EAL_ImplKdfDeInitCtx)CRYPT_PBKDF2_Deinit},
85 {CRYPT_EAL_IMPLKDF_CTRL, (CRYPT_EAL_ImplKdfCtrl)CRYPT_EAL_DefKdfCtrl},
86 {CRYPT_EAL_IMPLKDF_FREECTX, (CRYPT_EAL_ImplKdfFreeCtx)CRYPT_PBKDF2_FreeCtx},
87 #endif
88 CRYPT_EAL_FUNC_END,
89 };
90
91 const CRYPT_EAL_Func g_defEalKdfKdfTLS12[] = {
92 #ifdef HITLS_CRYPTO_KDFTLS12
93 {CRYPT_EAL_IMPLKDF_NEWCTX, (CRYPT_EAL_ImplKdfNewCtx)CRYPT_EAL_DefKdfNewCtx},
94 {CRYPT_EAL_IMPLKDF_SETPARAM, (CRYPT_EAL_ImplKdfSetParam)CRYPT_KDFTLS12_SetParam},
95 {CRYPT_EAL_IMPLKDF_DERIVE, (CRYPT_EAL_ImplKdfDerive)CRYPT_KDFTLS12_Derive},
96 {CRYPT_EAL_IMPLKDF_DEINITCTX, (CRYPT_EAL_ImplKdfDeInitCtx)CRYPT_KDFTLS12_Deinit},
97 {CRYPT_EAL_IMPLKDF_CTRL, (CRYPT_EAL_ImplKdfCtrl)CRYPT_EAL_DefKdfCtrl},
98 {CRYPT_EAL_IMPLKDF_FREECTX, (CRYPT_EAL_ImplKdfFreeCtx)CRYPT_KDFTLS12_FreeCtx},
99 #endif
100 CRYPT_EAL_FUNC_END,
101 };
102
103 const CRYPT_EAL_Func g_defEalKdfHkdf[] = {
104 #ifdef HITLS_CRYPTO_HKDF
105 {CRYPT_EAL_IMPLKDF_NEWCTX, (CRYPT_EAL_ImplKdfNewCtx)CRYPT_EAL_DefKdfNewCtx},
106 {CRYPT_EAL_IMPLKDF_SETPARAM, (CRYPT_EAL_ImplKdfSetParam)CRYPT_HKDF_SetParam},
107 {CRYPT_EAL_IMPLKDF_DERIVE, (CRYPT_EAL_ImplKdfDerive)CRYPT_HKDF_Derive},
108 {CRYPT_EAL_IMPLKDF_DEINITCTX, (CRYPT_EAL_ImplKdfDeInitCtx)CRYPT_HKDF_Deinit},
109 {CRYPT_EAL_IMPLKDF_CTRL, (CRYPT_EAL_ImplKdfCtrl)CRYPT_EAL_DefKdfCtrl},
110 {CRYPT_EAL_IMPLKDF_FREECTX, (CRYPT_EAL_ImplKdfFreeCtx)CRYPT_HKDF_FreeCtx},
111 #endif
112 CRYPT_EAL_FUNC_END,
113 };
114
115 #endif /* HITLS_CRYPTO_PROVIDER */