/* * Interface for TEE Driver * * Copyright (C) 2016 Samsung Electronics, Inc. * Egor Uleyskiy, * * This software is licensed under the terms of the GNU General Public * License version 2, as published by the Free Software Foundation, and * may be copied, distributed, and modified under those terms. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. */ #ifndef INTEGRITY_TEE_DRIVER_H #define INTEGRITY_TEE_DRIVER_H #include #include struct tee_iovec { enum hash_algo algo; const void *hash; size_t hash_len; const void *label; size_t label_len; void *signature; size_t signature_len; int rc; }; struct five_tee_driver_fns { int (*verify_hmac)(const struct tee_iovec *verify_args); int (*sign_hmac)(struct tee_iovec *sign_args); }; int register_five_tee_driver( struct five_tee_driver_fns *tee_driver_fns); void unregister_five_tee_driver(void); #endif