blob: acb1aee6a532d1e0062b2fb195a4ea37b937a990 [file] [log] [blame]
Pascal Brandc639ac82015-07-02 08:53:34 +02001/*
2 * Copyright (c) 2014, STMicroelectronics International N.V.
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are met:
7 *
8 * 1. Redistributions of source code must retain the above copyright notice,
9 * this list of conditions and the following disclaimer.
10 *
11 * 2. Redistributions in binary form must reproduce the above copyright notice,
12 * this list of conditions and the following disclaimer in the documentation
13 * and/or other materials provided with the distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
16 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
19 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25 * POSSIBILITY OF SUCH DAMAGE.
26 */
27
Pascal Brandc639ac82015-07-02 08:53:34 +020028#include <aes_taf.h>
Jens Wiklander28dfdc42018-11-15 00:29:08 +010029#include <arith_taf.h>
Pascal Brandc639ac82015-07-02 08:53:34 +020030#include <cryp_taf.h>
Jens Wiklandere9babd92018-04-20 11:20:59 +020031#include <mbedtls_taf.h>
Igor Opaniuk7ddaa782018-05-25 15:14:05 +030032#include <seed_rng_taf.h>
Jens Wiklandere9babd92018-04-20 11:20:59 +020033#include <sha2_taf.h>
34#include <ta_crypt.h>
35#include <tee_ta_api.h>
Jens Wiklander065ccfa2015-08-21 14:39:20 +020036#include <trace.h>
Pascal Brandc639ac82015-07-02 08:53:34 +020037
38static TEE_Result set_global(uint32_t param_types, TEE_Param params[4]);
39static TEE_Result get_global(uint32_t param_types, TEE_Param params[4]);
40static int _globalvalue;
41
42/*
43 * Trusted Application Entry Points
44 */
45
46/* Called each time a new instance is created */
47TEE_Result TA_CreateEntryPoint(void)
48{
49 return TEE_SUCCESS;
50}
51
52/* Called each time an instance is destroyed */
53void TA_DestroyEntryPoint(void)
54{
55}
56
57/* Called each time a session is opened */
58TEE_Result TA_OpenSessionEntryPoint(uint32_t nParamTypes,
59 TEE_Param pParams[4],
60 void **ppSessionContext)
61{
62 (void)nParamTypes;
63 (void)pParams;
64 (void)ppSessionContext;
65 return TEE_SUCCESS;
66}
67
68/* Called each time a session is closed */
69void TA_CloseSessionEntryPoint(void *pSessionContext)
70{
71 (void)pSessionContext;
72}
73
Jens Wiklander065ccfa2015-08-21 14:39:20 +020074/*
75 * To provoke the linker to produce R_ARM_ABS32 relocations we need to
76 * pre-initilize a pointer to the function and then also call the function
77 * directly.
78 */
79static TEE_Result (*ta_cmd_entries[])(uint32_t, TEE_Param *) = {
80 [TA_CRYPT_CMD_SHA224] = ta_entry_sha224,
81 [TA_CRYPT_CMD_SHA256] = ta_entry_sha256,
82};
83
Pascal Brandc639ac82015-07-02 08:53:34 +020084/* Called when a command is invoked */
85TEE_Result TA_InvokeCommandEntryPoint(void *pSessionContext,
86 uint32_t nCommandID, uint32_t nParamTypes,
87 TEE_Param pParams[4])
88{
Jens Wiklander065ccfa2015-08-21 14:39:20 +020089 static bool use_fptr = false;
90
Pascal Brandc639ac82015-07-02 08:53:34 +020091 (void)pSessionContext;
92
Jens Wiklander065ccfa2015-08-21 14:39:20 +020093
Pascal Brandc639ac82015-07-02 08:53:34 +020094 switch (nCommandID) {
95 case TA_CRYPT_CMD_SHA224:
Jens Wiklander065ccfa2015-08-21 14:39:20 +020096 use_fptr = !use_fptr;
97 if (use_fptr)
98 return ta_cmd_entries[nCommandID](nParamTypes, pParams);
99 else
100 return ta_entry_sha224(nParamTypes, pParams);
Pascal Brandc639ac82015-07-02 08:53:34 +0200101
102 case TA_CRYPT_CMD_SHA256:
Jens Wiklander065ccfa2015-08-21 14:39:20 +0200103 use_fptr = !use_fptr;
104 if (use_fptr)
105 return ta_cmd_entries[nCommandID](nParamTypes, pParams);
106 else
107 return ta_entry_sha256(nParamTypes, pParams);
Pascal Brandc639ac82015-07-02 08:53:34 +0200108
109 case TA_CRYPT_CMD_AES256ECB_ENC:
110 return ta_entry_aes256ecb_encrypt(nParamTypes, pParams);
111
112 case TA_CRYPT_CMD_AES256ECB_DEC:
113 return ta_entry_aes256ecb_decrypt(nParamTypes, pParams);
114
115 case TA_CRYPT_CMD_ALLOCATE_OPERATION:
116 return ta_entry_allocate_operation(nParamTypes, pParams);
117
118 case TA_CRYPT_CMD_FREE_OPERATION:
119 return ta_entry_free_operation(nParamTypes, pParams);
120
121 case TA_CRYPT_CMD_GET_OPERATION_INFO:
122 return ta_entry_get_operation_info(nParamTypes, pParams);
123
124 case TA_CRYPT_CMD_RESET_OPERATION:
125 return ta_entry_reset_operation(nParamTypes, pParams);
126
127 case TA_CRYPT_CMD_SET_OPERATION_KEY:
128 return ta_entry_set_operation_key(nParamTypes, pParams);
129
130 case TA_CRYPT_CMD_SET_OPERATION_KEY2:
131 return ta_entry_set_operation_key2(nParamTypes, pParams);
132
133 case TA_CRYPT_CMD_COPY_OPERATION:
134 return ta_entry_copy_operation(nParamTypes, pParams);
135
136 case TA_CRYPT_CMD_DIGEST_UPDATE:
137 return ta_entry_digest_update(nParamTypes, pParams);
138
139 case TA_CRYPT_CMD_DIGEST_DO_FINAL:
140 return ta_entry_digest_do_final(nParamTypes, pParams);
141
142 case TA_CRYPT_CMD_CIPHER_INIT:
143 return ta_entry_cipher_init(nParamTypes, pParams);
144
145 case TA_CRYPT_CMD_CIPHER_UPDATE:
146 return ta_entry_cipher_update(nParamTypes, pParams);
147
148 case TA_CRYPT_CMD_CIPHER_DO_FINAL:
149 return ta_entry_cipher_do_final(nParamTypes, pParams);
150
151 case TA_CRYPT_CMD_MAC_INIT:
152 return ta_entry_mac_init(nParamTypes, pParams);
153
154 case TA_CRYPT_CMD_MAC_UPDATE:
155 return ta_entry_mac_update(nParamTypes, pParams);
156
157 case TA_CRYPT_CMD_MAC_FINAL_COMPUTE:
158 return ta_entry_mac_final_compute(nParamTypes, pParams);
159
160 case TA_CRYPT_CMD_MAC_FINAL_COMPARE:
161 return ta_entry_mac_final_compare(nParamTypes, pParams);
162
163 case TA_CRYPT_CMD_ALLOCATE_TRANSIENT_OBJECT:
164 return ta_entry_allocate_transient_object(nParamTypes, pParams);
165
166 case TA_CRYPT_CMD_FREE_TRANSIENT_OBJECT:
167 return ta_entry_free_transient_object(nParamTypes, pParams);
168
169 case TA_CRYPT_CMD_RESET_TRANSIENT_OBJECT:
170 return ta_entry_reset_transient_object(nParamTypes, pParams);
171
172 case TA_CRYPT_CMD_POPULATE_TRANSIENT_OBJECT:
173 return ta_entry_populate_transient_object(nParamTypes, pParams);
174
175 case TA_CRYPT_CMD_COPY_OBJECT_ATTRIBUTES:
176 return ta_entry_copy_object_attributes(nParamTypes, pParams);
177
178 case TA_CRYPT_CMD_GENERATE_KEY:
179 return ta_entry_generate_key(nParamTypes, pParams);
180
181 case TA_CRYPT_CMD_ASYMMETRIC_ENCRYPT:
182 return ta_entry_asymmetric_encrypt(nParamTypes, pParams);
183
184 case TA_CRYPT_CMD_ASYMMETRIC_DECRYPT:
185 return ta_entry_asymmetric_decrypt(nParamTypes, pParams);
186
187 case TA_CRYPT_CMD_ASYMMETRIC_SIGN_DIGEST:
188 return ta_entry_asymmetric_sign_digest(nParamTypes, pParams);
189
190 case TA_CRYPT_CMD_ASYMMETRIC_VERIFY_DIGEST:
191 return ta_entry_asymmetric_verify_digest(nParamTypes, pParams);
192
193 case TA_CRYPT_CMD_DERIVE_KEY:
194 return ta_entry_derive_key(nParamTypes, pParams);
195
196 case TA_CRYPT_CMD_RANDOM_NUMBER_GENEREATE:
197 return ta_entry_random_number_generate(nParamTypes, pParams);
198
199 case TA_CRYPT_CMD_AE_INIT:
200 return ta_entry_ae_init(nParamTypes, pParams);
201
202 case TA_CRYPT_CMD_AE_UPDATE_AAD:
203 return ta_entry_ae_update_aad(nParamTypes, pParams);
204
205 case TA_CRYPT_CMD_AE_UPDATE:
206 return ta_entry_ae_update(nParamTypes, pParams);
207
208 case TA_CRYPT_CMD_AE_ENCRYPT_FINAL:
209 return ta_entry_ae_encrypt_final(nParamTypes, pParams);
210
211 case TA_CRYPT_CMD_AE_DECRYPT_FINAL:
212 return ta_entry_ae_decrypt_final(nParamTypes, pParams);
213
214 case TA_CRYPT_CMD_GET_OBJECT_BUFFER_ATTRIBUTE:
215 return ta_entry_get_object_buffer_attribute(nParamTypes,
216 pParams);
217 case TA_CRYPT_CMD_GET_OBJECT_VALUE_ATTRIBUTE:
218 return ta_entry_get_object_value_attribute(nParamTypes,
219 pParams);
220 case TA_CRYPT_CMD_SETGLOBAL:
221 return set_global(nParamTypes, pParams);
222
223 case TA_CRYPT_CMD_GETGLOBAL:
224 return get_global(nParamTypes, pParams);
225
Jens Wiklandere9babd92018-04-20 11:20:59 +0200226#ifdef CFG_TA_MBEDTLS
227 case TA_CRYPT_CMD_MBEDTLS_SELF_TESTS:
228 return ta_entry_mbedtls_self_tests(nParamTypes, pParams);
Jens Wiklanderf7ffa642018-04-20 16:25:21 +0200229 case TA_CRYPT_CMD_MBEDTLS_CHECK_CERT:
230 return ta_entry_mbedtls_check_cert(nParamTypes, pParams);
Jens Wiklanderda0208e2018-04-30 09:34:01 +0200231 case TA_CRYPT_CMD_MBEDTLS_SIGN_CERT:
232 return ta_entry_mbedtls_sign_cert(nParamTypes, pParams);
Jens Wiklandere9babd92018-04-20 11:20:59 +0200233#endif
Igor Opaniuk7ddaa782018-05-25 15:14:05 +0300234#ifdef CFG_SYSTEM_PTA
235 case TA_CRYPT_CMD_SEED_RNG_POOL:
236 return seed_rng_pool(nParamTypes, pParams);
237#endif
Jens Wiklander28dfdc42018-11-15 00:29:08 +0100238 case TA_CRYPT_CMD_ARITH_NEW_VAR:
239 return ta_entry_arith_new_var(nParamTypes, pParams);
240 case TA_CRYPT_CMD_ARITH_NEW_FMM_CTX:
241 return ta_entry_arith_new_fmm_ctx(nParamTypes, pParams);
242 case TA_CRYPT_CMD_ARITH_NEW_FMM_VAR:
243 return ta_entry_arith_new_fmm_var(nParamTypes, pParams);
244 case TA_CRYPT_CMD_ARITH_FREE_HANDLE:
245 return ta_entry_arith_free_handle(nParamTypes, pParams);
246 case TA_CRYPT_CMD_ARITH_FROM_OCTET_STRING:
247 return ta_entry_arith_from_octet_string(nParamTypes, pParams);
248 case TA_CRYPT_CMD_ARITH_FROM_S32:
249 return ta_entry_arith_from_s32(nParamTypes, pParams);
250 case TA_CRYPT_CMD_ARITH_GET_VALUE:
251 return ta_entry_arith_get_value(nParamTypes, pParams);
252 case TA_CRYPT_CMD_ARITH_GET_VALUE_S32:
253 return ta_entry_arith_get_value_s32(nParamTypes, pParams);
254 case TA_CRYPT_CMD_ARITH_GET_BIT:
255 return ta_entry_arith_get_bit(nParamTypes, pParams);
256 case TA_CRYPT_CMD_ARITH_GET_BIT_COUNT:
257 return ta_entry_arith_get_bit_count(nParamTypes, pParams);
258 case TA_CRYPT_CMD_ARITH_SHIFT_RIGHT:
259 return ta_entry_arith_shift_right(nParamTypes, pParams);
260 case TA_CRYPT_CMD_ARITH_CMP:
261 return ta_entry_arith_cmp(nParamTypes, pParams);
262 case TA_CRYPT_CMD_ARITH_CMP_S32:
263 return ta_entry_arith_cmp_s32(nParamTypes, pParams);
264 case TA_CRYPT_CMD_ARITH_ADD:
265 return ta_entry_arith_add(nParamTypes, pParams);
266 case TA_CRYPT_CMD_ARITH_SUB:
267 return ta_entry_arith_sub(nParamTypes, pParams);
268 case TA_CRYPT_CMD_ARITH_MUL:
269 return ta_entry_arith_mul(nParamTypes, pParams);
270 case TA_CRYPT_CMD_ARITH_NEG:
271 return ta_entry_arith_neg(nParamTypes, pParams);
272 case TA_CRYPT_CMD_ARITH_SQR:
273 return ta_entry_arith_sqr(nParamTypes, pParams);
274 case TA_CRYPT_CMD_ARITH_DIV:
275 return ta_entry_arith_div(nParamTypes, pParams);
276 case TA_CRYPT_CMD_ARITH_MOD:
277 return ta_entry_arith_mod(nParamTypes, pParams);
278 case TA_CRYPT_CMD_ARITH_ADDMOD:
279 return ta_entry_arith_addmod(nParamTypes, pParams);
280 case TA_CRYPT_CMD_ARITH_SUBMOD:
281 return ta_entry_arith_submod(nParamTypes, pParams);
282 case TA_CRYPT_CMD_ARITH_MULMOD:
283 return ta_entry_arith_mulmod(nParamTypes, pParams);
284 case TA_CRYPT_CMD_ARITH_SQRMOD:
285 return ta_entry_arith_sqrmod(nParamTypes, pParams);
286 case TA_CRYPT_CMD_ARITH_INVMOD:
287 return ta_entry_arith_invmod(nParamTypes, pParams);
288 case TA_CRYPT_CMD_ARITH_IS_RELATIVE_PRIME:
289 return ta_entry_arith_is_rel_prime(nParamTypes, pParams);
290 case TA_CRYPT_CMD_ARITH_COMPUTE_EGCD:
291 return ta_entry_arith_compute_egcd(nParamTypes, pParams);
292 case TA_CRYPT_CMD_ARITH_IS_PRIME:
293 return ta_entry_arith_is_prime(nParamTypes, pParams);
294 case TA_CRYPT_CMD_ARITH_TO_FMM:
295 return ta_entry_arith_to_fmm(nParamTypes, pParams);
296 case TA_CRYPT_CMD_ARITH_FROM_FMM:
297 return ta_entry_arith_from_fmm(nParamTypes, pParams);
298 case TA_CRYPT_CMD_ARITH_COMPUTE_FMM:
299 return ta_entry_arith_compute_fmm(nParamTypes, pParams);
300
Pascal Brandc639ac82015-07-02 08:53:34 +0200301 default:
302 return TEE_ERROR_BAD_PARAMETERS;
303 }
304}
305
306static TEE_Result set_global(uint32_t param_types, TEE_Param params[4])
307{
308 int i;
309
310 /* Param 0 is a memref, input/output */
311 if (TEE_PARAM_TYPE_VALUE_INPUT != TEE_PARAM_TYPE_GET(param_types, 0))
312 return TEE_ERROR_BAD_PARAMETERS;
313
314 /* Other parameters must be of type TEE_PARAM_TYPE_NONE */
315 for (i = 1; i < 4; i++) {
316 if (TEE_PARAM_TYPE_NONE != TEE_PARAM_TYPE_GET(param_types, i))
317 return TEE_ERROR_BAD_PARAMETERS;
318 }
319
320 _globalvalue = params[0].value.a;
321 return TEE_SUCCESS;
322}
323
324static TEE_Result get_global(uint32_t param_types, TEE_Param params[4])
325{
326 int i;
327
328 /* Param 0 is a memref, input/output */
329 if (TEE_PARAM_TYPE_VALUE_OUTPUT != TEE_PARAM_TYPE_GET(param_types, 0))
330 return TEE_ERROR_BAD_PARAMETERS;
331
332 /* Other parameters must be of type TEE_PARAM_TYPE_NONE */
333 for (i = 1; i < 4; i++) {
334 if (TEE_PARAM_TYPE_NONE != TEE_PARAM_TYPE_GET(param_types, i))
335 return TEE_ERROR_BAD_PARAMETERS;
336 }
337
338 params[0].value.a = _globalvalue;
339 return TEE_SUCCESS;
340}