2 OP-TEE specific header file.
4 Copyright (c) 2018, Linaro Ltd. All rights reserved.<BR>
5 Copyright (c) 2021, Arm Limited. All rights reserved.<BR>
7 SPDX-License-Identifier: BSD-2-Clause-Patent
15 * The 'Trusted OS Call UID' is supposed to return the following UUID for
16 * OP-TEE OS. This is a 128-bit value.
18 #define OPTEE_OS_UID0 0x384fb3e0
19 #define OPTEE_OS_UID1 0xe7f811e3
20 #define OPTEE_OS_UID2 0xaf630002
21 #define OPTEE_OS_UID3 0xa5d5c51b
23 #define OPTEE_MESSAGE_ATTRIBUTE_TYPE_NONE 0x0
24 #define OPTEE_MESSAGE_ATTRIBUTE_TYPE_VALUE_INPUT 0x1
25 #define OPTEE_MESSAGE_ATTRIBUTE_TYPE_VALUE_OUTPUT 0x2
26 #define OPTEE_MESSAGE_ATTRIBUTE_TYPE_VALUE_INOUT 0x3
27 #define OPTEE_MESSAGE_ATTRIBUTE_TYPE_MEMORY_INPUT 0x9
28 #define OPTEE_MESSAGE_ATTRIBUTE_TYPE_MEMORY_OUTPUT 0xa
29 #define OPTEE_MESSAGE_ATTRIBUTE_TYPE_MEMORY_INOUT 0xb
31 #define OPTEE_MESSAGE_ATTRIBUTE_TYPE_MASK 0xff
33 #define OPTEE_SUCCESS 0x00000000
34 #define OPTEE_ORIGIN_COMMUNICATION 0x00000002
35 #define OPTEE_ERROR_COMMUNICATION 0xFFFF000E
40 UINT64 SharedMemoryReference
;
41 } OPTEE_MESSAGE_PARAM_MEMORY
;
47 } OPTEE_MESSAGE_PARAM_VALUE
;
50 OPTEE_MESSAGE_PARAM_MEMORY Memory
;
51 OPTEE_MESSAGE_PARAM_VALUE Value
;
52 } OPTEE_MESSAGE_PARAM_UNION
;
56 OPTEE_MESSAGE_PARAM_UNION Union
;
57 } OPTEE_MESSAGE_PARAM
;
59 #define OPTEE_MAX_CALL_PARAMS 4
71 // NumParams tells the actual number of element in Params
72 OPTEE_MESSAGE_PARAM Params
[OPTEE_MAX_CALL_PARAMS
];
76 EFI_GUID Uuid
; // [in] GUID/UUID of the Trusted Application
77 UINT32 Session
; // [out] Session id
78 UINT32 Return
; // [out] Return value
79 UINT32 ReturnOrigin
; // [out] Origin of the return value
80 } OPTEE_OPEN_SESSION_ARG
;
83 UINT32 Function
; // [in] Trusted Application function, specific to the TA
84 UINT32 Session
; // [in] Session id
85 UINT32 Return
; // [out] Return value
86 UINT32 ReturnOrigin
; // [out] Origin of the return value
87 OPTEE_MESSAGE_PARAM Params
[OPTEE_MAX_CALL_PARAMS
]; // Params for function to be invoked
88 } OPTEE_INVOKE_FUNCTION_ARG
;
105 IN OUT OPTEE_OPEN_SESSION_ARG
*OpenSessionArg
116 OpteeInvokeFunction (
117 IN OUT OPTEE_INVOKE_FUNCTION_ARG
*InvokeFunctionArg
120 #endif // OPTEE_LIB_H_