xref: /optee_os/ta/pkcs11/src/token_capabilities.h (revision 512cbf1d30ddce3513abf2b08d4063d5c8415a40)
18849c126SEtienne Carriere /* SPDX-License-Identifier: BSD-2-Clause */
28849c126SEtienne Carriere /*
38849c126SEtienne Carriere  * Copyright (c) 2017-2020, Linaro Limited
48849c126SEtienne Carriere  */
58849c126SEtienne Carriere 
68849c126SEtienne Carriere #ifndef TOKEN_CAPABILITIES_H
78849c126SEtienne Carriere #define TOKEN_CAPABILITIES_H
88849c126SEtienne Carriere 
9c4108388SJens Wiklander #include <pkcs11_ta.h>
10c4108388SJens Wiklander #include <stdbool.h>
11c4108388SJens Wiklander #include <stdint.h>
12c4108388SJens Wiklander 
138849c126SEtienne Carriere bool mechanism_flags_complies_pkcs11(uint32_t mechanism_type, uint32_t flags);
148849c126SEtienne Carriere 
15*512cbf1dSJens Wiklander bool mechanism_is_one_shot_only(uint32_t mechanism_type);
16*512cbf1dSJens Wiklander 
178849c126SEtienne Carriere bool mechanism_is_valid(enum pkcs11_mechanism_id id);
188849c126SEtienne Carriere 
198849c126SEtienne Carriere #if CFG_TEE_TA_LOG_LEVEL > 0
208849c126SEtienne Carriere const char *mechanism_string_id(enum pkcs11_mechanism_id id);
218849c126SEtienne Carriere #endif
228849c126SEtienne Carriere 
238849c126SEtienne Carriere uint32_t *tee_malloc_mechanism_list(size_t *out_count);
248849c126SEtienne Carriere 
258849c126SEtienne Carriere uint32_t mechanism_supported_flags(enum pkcs11_mechanism_id id);
268849c126SEtienne Carriere 
27*512cbf1dSJens Wiklander void mechanism_supported_key_sizes(uint32_t proc_id, uint32_t *min_key_size,
28*512cbf1dSJens Wiklander 				   uint32_t *max_key_size);
29*512cbf1dSJens Wiklander 
308849c126SEtienne Carriere static inline bool mechanism_is_supported(enum pkcs11_mechanism_id id)
318849c126SEtienne Carriere {
328849c126SEtienne Carriere 	return mechanism_supported_flags(id) != 0;
338849c126SEtienne Carriere }
348849c126SEtienne Carriere 
358849c126SEtienne Carriere #endif /*TOKEN_CAPABILITIES_H*/
36