summaryrefslogtreecommitdiff
path: root/plat/imx/common/sci/svc/seco/sci_seco_rpc.h
blob: ed3fc0615136390cb2edc0732e7c9d75b9bd2057 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/*
 * Copyright (C) 2016 Freescale Semiconductor, Inc.
 * Copyright 2017-2019 NXP
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */

/*!
 * Header file for the SECO RPC implementation.
 *
 * @addtogroup SECO_SVC
 * @{
 */

#ifndef SC_SECO_RPC_H
#define SC_SECO_RPC_H

/* Includes */

/* Defines */

/*!
 * @name Defines for RPC SECO function calls
 */
/*@{*/
#define SECO_FUNC_UNKNOWN 0	/* Unknown function */
#define SECO_FUNC_IMAGE_LOAD 1U	/* Index for sc_seco_image_load() RPC call */
#define SECO_FUNC_AUTHENTICATE 2U	/* Index for sc_seco_authenticate() RPC call */
#define SECO_FUNC_ENH_AUTHENTICATE 24U	/* Index for sc_seco_enh_authenticate() RPC call */
#define SECO_FUNC_FORWARD_LIFECYCLE 3U	/* Index for sc_seco_forward_lifecycle() RPC call */
#define SECO_FUNC_RETURN_LIFECYCLE 4U	/* Index for sc_seco_return_lifecycle() RPC call */
#define SECO_FUNC_COMMIT 5U	/* Index for sc_seco_commit() RPC call */
#define SECO_FUNC_ATTEST_MODE 6U	/* Index for sc_seco_attest_mode() RPC call */
#define SECO_FUNC_ATTEST 7U	/* Index for sc_seco_attest() RPC call */
#define SECO_FUNC_GET_ATTEST_PKEY 8U	/* Index for sc_seco_get_attest_pkey() RPC call */
#define SECO_FUNC_GET_ATTEST_SIGN 9U	/* Index for sc_seco_get_attest_sign() RPC call */
#define SECO_FUNC_ATTEST_VERIFY 10U	/* Index for sc_seco_attest_verify() RPC call */
#define SECO_FUNC_GEN_KEY_BLOB 11U	/* Index for sc_seco_gen_key_blob() RPC call */
#define SECO_FUNC_LOAD_KEY 12U	/* Index for sc_seco_load_key() RPC call */
#define SECO_FUNC_GET_MP_KEY 13U	/* Index for sc_seco_get_mp_key() RPC call */
#define SECO_FUNC_UPDATE_MPMR 14U	/* Index for sc_seco_update_mpmr() RPC call */
#define SECO_FUNC_GET_MP_SIGN 15U	/* Index for sc_seco_get_mp_sign() RPC call */
#define SECO_FUNC_BUILD_INFO 16U	/* Index for sc_seco_build_info() RPC call */
#define SECO_FUNC_CHIP_INFO 17U	/* Index for sc_seco_chip_info() RPC call */
#define SECO_FUNC_ENABLE_DEBUG 18U	/* Index for sc_seco_enable_debug() RPC call */
#define SECO_FUNC_GET_EVENT 19U	/* Index for sc_seco_get_event() RPC call */
#define SECO_FUNC_FUSE_WRITE 20U	/* Index for sc_seco_fuse_write() RPC call */
#define SECO_FUNC_PATCH 21U	/* Index for sc_seco_patch() RPC call */
#define SECO_FUNC_START_RNG 22U	/* Index for sc_seco_start_rng() RPC call */
#define SECO_FUNC_SAB_MSG 23U	/* Index for sc_seco_sab_msg() RPC call */
#define SECO_FUNC_SECVIO_ENABLE 25U	/* Index for sc_seco_secvio_enable() RPC call */
#define SECO_FUNC_SECVIO_CONFIG 26U	/* Index for sc_seco_secvio_config() RPC call */
#define SECO_FUNC_SECVIO_DGO_CONFIG 27U	/* Index for sc_seco_secvio_dgo_config() RPC call */
#define SECO_FUNC_SET_FIPS_MODE 29U /* Index for sc_seco_set_fips_mode() RPC call */
/*@}*/

/* Types */

/* Functions */

/*!
 * This function dispatches an incoming SECO RPC request.
 *
 * @param[in]     caller_pt   caller partition
 * @param[in]     mu          MU message came from
 * @param[in]     msg         pointer to RPC message
 */
void seco_dispatch(sc_rm_pt_t caller_pt, sc_rsrc_t mu, sc_rpc_msg_t *msg);

#endif				/* SC_SECO_RPC_H */

/**@}*/