• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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 */