1 /* 2 * Copyright (c) 2016, Freescale Semiconductor, Inc. 3 * Copyright 2017-2020 NXP 4 * 5 * SPDX-License-Identifier: BSD-3-Clause 6 * 7 * Redistribution and use in source and binary forms, with or without modification, 8 * are permitted provided that the following conditions are met: 9 * 10 * o Redistributions of source code must retain the above copyright notice, this list 11 * of conditions and the following disclaimer. 12 * 13 * o Redistributions in binary form must reproduce the above copyright notice, this 14 * list of conditions and the following disclaimer in the documentation and/or 15 * other materials provided with the distribution. 16 * 17 * o Neither the name of the copyright holder nor the names of its 18 * contributors may be used to endorse or promote products derived from this 19 * software without specific prior written permission. 20 * 21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 22 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 23 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 24 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR 25 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 26 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 27 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON 28 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 29 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 30 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 31 */ 32 33 /*! 34 * Header file for the SECO RPC implementation. 35 * 36 * @addtogroup SECO_SVC 37 * @{ 38 */ 39 40 #ifndef SC_SECO_RPC_H 41 #define SC_SECO_RPC_H 42 43 /* Includes */ 44 45 /* Defines */ 46 47 /*! 48 * @name Defines for RPC SECO function calls 49 */ 50 /*@{*/ 51 #define SECO_FUNC_UNKNOWN 0 /*!< Unknown function */ 52 #define SECO_FUNC_IMAGE_LOAD 1U /*!< Index for sc_seco_image_load() RPC call */ 53 #define SECO_FUNC_AUTHENTICATE 2U /*!< Index for sc_seco_authenticate() RPC call */ 54 #define SECO_FUNC_ENH_AUTHENTICATE 24U /*!< Index for sc_seco_enh_authenticate() RPC call */ 55 #define SECO_FUNC_FORWARD_LIFECYCLE 3U /*!< Index for sc_seco_forward_lifecycle() RPC call */ 56 #define SECO_FUNC_RETURN_LIFECYCLE 4U /*!< Index for sc_seco_return_lifecycle() RPC call */ 57 #define SECO_FUNC_COMMIT 5U /*!< Index for sc_seco_commit() RPC call */ 58 #define SECO_FUNC_ATTEST_MODE 6U /*!< Index for sc_seco_attest_mode() RPC call */ 59 #define SECO_FUNC_ATTEST 7U /*!< Index for sc_seco_attest() RPC call */ 60 #define SECO_FUNC_GET_ATTEST_PKEY 8U /*!< Index for sc_seco_get_attest_pkey() RPC call */ 61 #define SECO_FUNC_GET_ATTEST_SIGN 9U /*!< Index for sc_seco_get_attest_sign() RPC call */ 62 #define SECO_FUNC_ATTEST_VERIFY 10U /*!< Index for sc_seco_attest_verify() RPC call */ 63 #define SECO_FUNC_GEN_KEY_BLOB 11U /*!< Index for sc_seco_gen_key_blob() RPC call */ 64 #define SECO_FUNC_LOAD_KEY 12U /*!< Index for sc_seco_load_key() RPC call */ 65 #define SECO_FUNC_GET_MP_KEY 13U /*!< Index for sc_seco_get_mp_key() RPC call */ 66 #define SECO_FUNC_UPDATE_MPMR 14U /*!< Index for sc_seco_update_mpmr() RPC call */ 67 #define SECO_FUNC_GET_MP_SIGN 15U /*!< Index for sc_seco_get_mp_sign() RPC call */ 68 #define SECO_FUNC_BUILD_INFO 16U /*!< Index for sc_seco_build_info() RPC call */ 69 #define SECO_FUNC_CHIP_INFO 17U /*!< Index for sc_seco_chip_info() RPC call */ 70 #define SECO_FUNC_ENABLE_DEBUG 18U /*!< Index for sc_seco_enable_debug() RPC call */ 71 #define SECO_FUNC_GET_EVENT 19U /*!< Index for sc_seco_get_event() RPC call */ 72 #define SECO_FUNC_FUSE_WRITE 20U /*!< Index for sc_seco_fuse_write() RPC call */ 73 #define SECO_FUNC_PATCH 21U /*!< Index for sc_seco_patch() RPC call */ 74 #define SECO_FUNC_SET_MONO_COUNTER_PARTITION 28U /*!< Index for sc_seco_set_mono_counter_partition() RPC call */ 75 #define SECO_FUNC_SET_FIPS_MODE 29U /*!< Index for sc_seco_set_fips_mode() RPC call */ 76 #define SECO_FUNC_START_RNG 22U /*!< Index for sc_seco_start_rng() RPC call */ 77 #define SECO_FUNC_SAB_MSG 23U /*!< Index for sc_seco_sab_msg() RPC call */ 78 #define SECO_FUNC_SECVIO_ENABLE 25U /*!< Index for sc_seco_secvio_enable() RPC call */ 79 #define SECO_FUNC_SECVIO_CONFIG 26U /*!< Index for sc_seco_secvio_config() RPC call */ 80 #define SECO_FUNC_SECVIO_DGO_CONFIG 27U /*!< Index for sc_seco_secvio_dgo_config() RPC call */ 81 /*@}*/ 82 83 /* Types */ 84 85 /* Functions */ 86 87 /*! 88 * This function dispatches an incoming SECO RPC request. 89 * 90 * @param[in] caller_pt caller partition 91 * @param[in] mu MU message came from 92 * @param[in] msg pointer to RPC message 93 */ 94 void seco_dispatch(sc_rm_pt_t caller_pt, sc_rsrc_t mu, sc_rpc_msg_t *msg); 95 96 #endif /* SC_SECO_RPC_H */ 97 98 /**@}*/ 99 100